JWT-Token

JWT-Token令牌认证

1、导入依赖

		<!--JWT依赖-->
        <dependency>
            <groupId>com.auth0</groupId>
            <artifactId>java-jwt</artifactId>
            <version>3.19.0</version>
        </dependency>
        <!--druid-->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>fastjson</artifactId>
            <version>1.2.24</version>
        </dependency>

2、JwtUtils

	public class JwtUtils {

    private static final String SIGN = "!WZ@Jay";//设置一个全局的静态密钥,自定义

    /**
     * 生成token  header。payload。sing
     */
    public static String getToken(Map<String, String> map){

        Calendar instance = Calendar.getInstance();
        instance.add(Calendar.DATE,7);//设置过期时间为7天
        //创建jwt builder
        JWTCreator.Builder builder = JWT.create();
        //payload
        map.forEach((k,v)->{
            builder.withClaim(k,v);
        });

        //生成token
        String token = builder.withExpiresAt(instance.getTime())//指定过期时间
                .sign(Algorithm.HMAC256(SIGN));//sign

        return token;
    }

    /**
     * 验证token 合法性
     */
    public static DecodedJWT verify(String token){
        return JWT.require(Algorithm.HMAC256(SIGN)).build().verify(token);
    }

3、UserMapper.xml

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
        PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
        "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.ant.demo.Mapper.UserMapper">
    <select id="login" resultType="com.ant.demo.Entity.User" parameterType="User">
        select * from user where username=#{username} and password=#{password}
    </select>
</mapper>

4、UserMapper And UserService

User login(User user);

5、UserServiceImpl

@Override
@Transactional(propagation = Propagation.SUPPORTS)
public User login(User user) {
    //根据接收的用户名密码查询数据库
    User userDB = userMapper.login(user);
    if (userDB != null){
        return userDB;
    }
    throw new RuntimeException("~~认证失败~~");
}

6、UserController

@Slf4j//日志
@CrossOrigin//跨域
@RestController//声明Controller
@RequestMapping("/user")
public class UserController {

    @Resource
    UserService userService;
    //登录接口
    @PostMapping("/login")
    public Map<String, Object> login(User user) {
        Map<String, Object> map = new HashMap<>();
        log.info("用户名:[{}]",user.getUsername());
        log.info("密码:[{}]",user.getPassword());
        try {
            User userDB = userService.login(user);
            Map<String, String> payload = new HashMap<>();
            payload.put("username",userDB.getUsername());
            payload.put("password",userDB.getPassword());
            //生成token令牌
            String token = JwtUtils.getToken(payload);
            map.put("state",true);
            map.put("msg",200);
            map.put("token",token);
        }catch (Exception e){
            map.put("state",false);
            map.put("msg",e.getMessage());
        }
        return map;
    }
    @PostMapping("/logout")
    public Map<String, Object> logout(String token) {
        Map<String, Object> map = new HashMap<>();
        if (token == null) {
            map.put("state", true);
            map.put("msg", "成功退出");
            return map;
        }
        return null;
    }

token拦截器

1、Interceptors

public class JWTInterceptor implements HandlerInterceptor {
    /**
     *拦截器
     */
    @Override
    public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
        Map<String, Object> map = new HashMap<>();
        //获取请求头中的令牌
        String token = request.getHeader("token");
        try {
            JwtUtils.verify(token);//验证token令牌
            return true;//放行请求
        } catch (SignatureVerificationException e){
            e.printStackTrace();
            map.put("msg","签名无效!");
        } catch (TokenExpiredException e){
            e.printStackTrace();
            map.put("msg","token过期!");
        } catch (AlgorithmMismatchException e){
            e.printStackTrace();
            map.put("msg","token算法不一致!");
        } catch (Exception e){
            e.printStackTrace();
            map.put("msg","token无效!");
        }
        map.put("state",false);//设置状态
        //将map 转为json jackson
        String json = new ObjectMapper().writeValueAsString(map);
        response.setContentType("application/json;charset=UTF-8");
        response.getWriter().println(json);
        return false;
    }

2、InterceptorConfig

@Configuration
public class InterceptorConfig implements WebMvcConfigurer {

    @Override
    public void addInterceptors(InterceptorRegistry registry) {
        registry.addInterceptor(new JWTInterceptor())
                .addPathPatterns("/**/**")//其他接口保护
                .excludePathPatterns("/user/login");//放行user
    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值