public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { System.out.println("admin身份检测进行"); //检测Cookie过滤 HttpServletRequest request= (HttpServletRequest) servletRequest; Cookie[] cookies=request.getCookies(); //对Cookie进行遍历获取 for(Cookie c:cookies){ String cName = c.getName();//获取cookie名 String cValue = c.getValue();//获取cookie值 System.out.println(cName); System.out.println(cValue); if(cName.contains("user") && cValue.contains("admin")){ filterChain.doFilter(servletRequest,servletResponse); }else { System.out.println("非管理员访问"); } } } }代码解析
时间: 2024-02-14 19:20:48 浏览: 54
这是一个Java Servlet中的过滤器(Filter)代码,用于实现管理员身份检测。
在doFilter()方法中,首先输出一句话"admin身份检测进行",然后获取HttpServletRequest对象,通过调用它的getCookies()方法获取所有的Cookie。
接下来,对获取到的Cookie进行遍历,对于每个Cookie,获取它的名字和值,并分别输出。如果该Cookie的名字包含"user"且值包含"admin",则调用FilterChain对象的doFilter()方法,将请求和响应交给下一个过滤器或Servlet处理;否则输出"非管理员访问"。
总之,这段代码的作用是检测请求是否来自管理员用户,如果是,则放行,否则拒绝访问。
相关问题
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException { System.out.println("Filter1 doFilter..........11"); filterChain.doFilter(servletRequest, servletResponse); System.out.println("Filter1 doFilter..........12"); }
这段代码是一个过滤器(Filter)的`doFilter`方法的实现。过滤器用于在请求到达目标资源之前或之后对请求和响应进行处理。在这个方法中,首先打印出一条日志信息:"Filter1 doFilter..........11",表示过滤器开始处理请求。然后调用`filterChain.doFilter(servletRequest, servletResponse)`方法,将请求和响应对象传递给下一个过滤器或目标资源进行处理。最后,打印出另一条日志信息:"Filter1 doFilter..........12",表示过滤器处理完请求。这个方法的目的是在请求处理前后进行一些额外的操作,例如日志记录、权限验证等。
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain chain) throws ServletException, IOException { System.out.println("characterEncoding="+characterEncoding); if(null!=characterEncoding) { req.setCharacterEncoding(characterEncoding); resp.setCharacterEncoding(characterEncoding); } chain.doFilter(req, resp); }
这个doFilter方法是实现了Filter接口中的方法,用于处理请求和响应,并将请求转发给下一个过滤器或Servlet。在这个方法中,首先会输出字符编码的值,然后判断characterEncoding是否为空,如果不为空,则将请求和响应的字符编码都设置为characterEncoding所指定的字符编码。最后,将请求和响应转发给下一个过滤器或Servlet进行处理。
具体来说,当请求到达时,先经过该过滤器进行处理。在处理之前,先输出characterEncoding的值,以便进行调试。然后判断是否需要设置字符编码。如果需要,就将请求和响应的字符编码都设置为characterEncoding所指定的编码。最后,将请求和响应转发给下一个过滤器或Servlet进行处理,直到最后一个过滤器或Servlet处理完毕并将响应返回给客户端。
阅读全文