日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

springboot攔截器過濾token,并返回結果及異常處理操作

瀏覽:17日期:2023-04-21 11:13:09

1.springboot 攔截器處理過濾token,并且返回結果

import org.apache.commons.lang3.StringUtils;import org.apache.shiro.subject.Subject;import org.springframework.lang.Nullable;import org.springframework.stereotype.Component;import org.springframework.web.servlet.HandlerInterceptor;import org.springframework.web.servlet.ModelAndView;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import java.io.IOException;import java.io.PrintWriter;import java.util.Map;@Componentpublic class ECInterceptor implements HandlerInterceptor { /** * @Description 在業務處理器處理請求之前被調用。預處理,可以進行編碼、安全控制等處理; * @Date 2019/5/14 16:04 * @Version 1.0 */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { System.out.println(request.getRequestURL()+'===========preHandle==========='); String token = request.getParameter('token'); if(StringUtils.isNotEmpty(token)){ Subject subject = ShiroUtil.getSubject(token); if(subject != null && subject.isAuthenticated()){return true; } else{//返回校驗token結果returnJson(response);// return false; //我做的時候返回數據后忘記return false了,所以導致異常 } } return true; } @Override public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable ModelAndView modelAndView) throws Exception { System.out.println(request.getContextPath()+'============postHandle=========='); } /** * @Description 在DispatcherServlet完全處理完請求后被調用,也就是說視圖渲染已經完畢或者調用者已經拿到結果 * @Date 2019/5/14 16:05 * @Version 1.0 */ @Override public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, @Nullable Exception ex) throws Exception { System.out.println(request.getContextPath()+'============afterCompletion=========='); } private void returnJson(HttpServletResponse response){ PrintWriter writer = null; response.setCharacterEncoding('UTF-8'); response.setContentType('application/json; charset=utf-8'); try { writer = response.getWriter(); Map<String, Object> result = PackageReturnResult.returnJson(400, '用戶令牌token無效'); result.put('data', null); writer.print(result); } catch (IOException e){ LoggerUtil.logError(ECInterceptor.class, '攔截器輸出流異常'+e); } finally { if(writer != null){writer.close(); } } }}

2.java.lang.IllegalStateException: getWriter() has already been called for this response異常

我再做攔截器處理response數據后忘記return false返回,導致攔截器被調用兩次,報java.lang.IllegalStateException: getWriter() has already been called for this response異常,犯這樣低級錯誤花了很長時間才解決,謹記!!!

[2019-05-27 09:27:17.690] [http-nio-8080-exec-1] [ERROR] [o.a.c.c.C.[.[.[.[dispatcherServlet] :175 ] - Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Request processing failed; nested exception is java.lang.IllegalStateException: getWriter() has already been called for this response] with root causejava.lang.IllegalStateException: getWriter() has already been called for this responseat org.apache.catalina.connector.Response.getOutputStream(Response.java:548)at org.apache.catalina.connector.ResponseFacade.getOutputStream(ResponseFacade.java:210)at javax.servlet.ServletResponseWrapper.getOutputStream(ServletResponseWrapper.java:105)at org.springframework.http.server.ServletServerHttpResponse.getBody(ServletServerHttpResponse.java:83)at org.springframework.http.converter.json.AbstractJackson2HttpMessageConverter.writeInternal(AbstractJackson2HttpMessageConverter.java:255)at org.springframework.http.converter.AbstractGenericHttpMessageConverter.write(AbstractGenericHttpMessageConverter.java:103)at org.springframework.web.servlet.mvc.method.annotation.AbstractMessageConverterMethodProcessor.writeWithMessageConverters(AbstractMessageConverterMethodProcessor.java:290)at org.springframework.web.servlet.mvc.method.annotation.RequestResponseBodyMethodProcessor.handleReturnValue(RequestResponseBodyMethodProcessor.java:180)at com.uufund.ecapi.config.returnvalue.HandlerMethodReturnValueHandlerProxy.handleReturnValue(HandlerMethodReturnValueHandlerProxy.java:40)at org.springframework.web.method.support.HandlerMethodReturnValueHandlerComposite.handleReturnValue(HandlerMethodReturnValueHandlerComposite.java:82)at org.springframework.web.servlet.mvc.method.annotation.ServletInvocableHandlerMethod.invokeAndHandle(ServletInvocableHandlerMethod.java:119)at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.invokeHandlerMethod(RequestMappingHandlerAdapter.java:892)at org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter.handleInternal(RequestMappingHandlerAdapter.java:797)at org.springframework.web.servlet.mvc.method.AbstractHandlerMethodAdapter.handle(AbstractHandlerMethodAdapter.java:87)at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1038)at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:942)at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:1005)at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:897)at javax.servlet.http.HttpServlet.service(HttpServlet.java:634)at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:882)at javax.servlet.http.HttpServlet.service(HttpServlet.java:741)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:231)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.apache.tomcat.websocket.server.WsFilter.doFilter(WsFilter.java:53)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.apache.shiro.web.servlet.AbstractShiroFilter.executeChain(AbstractShiroFilter.java:449)at org.apache.shiro.web.servlet.AbstractShiroFilter$1.call(AbstractShiroFilter.java:365)at org.apache.shiro.subject.support.SubjectCallable.doCall(SubjectCallable.java:90)at org.apache.shiro.subject.support.SubjectCallable.call(SubjectCallable.java:83)at org.apache.shiro.subject.support.DelegatingSubject.execute(DelegatingSubject.java:387)at org.apache.shiro.web.servlet.AbstractShiroFilter.doFilterInternal(AbstractShiroFilter.java:362)at org.apache.shiro.web.servlet.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:125)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at com.uufund.ecapi.config.filter.ECWebFilter.doFilter(ECWebFilter.java:24)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.springframework.web.filter.RequestContextFilter.doFilterInternal(RequestContextFilter.java:99)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.springframework.web.filter.FormContentFilter.doFilterInternal(FormContentFilter.java:92)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.springframework.web.filter.HiddenHttpMethodFilter.doFilterInternal(HiddenHttpMethodFilter.java:93)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.springframework.web.filter.CharacterEncodingFilter.doFilterInternal(CharacterEncodingFilter.java:200)at org.springframework.web.filter.OncePerRequestFilter.doFilter(OncePerRequestFilter.java:107)at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:193)at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:166)at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:200)at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:96)at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:490)at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:139)at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:92)at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:74)at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:343)at org.apache.coyote.http11.Http11Processor.service(Http11Processor.java:408)at org.apache.coyote.AbstractProcessorLight.process(AbstractProcessorLight.java:66)at org.apache.coyote.AbstractProtocol$ConnectionHandler.process(AbstractProtocol.java:834)at org.apache.tomcat.util.net.NioEndpoint$SocketProcessor.doRun(NioEndpoint.java:1415)at org.apache.tomcat.util.net.SocketProcessorBase.run(SocketProcessorBase.java:49)at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149)at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624)at org.apache.tomcat.util.threads.TaskThread$WrappingRunnable.run(TaskThread.java:61)at java.lang.Thread.run(Thread.java:748)

補充知識:springboot 攔截器過濾權限和錯誤處理

先說異常處理,增加一個異常處理的類MyControllerAdvice就可以了,不需要其他地方使用,注意使用注解@ControllerAdvice

@ControllerAdvicepublic class MyControllerAdvice { @Resource GetRootPath getRootPath; private static final Logger logger = LoggerFactory.getLogger(MyControllerAdvice.class); public void output(Object json, HttpServletRequest request, HttpServletResponse response) throws IOException { String header = request.getHeader('Origin'); response.setContentType('application/json;charset=UTF-8;'); PrintWriter out = response.getWriter(); out.println(json); out.flush(); out.close(); } /*** * 404處理 * @param e * @return */ @ExceptionHandler(NoHandlerFoundException.class) public void notFountHandler(HttpServletRequest request, HttpServletResponse response, Model model, NoHandlerFoundException e) throws IOException, JSONException { JSONObject json = new JSONObject(); json.put('code', 500); json.put('content', null); json.put('msg', '未找到路徑:'+request.getServletPath()); output(json,request,response); } /** * 運行時異常 * * @param exception * @return */ @ExceptionHandler({RuntimeException.class}) @ResponseStatus(HttpStatus.OK) public void processException(HttpServletRequest request, HttpServletResponse response, Model model, RuntimeException exception) throws JSONException, IOException { JSONObject json = new JSONObject(); json.put('code', 500); json.put('content', null); json.put('msg', exception.getMessage()); output(json,request,response); } /** * Excepiton異常 * * @param exception * @return */ @ExceptionHandler({Exception.class}) @ResponseStatus(HttpStatus.OK) public void processException(HttpServletRequest request, HttpServletResponse response, Model model, Exception exception) throws JSONException, IOException { JSONObject json = new JSONObject(); json.put('code', 500); json.put('content', null); json.put('msg', exception.getMessage()); output(json,request,response); }}

再來權限驗證的,接手的項目框架中只有驗證是否登錄的,沒有驗收權限的,增加一個類WebMvcConfig,注意使用注解@Configuration, 不需要在其他地方引用即可起作用,并注意使用excludePathPatterns去掉不需要攔截的部分,否則會攔截掉靜態資源。

@Configurationpublic class WebMvcConfig implements WebMvcConfigurer { /** * 添加攔截器 */ @Override public void addInterceptors(InterceptorRegistry registry) { //靜態資源不攔截 registry.addInterceptor(new LoginInterceptor()).addPathPatterns('/**').excludePathPatterns('/static/**'); }}

增加攔截器類LoginInterceptor

public class LoginInterceptor extends HandlerInterceptorAdapter { /** * 檢查是否已經登錄 */ @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { Object username = request.getSession().getAttribute(Constants.LOGIN_USER); String servletPath = request.getServletPath(); String type = request.getHeader('X-Requested-With') == null ? '' : request.getHeader('X-Requested-With'); if (username != null) { //檢查頁面訪問的權限 if (!'XMLHttpRequest'.equals(type)) {int userId = Integer.valueOf(request.getSession().getAttribute(Constants.LOGIN_USERID).toString());List<ModuleEntity> moduleList = (List<ModuleEntity>) request.getSession().getAttribute(Constants.USER_MODULE);boolean chkResult = methodPermissionLimit(moduleList, servletPath);if(!chkResult){ JSONObject outputMSg = new JSONObject(); outputMSg.put('code', 500); outputMSg.put('content', ''); outputMSg.put('msg', '沒有權限'); output(outputMSg, request, response); return false;}else{ return true;} } else {//如果是json訪問,則不做檢查return true; } } else { //檢查是否登錄允許 if (methodLoginLimit(handler)) {return true; } else {if ('XMLHttpRequest'.equals(type)) { JSONObject outputMSg = new JSONObject(); outputMSg.put('code', 500); outputMSg.put('content', ''); outputMSg.put('msg', '登錄過期,請重新登陸'); output(outputMSg, request, response); return false;} else { String redirectUrl = request.getContextPath() + '/login'; response.sendRedirect(redirectUrl); return false;} } } } public boolean methodLoginLimit(Object handler) { HandlerMethod method = (HandlerMethod) handler; //獲取當前方法PermessionLimit LoginLimit loginLimit = method.getMethodAnnotation(LoginLimit.class); if (loginLimit == null) { //獲取控制器的PermessionLimit loginLimit = method.getMethod().getDeclaringClass().getAnnotation(LoginLimit.class); } if (loginLimit != null && !loginLimit.limit()) { return true; } else { return false; } } /** * 檢查權限 * * @param moduleList * @param path * @return */ public boolean methodPermissionLimit(List<ModuleEntity> moduleList, String path) { boolean havePermission = moduleList.stream().anyMatch(f->f.getPath().toLowerCase().equals(path.toLowerCase())); return havePermission; } public void output(Object json, HttpServletRequest request, HttpServletResponse response) throws IOException { String header = request.getHeader('Origin'); response.setContentType('application/json;charset=UTF-8;'); PrintWriter out = response.getWriter(); out.println(json); out.flush(); out.close(); }}

這樣的攔截器只對頁面地址進行攔截,對ajax提交的數據不做處理,做普通項目的權限過濾是可以了。

以上這篇springboot攔截器過濾token,并返回結果及異常處理操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Spring
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美韩日一区| 伊人成人在线视频| 美女视频一区在线观看| 一区免费视频| 不卡视频在线| 午夜在线观看免费一区| 蜜桃久久久久久| 欧美日韩一区自拍| 新版的欧美在线视频| 精品一区二区三区中文字幕| 色偷偷色偷偷色偷偷在线视频| 欧美日韩黄网站| 性欧美videohd高精| 快she精品国产999| 国产精品jk白丝蜜臀av小说| 日韩精品免费一区二区三区| 一区在线免费观看| 极品av在线| 日韩视频免费| 男人的天堂久久精品| 91在线成人| 亚洲播播91| 久久国际精品| 好吊视频一区二区三区四区| 中文在线а√在线8| 自拍自偷一区二区三区| 欧美sss在线视频| 91精品麻豆| 在线亚洲国产精品网站| 精品一区二区三区免费看| 1024精品久久久久久久久| 欧美久久久网站| 午夜日韩在线| 国产精品毛片视频| 婷婷亚洲五月| 久久久久午夜电影| www.51av欧美视频| 久久精品系列| 国产精品sss在线观看av| 91成人超碰| 超级白嫩亚洲国产第一| 欧美一区自拍| 中文一区在线| 国产成人精品一区二区三区视频| 久久先锋影音| 日本韩国欧美超级黄在线观看| 国产日韩亚洲| 少妇精品在线| 亚洲国产日韩欧美在线| 国产自产自拍视频在线观看| 国产亚洲高清一区| 日韩av资源网| 亚洲精品综合| 亚洲午夜国产成人| 午夜在线播放视频欧美| 日韩一区二区久久| 久久精品国产大片免费观看| 久久一区亚洲| 精品国产午夜肉伦伦影院| 国产乱码精品| 你懂的国产精品永久在线| 久久国产乱子精品免费女| 日韩中文字幕| 亚洲三级网址| 丝袜美腿亚洲色图| 亚洲精品观看| 欧美国产另类| 日韩伦理在线一区| 亚洲高清久久| 中文字幕中文字幕精品| 国产色噜噜噜91在线精品 | 亚洲特级毛片| 日韩午夜av| 日韩欧美中文字幕在线视频| 国产视频一区二| 成人在线免费观看网站| 国产99久久| 在线国产一区二区| 一区二区三区国产盗摄| 国产乱码精品一区二区三区亚洲人 | 国产在线观看91一区二区三区| 国产一区二区三区久久久久久久久| 欧美亚洲日本精品| 视频一区二区三区入口| 国产欧美一级| 久久久久久美女精品| 亚洲在线久久| 欧美成a人片免费观看久久五月天| 激情综合五月| 99国产精品视频免费观看一公开| 婷婷综合国产| 视频在线不卡免费观看| 免费人成精品欧美精品| 国产精品久久| 99久久婷婷| 国产日本亚洲| 97精品在线| 最近国产精品视频| 欧美黑人巨大videos精品| 日韩欧美一区二区三区在线视频 | 激情五月综合| 老司机免费视频一区二区| 久久精品91| 日本一区二区中文字幕| 国产欧美一区二区三区精品酒店| 亚洲成a人片| 欧美午夜三级| 爽爽淫人综合网网站| 天堂中文av在线资源库| 91精品一区| 香蕉久久久久久久av网站| 亚洲性色av| 欧美国产免费| 亚洲人成网77777色在线播放| 国产中文字幕一区二区三区| 欧美一级全黄| | 国产精品一线天粉嫩av| 亚洲欧美日本视频在线观看| 国产一区二区三区久久| 国产欧美精品| 国产精品亚洲欧美日韩一区在线 | 99久久婷婷这里只有精品| 日韩成人精品一区| 欧美在线首页| 丝袜美腿成人在线| 综合欧美精品| 先锋影音国产一区| 亚洲制服欧美另类| 亚洲欧美日韩国产一区| 日韩欧美综合| 美女视频黄久久| 美腿丝袜在线亚洲一区| 久久精品国产免费| 日本亚洲视频在线| 欧美日韩国产免费观看| 青青久久av| 美女网站一区| 男女精品网站| 男人天堂欧美日韩| 久久国产精品亚洲77777| 蜜臀久久99精品久久久久宅男| 久久国产精品99国产| 亚洲欧洲免费| 国产精品任我爽爆在线播放| 久久99精品久久久野外观看| 国产精品手机在线播放| 91中文字幕精品永久在线| 日本韩国欧美超级黄在线观看| 久久久蜜桃一区二区人| 欧美成人久久| 亚洲精品黄色| 国产剧情在线观看一区| 日韩欧美一区二区三区免费看| 欧美日一区二区| 亚洲欧洲一区二区天堂久久| 日韩精彩视频在线观看| 久久精品av麻豆的观看方式| 国产精品久久久久av蜜臀| 国产拍在线视频| 国产精品毛片一区二区三区| 男女男精品视频网| 国产女人18毛片水真多18精品| 国产精品99久久久久久董美香| 麻豆极品一区二区三区| 激情亚洲影院在线观看| 老鸭窝毛片一区二区三区| 老色鬼精品视频在线观看播放| 欧美不卡视频| 国产精品va视频| 国产在线日韩| 精品国产黄a∨片高清在线| 午夜在线一区二区| 99热精品久久| 久久影院一区二区三区| 色吊丝一区二区| 午夜久久久久| 日韩av二区在线播放| 日本精品影院| www在线观看黄色| 国产视频网站一区二区三区| 日韩午夜av在线| 91精品婷婷色在线观看| 国产精品欧美在线观看| 首页国产欧美久久| 国产欧美一区二区色老头| 国产综合视频| 日韩精品社区| av高清不卡| 国产日韩一区二区三区在线播放| 欧美 日韩 国产精品免费观看| 麻豆精品99| 久久精品一区二区国产| 国产精品成人一区二区网站软件| 日韩精品成人在线观看| 日韩二区三区四区| 青青在线精品| 91欧美精品| 美女国产一区二区三区| 国产精品4hu.www|