国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

springboot攔截器Interceptor的使用,你都了解嗎

瀏覽:88日期:2023-02-24 08:26:09

springmvc 中的攔截器可以對請求進行判別, 在請求到達控制器之前, 把非法的請求給攔截掉下面來說一說, 它在springboot中的使用

攔截器是可以有多個的, 對不同的 url 進行攔截我們這個例子設想的是, 如果用戶登錄過, 就會用戶設置一個 session , 如果session中 有user 的信息,就說明用戶是登錄過的

1.我們先創(chuàng)建一個 User 的實例對象 domain

public class User { private Integer id; private String name; private Integer age; public User() { } public User(Integer id, String name, Integer age) {this.id = id;this.name = name;this.age = age; } public Integer getId() {return id; } public void setId(Integer id) {this.id = id; } public String getName() {return name; } public void setName(String name) {this.name = name; } public Integer getAge() {return age; } public void setAge(Integer age) {this.age = age; }}

2.創(chuàng)建一個攔截器 LoginInterceptor 實現(xiàn) HandlerInterceptor 接口,并實現(xiàn)其方法, 主要是 preHandle方法,其它的可以不用管

package com.huang.interceptor;import com.huang.domain.User;import org.springframework.web.servlet.HandlerInterceptor;import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import javax.servlet.http.HttpSession;public class LoginInterceptor implements HandlerInterceptor { @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {//如果用戶登錄過才可以訪問HttpSession session = request.getSession();User user = (User)session.getAttribute('user');if(user == null){ response.sendRedirect(request.getContextPath()+'/user/login'); return false;}else{ return true;} } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception { } @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception { }}

在我們的springmvc項目中, 創(chuàng)建好攔截器, 下一步就是要在 springmvc的配置文件xml 中去 寫 interceptors > interceptor > bean class=“攔截器的全類名”但是在 springboot中, 我們不用這樣寫了, 我們可以使用 配置類的方式去完成

所以我們新建一個配置類 InterceptorConfig 去實現(xiàn) WebMvcConfigurer 接口

package com.huang.configure;import com.huang.interceptor.LoginInterceptor;import org.springframework.context.annotation.Configuration;import org.springframework.web.servlet.config.annotation.InterceptorRegistry;import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;@Configurationpublic class InterceptorConfig implements WebMvcConfigurer { @Override public void addInterceptors(InterceptorRegistry registry) {registry.addInterceptor(new LoginInterceptor()).addPathPatterns('/user/**').excludePathPatterns('/user/login','/user/logout','/user/setsession'); }}

注意 我們要使用一個注解 @Configuration 表示這是一個配置類, springboot 在啟動的時候會自動掃瞄這個類上面的代碼可以看出, InterceptorRegistry 是一個 interceptor的注冊器類,使用 addInterceptor(new XXXInterceptor) 來把這個攔截器類注冊好, addPathPatterns('/user/**') 這個方法是被重構過的, 可以接受多個字符串參數(shù), 也可以接受一個list的集合, 也就是匹配的 url , excludePathPatterns() 也是重構過的, 表示哪些 url 是排除的, 也就是不經過這個攔截器

上面的攔截器和注冊都完成了, 我們就可以在控制器中寫幾個方法測試了

package com.huang.controller;import com.huang.domain.User;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import org.springframework.web.bind.annotation.ResponseBody;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpSession;@Controller@RequestMapping(value='/user')public class UserController { @RequestMapping(value='/login') @ResponseBody public String userlogin(){return '跳轉到用戶登錄的頁面'; } @RequestMapping(value='/gomain') @ResponseBody public String goMain(){return '這是用戶進入后的頁面'; } @RequestMapping(value='/logout') @ResponseBody public String logout(){return '這是用戶登出界面'; } @RequestMapping(value='/setsession') @ResponseBody public Object setSession(HttpServletRequest request){HttpSession session = request.getSession();session.setAttribute('user',new User(1,'huang',20));return 'OK'; }}

在用戶沒有請求過 /user/setsession的時候,如果用戶請求了 /user/gomain 攔截器就會發(fā)揮作用, 把它跳轉到/user/login的接口上去,如果用戶請求過/user/setsession的話, 再去請求/user/gomain 攔截器就會放行, 請求到相應的結果

到此這篇關于springboot攔截器Interceptor的使用的文章就介紹到這了,更多相關springboot攔截器Interceptor內容請搜索好吧啦網以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Spring
相關文章:
主站蜘蛛池模板: 成年人网站在线观看视频 | 国产一级做a爰片在线看免费 | 性刺激免费视频观看在线观看 | 国产成人免费高清视频 | 欧美 日韩 国产 成人 在线观看 | 手机看片国产免费久久网 | 日韩99在线| 国产精品久久久影院 | 美国一级做a一级视频 | 婷婷国产成人久久精品激情 | 精品成人在线 | 日韩黄色免费观看 | 日韩一区二区在线免费观看 | 91精品久久久久久久久网影视 | 国产在线91精品入口首页 | 亚洲国产精品综合久久网络 | 国产精亚洲视频 | 100000免费啪啪18免进 | 精品国产品香蕉在线观看 | 亚洲国产成人精品激情 | 日韩 欧美 自拍 | 青青热在线精品视频免费 | 毛片网站在线播放 | 久久久久久久久久综合情日本 | 成人怡红院 | 粉嫩高中生的第一次在线观看 | 在线观看国产区 | 66精品 | 日本一区二区三区在线 视频 | 国产精品一区二区丝瓜 | 中文字幕欧美在线观看 | 欧美一线高本道高清在线 | 亚洲免费在线看 | 国产成人精品亚洲日本在线观看 | 久久伊人男人的天堂网站 | 色婷婷久久综合中文久久蜜桃 | 国产三级日本三级日产三级66 | 欧美久久久久久久久 | 黄色网址在线免费看 | 小泽玛利亚的一级毛片的 | 性生活免费视频网站 |