JwtUtils 的集成

倒包:

<!-- JWT依赖--><dependency> <groupId>io.jsonwebtoken</groupId> <artifactId>jjwt</artifactId> <version>0.9.1</version></dependency>

<!-- no more than 2.3.3--><dependency> <groupId>org.glassfish.jaxb</groupId> <artifactId>jaxb-runtime</artifactId> <version>2.3.3</version></dependency>

<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId></dependency>


工具类:

public class JwtUtils {

private static String signKey ="yixiatech";

private static Long expire =1626662400000L;

/**

    * 生成JWT令牌

    * @param claims JWT第二部分负载 payload 中存储的内容

    * @return

*/

    public static String generateJwt(Map claims){

String jwt =Jwts.builder()

.addClaims(claims)

.signWith(SignatureAlgorithm.HS256,signKey)

.setExpiration(new Date(System.currentTimeMillis() +expire))

.compact();

return jwt;

}

/**

    * 解析JWT令牌

    * @param jwt JWT令牌

    * @return JWT第二部分负载 payload 中存储的内容

    */

    public static Claims parseJWT(String jwt){

Claims claims =Jwts.parser()

.setSigningKey(signKey)

.parseClaimsJws(jwt)

.getBody();

return claims;

}

}

控制器代码:

@Slf4j

@RestController

public class LoginController {

@Autowired

    private EmpService empService;

@PostMapping("/login")

public Result login(@RequestBody Emp emp){

Emp e =empService.login(emp);

log.info("员工登录: {}",e);

//登录成功,生成令牌,下发令牌

        if (e !=null){

Mapclaims =new HashMap<>();

claims.put("id",e.getEmpId());

claims.put("name",e.getName());

claims.put("username",e.getUsername());

String jwt =JwtUtils.generateJwt(claims);//jwt包含了当前登录的员工信息

            return Result.success(jwt);

}

//登录失败, 返回错误信息

        return Result.error("用户名或密码错误");

}

}

当我们在Filter类上面加了@WebFilter注解之后,接下来我们还需要在启动类上面加上一个注解@ServletComponentScan,通过这个@ServletComponentScan注解来开启SpringBoot项目对于Servlet组件的支持。

具体操作的类

import javax.servlet.*;

import javax.servlet.annotation.WebFilter;

import java.io.IOException;

@WebFilter(urlPatterns ="/*")

public class EmpFilter implements Filter {

@Override //初始化方法, 只调用一次

    public void init(FilterConfig filterConfig)throws ServletException {

System.out.println("init 初始化方法执行了");

}

@Override //拦截到请求之后调用, 调用多次

    public void doFilter(ServletRequest request,ServletResponse response,FilterChain chain)throws IOException,ServletException {

System.out.println("Demo 拦截到了请求...放行前逻辑");

chain.doFilter(request,response);

System.out.println("Demo 拦截到了请求...放行后逻辑");

}

@Override //销毁方法, 只调用一次

    public void destroy() {

System.out.println("destroy 销毁方法执行了");

}

}

对象转json

依赖

<!--fastJSON--><dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.76</version></dependency>

代码

Result error = Result.error("NOT_LOGIN");

//手动转换 对象--json --------> 阿里巴巴fastJSON

String notLogin = JSONObject.toJSONString(error);


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容