SpringCloud Zuul过滤器实现登陆鉴权代码实例
1.新建一个filter‘包
2.新建一个类,实现ZuulFilter,重写里面的方法
3.在顶部类添加注解,@Component,让Spring扫描
/** *登陆过滤器 */ @Component publicclassLoginFilterextendsZuulFilter{ @Override publicStringfilterType(){//前置过滤器 returnPRE_TYPE; } @Override publicintfilterOrder(){//过滤器顺序,越小越先执行 return3; } @Override publicbooleanshouldFilter(){//过滤器是否生效 RequestContextrequestContext=RequestContext.getCurrentContext(); HttpServletRequestrequest=requestContext.getRequest(); System.out.println(request.getRequestURI()); System.out.println(request.getRequestURL()); if("/apizuul/order/api/v1/order/save".equalsIgnoreCase(request.getRequestURI())){//拦截 returntrue; } returnfalse; } /** *业务逻辑 *@return *@throwsZuulException */ @Override publicObjectrun()throwsZuulException{ System.out.println("拦截..."); RequestContextrequestContext=RequestContext.getCurrentContext(); HttpServletRequestrequest=requestContext.getRequest(); Stringtoken=request.getHeader("token"); if(StringUtils.isBlank(token)){ token=request.getParameter("token"); } //登陆校验逻辑jwt生成token if(StringUtils.isBlank(token)){ requestContext.setSendZuulResponse(false);//不会往下执行 requestContext.setResponseStatusCode(HttpStatus.UNAUTHORIZED.value()); } returnnull; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。