Java 웹 응용 프로그램에서 Filter 사용은 매우 간단합니다. javax.servlet.Filter 인터페이스를 구현하는 클래스를 작성한 다음 web.xml 구성 파일에서 Filter를 구성하여 Filter를 사용하면 됩니다. . 다음은 필터의 코드 예입니다.
public class MyFilter implements Filter { public void init(FilterConfig filterConfig) throws ServletException { // 初始化操作 } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 过滤器逻辑处理 chain.doFilter(request, response); } public void destroy() { // 销毁操作 } }
웹에서 필터를 구성합니다. 필터의 매핑 규칙, 즉 필터가 가로채는 URL입니다.
Filter의 수명 주기
init() 메서드: 필터가 생성될 때 호출되며 필터를 초기화하는 데 사용됩니다. 이 메서드는 한 번만 호출됩니다.
인셉터가 각 요청을 캡처하면 doFilter() 메서드가 호출되어 요청과 응답을 처리합니다. 다음 Filter를 계속해서 실행해야 한다면 chain.doFilter(request, response) 메소드를 호출해야 하며, 그렇지 않으면 이 메소드를 호출할 필요가 없습니다.
destroy() 메서드: 필터가 파괴될 때 호출되며 리소스를 해제하는 데 사용됩니다.
필터 실행 순서
<filter> <filter-name>MyFilter</filter-name> <filter-class>com.example.MyFilter</filter-class> </filter> <filter-mapping> <filter-name>MyFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
위 구성에서는 FilterA가 먼저 실행된 다음 FilterB가 실행됩니다.
세부 정보 필터링
<filter> <filter-name>FilterA</filter-name> <filter-class>com.example.FilterA</filter-class> </filter> <filter-mapping> <filter-name>FilterA</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <filter> <filter-name>FilterB</filter-name> <filter-class>com.example.FilterB</filter-class> </filter> <filter-mapping> <filter-name>FilterB</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
자동 로그인 필터의 간단한 코드 예입니다.
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 ("admin".equals(username) && "123456".equals(password)) { // 登录成功,保存用户信息到Session中 HttpSession session = request.getSession(); session.setAttribute("username", username); // 保存自动登录信息到Cookie中 Cookie cookie = new Cookie("autologin", username + ":" + password); cookie.setMaxAge(7 * 24 * 60 * 60); // 设置Cookie过期时间为一周 response.addCookie(cookie); // 跳转到首页 response.sendRedirect(request.getContextPath() + "/index.jsp"); } else { // 登录失败,返回登录页面 response.sendRedirect(request.getContextPath() + "/login.jsp"); } } }
BeanUtils 사용
public class AutoLoginFilter implements Filter { public void init(FilterConfig filterConfig) throws ServletException { // 初始化操作 } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 判断用户是否已经登录 HttpSession session = ((HttpServletRequest) request).getSession(); String username = (String) session.getAttribute("username"); if (username == null) { // 判断是否存在Cookie Cookie[] cookies = ((HttpServletRequest) request).getCookies(); if (cookies != null) { for (Cookie cookie : cookies) { if ("autologin".equals(cookie.getName())) { // 自动填充用户名和密码 String[] values = cookie.getValue().split(":"); String autologinUsername = values[0]; String autologinPassword = values[1]; request.setAttribute("autologinUsername", autologinUsername); request.setAttribute("autologinPassword", autologinPassword); } } } } chain.doFilter(request, response); } public void destroy() { // 销毁操作 } }
위 코드에서는 BeanUtils.setProperty() 메소드를 통해 폼 데이터가 User 객체로 캡슐화됩니다.
위 내용은 Java에서 필터의 기능, 유형 및 적용 시나리오는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!