标签:拦截器 Springboot 创建 request Access result response out
拦截器创建
1、创建拦截器
@Component public class RequestInterceptor implements HandlerInterceptor { public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception { if(request.getMethod().equals("OPTIONS")){ return true; } System.out.println("it is preHandle"); String accessToken= request.getHeader("accessToken"); System.out.println("mehtod:"+request.getMethod()+"; accessToken = " + accessToken); boolean resultFlag=true; if(resultFlag){ Result result=new Result(); result.msg="22222"; result.code="001"; setResult(request,response,result); return false; } return true; } /** * 验签失败返回结果信息 * * @param request * @param response * @param result */ private void setResult(HttpServletRequest request, HttpServletResponse response, Result result) { response.setContentType("application/json; charset=UTF-8"); response.addHeader("Access-Control-Allow-Origin", request.getHeader("Origin")); response.addHeader("Access-Control-Allow-Credentials", "true"); response.addHeader("Access-Control-Allow-Headers", "accessToken,traceID,productCode,productVersion,appKeySign,clientIP"); PrintWriter out = null; try { out = response.getWriter(); out.append(JSON.toJSON(result).toString()); } catch (IOException e) { // logger.error("ValidateAPPKeyInterceptor setResult", e); } finally { if (out!=null) { out.close(); } } } }
2、设置拦截器放行地址和启用拦截器
@Configuration public class MywebConfig implements WebMvcConfigurer { @Resource RequestInterceptor requestInterceptor; @Override public void addInterceptors(InterceptorRegistry registry) { registry.addInterceptor(requestInterceptor) .addPathPatterns("/**"); } }
3、拦截器中不通过时返回结果
/** * 验签失败返回结果信息 * * @param request * @param response * @param result */ private void setResult(HttpServletRequest request, HttpServletResponse response, Result result) { response.setContentType("application/json; charset=UTF-8"); response.addHeader("Access-Control-Allow-Origin", request.getHeader("Origin")); response.addHeader("Access-Control-Allow-Credentials", "true"); response.addHeader("Access-Control-Allow-Headers", "accessToken,traceID,productCode,productVersion,appKeySign,clientIP"); PrintWriter out = null; try { out = response.getWriter(); out.append(JSON.toJSON(result).toString()); } catch (IOException e) { // logger.error("ValidateAPPKeyInterceptor setResult", e); } finally { if (out!=null) { out.close(); } } }
标签:拦截器,Springboot,创建,request,Access,result,response,out 来源: https://www.cnblogs.com/liyanbofly/p/15761151.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。