最近在学习 jwt 我分别用 jjwt 和 java-jwt 写了两个 demo 生成 jwt,生成一个 jwt 字符串至少得 900ms
为啥在这里能几十毫秒就能创建一个?
1
gam2046 2019-04-22 15:37:47 +08:00
jwt 唯一可能耗时的只有签名,但是 900ms 怎么样都有点过分了,payload 应该不至于这么大吧?
所以比较大的概率是耗时的过程不在生成的 jwt 上,而是你的其他代码有速度慢的地方。 |
2
whileFalse 2019-04-22 15:44:07 +08:00
好奇怎么做到 900ms 的。
|
3
raiz 2019-04-22 15:57:01 +08:00
900ms 有问题
|
4
Xiamaer OP System.out.println(System.currentTimeMillis());
String jws = Jwts.builder() // (1) .setSubject("Bob") // (2) .signWith(SignatureAlgorithm.HS256,"mykey") // (3) .compact(); // (4) System.out.println(System.currentTimeMillis()); System.out.println(jws); @gam2046 @whileFalse @raiz 我就只用了 api 生成 jwt,代码就这几句自己写的,别的啥都没有 |
5
gam2046 2019-04-22 16:20:28 +08:00
你确定你的代码可以跑??
我这跑起来抛异常:io.jsonwebtoken.security.WeakKeyException: The signing key's size is 24 bits which is not secure enough for the HS256 algorithm. The JWT JWA Specification (RFC 7518, Section 3.2) states that keys used with HS256 MUST have a size >= 256 bits (the key size must be greater than or equal to the hash output size). Consider using the io.jsonwebtoken.security.Keys class's 'secretKeyFor(SignatureAlgorithm.HS256)' method to create a key guaranteed to be secure enough for HS256. See https://tools.ietf.org/html/rfc7518#section-3.2 for more information. 我这的使用方法(Kotlin),看了下,基本和你的差不多。并没有很慢,如果你那跑起来需要近 1 秒的时间,检查一下是否配置原因导致? https://i.loli.net/2019/04/22/5cbd79471e5d9.jpg |
6
invalidtoken 2019-04-22 16:29:22 +08:00
|
7
misaka19000 2019-04-22 16:50:10 +08:00
System.out.println(System.currentTimeMillis());
楼主你确定不是来黑 Java 的吗 |
8
66beta 2019-04-22 16:56:36 +08:00 via Android
原来 Java 系统级 API 获取时间还有坑
|
9
quadrapop 2019-04-22 17:07:39 +08:00
在下用的 RSA256 生成 jwt 平均耗时 800ms,用 HS256 这种平均 200ms 不到,HS256 不太安全建议使用 RSA
|
10
Xiamaer OP @misaka19000 没怎么用过这个,还请大佬指点
|
12
misaka19000 2019-04-22 17:55:27 +08:00
@Xiamaer #10 我的意思是你的时间计算代码中把 IO 的时间也算进去了
|
13
0x4F5DA2 2019-04-22 18:28:03 +08:00
|
14
0x4F5DA2 2019-04-22 18:29:00 +08:00
emmm。。。。接上一条,手滑发出去了。。。实习的时候写的垃圾玩意儿。。。生成 jwt 好像蛮快的,基本上能秒出
|
15
wm5821090 2019-04-22 19:48:40 +08:00 via iPhone
Java 的加密 lib 你是收费的?
|
17
Xiamaer OP 找到原因了,java 刚启动的时候代码执行效率较低,cpu 占用高,我循环创建了一下发现还是很快的,可以到毫秒级。
|