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(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。