这篇文章主要介绍了springboot+springmvc如何实现登录拦截,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。
成都创新互联主营盐津网站建设的网络公司,主营网站建设方案,重庆APP开发,盐津h5成都微信小程序搭建,盐津网站营销推广欢迎盐津等地区企业咨询
LoginInterceptor
package com.ytkj.smart_sand.system.interceptor; import com.alibaba.fastjson.JSONObject; import com.ytkj.smart_sand.base.DataResponse; import com.ytkj.smart_sand.dict.user.Dic_sysuser_sessionkey; import com.ytkj.smart_sand.pojo.user.SysUser; import org.springframework.web.servlet.HandlerInterceptor; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; /** * @description: * @author: changzhou.xie@yuantiaokj.com * @date: 2019/10/21 17:04 */ public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println("requestURI:" + request.getRequestURI()); SysUser sysUser = (SysUser) request.getSession().getAttribute(Dic_sysuser_sessionkey.CURRENT_USER); if(sysUser == null){ DataResponse result = DataResponse.failure("0100", "用户没有登录"); response.setContentType("application/json;charset=UTF-8"); response.getWriter().write(JSONObject.toJSONString(result)); return false; } return true; } }
LoginConfiguration
package com.ytkj.smart_sand.config; import com.ytkj.smart_sand.dict.system.Dict_decollator; import com.ytkj.smart_sand.system.interceptor.LoginInterceptor; import com.ytkj.smart_sand.system.properties.LoginInfoProperties; import org.apache.commons.lang3.StringUtils; import org.springframework.context.annotation.Configuration; import org.springframework.web.servlet.config.annotation.InterceptorRegistry; import org.springframework.web.servlet.config.annotation.WebMvcConfigurer; /** * @description: * @author: changzhou.xie@yuantiaokj.com * @date: 2019/10/21 17:11 */ @Configuration public class LoginConfiguration implements WebMvcConfigurer { /* 注意拦截路径的写法: /**/*.html 表示所有的html文件。 /img/** 表示img目录下的所有文件。 */ @Override public void addInterceptors(InterceptorRegistry registry) { String paths = LoginInfoProperties.getValue("loginReleasePaths"); String[] loginReleasePaths; if(StringUtils.isNotBlank(paths)){ loginReleasePaths = paths.split(Dict_decollator.ENG_COMMA); }else{ loginReleasePaths = new String[0]; } registry.addInterceptor(new LoginInterceptor()) .addPathPatterns("/**")//拦截路径 .excludePathPatterns(loginReleasePaths);//不进行拦截路径 } }
LoginInfoProperties
package com.ytkj.smart_sand.system.properties; import java.util.MissingResourceException; import java.util.ResourceBundle; /** * @description: * @author: changzhou.xie@yuantiaokj.com * @date: 2019/10/21 16:59 */ public class LoginInfoProperties { private static final String LOGIN = "login"; private static ResourceBundle LOGIN_BUNDLE = ResourceBundle.getBundle(LOGIN); public static String getValue(String key){ try { return LOGIN_BUNDLE.getString(key); } catch (MissingResourceException e) { e.printStackTrace(); } return ""; } }
login.properties
# main/resources/login.properties # /**/*.html 表示所有的html文件。 # /img/** 表示img目录下的所有文件。 loginReleasePaths=/img/**,\ /**/*.html,\ /user/login/pc
ResourceBundle
是一个加载properties文件的工具类。支持国际化。从classpath中加载配置文件。
文件命名方式 baseName_国别_语言.properties
ResourceBundle bundle = ResourceBundle.getBundle("res", new Locale("zh", "CN"));
new Locale("zh", "CN")这个对象就告诉了程序你的本地化信息。如果不指定则使用系统默认的Locale。
classpath下寻找res_zh_CN.properties 若不存在
那么会去找res_zh.properties,若还是不存在
则会去寻找res.properties,要还是找不到的话,那么就该抛异常了:MissingResourceException.
// login是资源文件的名称。 ResourceBundle login = ResourceBundle.getBundle("login");//不指定locale会使用系统默认的。 Exception in thread "main" java.util.MissingResourceException: Can't find bundle for base name login, locale zh_CN
springboot一种全新的编程规范,其设计目的是用来简化新Spring应用的初始搭建以及开发过程,SpringBoot也是一个服务于框架的框架,服务范围是简化配置文件。
感谢你能够认真阅读完这篇文章,希望小编分享的“springboot+springmvc如何实现登录拦截”这篇文章对大家有帮助,同时也希望大家多多支持创新互联,关注创新互联行业资讯频道,更多相关知识等着你来学习!