Java登陆第四十四天——跟写微头条遇到的问题
作为JavaWeb的收官之作,这里记载了写项目时遇到的问题。
前提:使用maven进行依赖管理
1.JJWT导入依赖太少
最初只导入了
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt-api</artifactId>
<version>0.11.5</version>
</dependency>
出现异常Have you remembered to include the jjwt-impl.jar in your runtime classpath?
于是上网搜索,还需要额外导入以下两个依赖
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt-impl</artifactId>
<version>0.11.5</version>
</dependency>
<dependency>
<groupId>io.jsonwebtoken</groupId>
<artifactId>jjwt-jackson</artifactId>
<version>0.11.5</version>
</dependency>
2. JJWT密钥太短
异常The signing key's size is 32 bits which is not secure enough for the HS512 algorithm.
jwt 0.9.1 之后的版本对于密钥安全性要求更高(体现在 secret 密钥的长度要达到一定的位数)。
于是修改代码
JwtUtil类
private static long tokenExpiration = 24 * 60 * 60 * 1000;
//private static String tokenSignKey = "123456" 加密太短了 随便加点
private static String tokenSignKey = "dsiofayasdiufyiouqweyhruio2q3yo512435y3hpsaiafhp9uisrdoufiosduriou1io23u4i1o2u3io1p2u3ipoudsiopfuipaosdpufpioau1231242141";
3.代码优化
这是我写的
protected void getUserInfo(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//获取请求头
String token = req.getHeader("token");
//根据token解密后的uid查询用户
NewsUser realUser = userService.findByUserId(JwtUtil.getUserId(token));
Result result = null;
//用户存在
if (realUser != null) {
HashMap<String, Object> map = new HashMap<>();
//密码不返回
realUser.setUserPwd("");
map.put("loginUser", realUser);
result = Result.ok(map);
}
WebUtil.writeJson(resp, result);
}
没有检验token直接就去操作数据库,会加大数据库的压力,也会导致无效的查询。
修改代码
protected void getUserInfo(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
//获取请求头
String token = req.getHeader("token");
Result result = null;
//使用短路与 第一个布尔表达式不成立直接就F了
//isExpiration判断是否失效,T是失效,F是有效,所以取反
if (token != null && (!JwtUtil.isExpiration(token)) ) {
//根据token解密后的uid查询用户
NewsUser realUser = userService.findByUserId(JwtUtil.getUserId(token));
//用户存在
if (realUser != null) {
HashMap<String, Object> map = new HashMap<>();
//密码不返回
realUser.setUserPwd("");
map.put("loginUser", realUser);
result = Result.ok(map);
}
}
WebUtil.writeJson(resp, result);
}