一,配置自定义过滤器
在zuul 微服务上配置自定义过滤器
package com.zjk.zuul.filter;
import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import com.netflix.zuul.exception.ZuulException;
import org.apache.http.HttpStatus;
import javax.servlet.http.HttpServletRequest;
public class LoginFilter extends ZuulFilter {
@Override
public String filterType() {
return "pre";
}
@Override
public int filterOrder() {
return 1;
}
@Override
public boolean shouldFilter() {
return true;
}
@Override
public Object run() throws ZuulException {
RequestContext currentContext = RequestContext.getCurrentContext();
HttpServletRequest request = currentContext.getRequest();
String token = request.getParameter("token");
if (token == null){
currentContext.setSendZuulResponse(false);
currentContext.setResponseStatusCode(HttpStatus.SC_GONE);
}
return null;
}
}
RequestContext :用于在过滤器之间传递消息。它的数据保存在每个请求的 ThreadLocal 中。它
用于存储请求路由到哪里、错误、 HttpServletRequest 、 HttpServletResponse 都存储在
RequestContext 中。 RequestContext 扩展了 ConcurrentHashMap ,所以,任何数据都可以存储
在上下文中
二,重启zuul 微服务
不带参数访问:
带参数访问: