本来想通过Oauth2.0来实现自动登录的。
但是因为一系列原因,最后还是通过如下的方法。
自定义SpringMVC参数解析器, 改变SpringMVC的Controller传入参数,实现可以User替换Token做为参数从登陆页面传到商品列表页面
WebConfig.java
/**
* 自定参数解析器, 作用:改变SpringMVC的Controller传入参数,实现可以User替换Token做为参数从登陆页面传到商品列表页面
*/
@Configuration
public class WebConfig extends WebMvcConfigurerAdapter{
@Autowired
UserArgumentResolver userArgumentResolver;
/**
* SpringMVC框架回调addArgumentResolvers,然后给Controller的参数赋值
* @param argumentResolvers
*/
@Override
public void addArgumentResolvers(List<HandlerMethodArgumentResolver> argumentResolvers) {
argumentResolvers.add(userArgumentResolver);
}
}
UserArgumentResolver.java
@Service
public class UserArgumentResolver implements HandlerMethodArgumentResolver {
@Autowired
UserService userService;
/**
* 当参数类型为User才做处理
*
* @param methodParameter
* @return
*/
@Override
public boolean supportsParameter(MethodParameter methodParameter) {
//获取参数类型
Class<?> clazz = methodParameter.getParameterType();
return clazz == User.class;
}
/**
* 思路:先获取到已有参数HttpServletRequest,从中获取到token,再用token作为key从redis拿到User,而HttpServletResponse作用是为了延迟有效期
*/
@Override
public Object resolveArgument(MethodParameter methodParameter, ModelAndViewContainer modelAndViewContainer, NativeWebRequest nativeWebRequest, WebDataBinderFactory webDataBinderFactory) throws Exception {
HttpServletRequest request = nativeWebRequest.getNativeRequest(HttpServletRequest.class);
HttpServletResponse response = nativeWebRequest.getNativeResponse(HttpServletResponse.class);
String paramToken = request.getParameter(UserService.COOKIE_NAME_TOKEN);
String cookieToken = getCookieValue(request, UserService.COOKIE_NAME_TOKEN);
if (StringUtils.isEmpty(cookieToken) && StringUtils.isEmpty(paramToken)) {
return null;
}
String token = StringUtils.isEmpty(paramToken) ? cookieToken : paramToken;
return userService.getByToken(response, token);
}
//遍历所有cookie,找到需要的那个cookie
private String getCookieValue(HttpServletRequest request, String cookiName) {
Cookie[] cookies = request.getCookies();
for (Cookie cookie : cookies) {
if (cookie.getName().equals(cookiName)) {
return cookie.getValue();
}
}
return null;
}
}
本文介绍了如何在Java中通过自定义SpringMVC参数解析器来实现自动登录功能,替代了原本计划使用Oauth2.0的方式。主要方法是改变Controller的参数接收,用User代替Token在登录页面到商品列表页面的传递。
273

被折叠的 条评论
为什么被折叠?



