我有一个/token
正在使用password
授权的端点。因为它对JWT
令牌进行编码,所以它具有大约 1 秒的高延迟。有没有办法让 JWT 签名更快?
我正在使用 Go 与github.com/dgrijalva/jwt-go
图书馆。
package main
import (
"crypto/rsa"
"git.snappfood.ir/golang/framework/assert"
"io/ioutil"
"time"
"github.com/dgrijalva/jwt-go"
"github.com/sirupsen/logrus"
)
var (
private *rsa.PrivateKey
public *rsa.PublicKey
)
func main() {
var err error
var priv, pub []byte
pub, err = ioutil.ReadFile("public.pem")
if err!=nil{
panic(err)
}
priv, err = ioutil.ReadFile("private.pem")
if err!=nil{
panic(err)
}
public, err = jwt.ParseRSAPublicKeyFromPEM(pub)
if err!=nil{
panic(err)
}
private, err = jwt.ParseRSAPrivateKeyFromPEM(priv)
if err!=nil{
panic(err)
}
data := map[string]interface{}{
"jti": "dara",
"scopes": func() []string {
return []string{"sara", "dara"}
}(),
"aud": "aud",
"sub": "",
}
cl := jwt.MapClaims{}
for k, v := range data {
cl[k] = v
}
cl["iat"] = time.Now().Add(-6 * time.Hour).Unix()
cl["exp"] = time.Now().UTC().Add(1 * time.Hour).Unix()
t := jwt.NewWithClaims(jwt.GetSigningMethod("RS256"), cl)
t2 := time.Now()
tokenString, err := t.SignedString(private)
assert.Nil(err)
logrus.Warn(time.Since(t2))
logrus.Warn(tokenString)
}
Run Code Online (Sandbox Code Playgroud)
CES*_*SCO -2
在 Golang 中你总是可以降级到 C 级别。但随之而来的是交付应用程序的复杂性大大增加。但如果任何一位女士对你来说很重要,那它可能就是出路。
但与此同时,(我没有介绍任何内容)它仍然是 Go。您可以轻松并行私有/公共 ParseRSAPrivateKeyFromPEM 调用,以减少几毫秒的时间