因工做中须要用到登录,此时就要用到token的分发与校验,采用jwt来进行token的生成与校验,下面把使用方法记下:前端
大体方案:java
利用jwt生成token,并发放给前端;后端
下一次前端请求后端url时带上token,后端利用jwt相同的密钥对token进行校验,若是校验成功,容许前端访问后端api,返回200;api
若是校验失败,返回给前端401;并发
依赖:微服务
compile('com.auth0:java-jwt:3.4.0')
生成token:ui
public static String genToken(Map<String, String> claims, Date expireDatePoint){ try { //使用HMAC256进行加密 Algorithm algorithm = Algorithm.HMAC256(SECRET); //密钥 //建立jwt JWTCreator.Builder builder = JWT.create() .withClaim("loginName", username) withExpiresAt(expireDatePoint); //过时时间点 //传入参数 claims.forEach((key,value)-> { builder.withClaim(key, value); }); //签名加密 return builder.sign(algorithm); } catch (IllegalArgumentException | UnsupportedEncodingException e) { throw new RuntimeException(e); } }
校验token加密
public static Map<String,String> verifyToken(String token) throws RuntimeException{ Algorithm algorithm = null; try { //使用HMAC256进行加密 algorithm = Algorithm.HMAC256(SECRET); } catch (IllegalArgumentException | UnsupportedEncodingException e) { throw new RuntimeException(e); } //解密 JWTVerifier verifier = JWT.require(algorithm).withIssuer(ISSUER).build(); DecodedJWT jwt = verifier.verify(token); Map<String, Claim> map = jwt.getClaims(); Map<String, String> resultMap = new HashMap<>(); map.forEach((k,v) -> resultMap.put(k, v.asString())); return resultMap; }
校验token,能够用在微服务当中的api gateway服务,利用全局过滤器globalFilter,对全部api进行拦截,校验token的合法性,选择是否对其进行放行。url