Filter: 过滤器、装饰者设计模式解决乱码、自动登录

一。Filter: 过滤器:

  • 步骤:
    1.自定义类, 实现Filter接口
    2.重点实现doFilter方法
    3.注册Filter @WebFilter web.xml-配置]
    4.doFilter中, 直接响应, 要么放行 chain.doFilter
    5.测试: 发送的是Servlet请求

  • 多个过滤器顺序:
    web.xml文件中的标签顺序

    FilterChain: 过滤器链, 由filter-mapping将过滤器连接串起来的
    doFilter() -> 执行下一个过滤器, 递归

    Filter生命周期:
    服务器启动创建
    服务器关闭销毁

    FilterConfig
    《init-param》
    《param-name》driver《/param-name》
    《param-value》com.mysql.cj.jdbc.Driver《/param-value》
    《/init-param》
    config.getInitParameter(“driver”);
    ServletConfig

public class FilterC implements Filter {
    public void destroy() {
    }

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {
        System.out.println("MyfilterC");
        chain.doFilter(request, response);
    }

    public void init(FilterConfig config) throws ServletException {
        String qqai = config.getInitParameter("qqai");//获得xml文件中init-param的初始化参数
        System.out.println(qqai);
    }

}

    @WebServlet("/requstServlet")
public class requstServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        System.out.println("servelet进入");
    }
------------------------------------------------------
  <filter>
        <filter-name>FilterC</filter-name>
        <filter-class> filter.FilterC</filter-class>
        <!-- init-param :可被FilterConfig获得的的初始化参数-->
        <init-param>
            <param-name>qqai</param-name>
            <param-value>com.qqai</param-value>
        </init-param>
    </filter>
    <!--过滤器运行的先后顺序,谁的filter-mapping写在前面谁先-->
    <filter-mapping>
        <filter-name>FilterC</filter-name>
        <url-pattern>/requstServlet</url-pattern>
    </filter-mapping>

二。装饰者设计模式解决乱码

  • Get请求默认字符集: tomcat字符集一致 - utf-8
    设置Tomcat字符集为 ISO8859-1
    tomcat/conf/server.xml
    URIEncoding=“ISO8859-1”
    Post请求默认字符集: ISO8859-1
    request.setCharacterEncoding(“UTF-8”);
  • 修改tomcat默认字符编码:找到tomcat下的conf/server.xml文件
    改为《Connector port=“8080” protocol=“HTTP/1.1” connectionTimeout=“20000” redirectPort=“8443” URIEncoding=“UTF-8” /》
package luanma;

import javax.servlet.*;
import javax.servlet.annotation.WebFilter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletRequestWrapper;
import java.io.IOException;
import java.io.UnsupportedEncodingException;

@WebFilter("/*")
public class BmFilter implements Filter {
    public void destroy() {
    }

    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {
        HttpServletRequest request1= (HttpServletRequest) request;
        MyRequest myRequest=new MyRequest(request1);
        chain.doFilter(myRequest, response);
    }

    public void init(FilterConfig config) throws ServletException {

    }
}
//装饰者设计模式
/*
   1.装饰者和被装饰者拥有相同的父接口
   2.使用被装饰者 来 构建装饰者对象
   3.重写需要增强的方法, 方法内部会使用到被装饰者原来的方法
   4.将 被装饰者 包装成 装饰者对象 再去使用
 */
class MyRequest extends HttpServletRequestWrapper {
    private HttpServletRequest request;
    public MyRequest(HttpServletRequest request) {
        super(request);
        this.request = request;
    }

    @Override
    public String getParameter(String name) {
        //先调用原来是乱码的参数值
        String parameter = request.getParameter(name);
        //解决乱码
        try {
            parameter=new String(parameter.getBytes("ISO-8859-1"),"UTF-8");
        } catch (UnsupportedEncodingException e) {
            e.printStackTrace();
        }
        return parameter;
    }
}

三。Listener: 监听器
在这里插入图片描述

四。自动登录

  • 第一次登陆时将账号密码cooki发送。然后下回每次访问页面都被filter拦截的时候取出cooki,若符合就自动登陆
@WebServlet("/LoginServlet")
public class LoginServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        String username = request.getParameter("username");
        String password = request.getParameter("password");
        if(username.equals("lucy") && password.equals("1234f")){
            if("checked".equals(request.getParameter("loginself"))){
                Cookie cookie=new Cookie("username",username);
                Cookie cookie1=new Cookie("password",password);
                cookie.setMaxAge(Integer.MAX_VALUE);
                cookie1.setMaxAge(Integer.MAX_VALUE);
                cookie.setPath(request.getContextPath());
                cookie1.setPath(request.getContextPath());
                response.addCookie(cookie);
                response.addCookie(cookie1);

            }
            request.getSession().setAttribute("username",username);
            request.getSession().setAttribute("password",password);
            response.sendRedirect(request.getContextPath()+"/index.jsp");
        }
        else {
            request.getRequestDispatcher("/login.jsp").forward(request,response);
        }
    }
    ------------------------------------------------------------------------
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {
        HttpServletRequest _request=(HttpServletRequest)request;

        Cookie[] cookies = _request.getCookies();
        String username=null;
        String password=null;
        if(cookies!=null){
            for(Cookie c:cookies){
                if(c.getName().equals("username")){
                    username=c.getValue();
                }
                if(c.getName().equals("password")){
                    password=c.getValue();
                }
            }
        }
        if(username!=null&&password!=null){
            if(username.equals("lucy")&&password.equals("1234f")){
                _request.getSession().setAttribute("username",username);
            }
        }

        chain.doFilter(request, response);
    }
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值