开始.在我们之前的学习中,有一些重复的工作例如:设置编码格式,是可以省略的,只要利用好Filter过滤器.
原本的结构:Web浏览器—Web服务器–Servlet/JSP/静态资源.此时,
可以新增一层过滤器,层次更改为:Web浏览器—Web服务器–过滤器–Servlet/JSP/静态资源.
由于过滤器也需要req和resp对象才能完成过滤操作,实际过滤器也是Servlet!
Servlet实现Servlet接口,过滤器实现过滤器接口.
1.新建一个不使用模板的项目名为Javaweb-filter,右键项目名添加4.0的Web框架支持.
2.在pom.xml中导包,相对于上次,本次要多导数据库的包:
<dependencies>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>javax.servlet.jsp-api</artifactId>
<version>2.3.3</version>
</dependency>
<dependency>
<groupId>taglibs</groupId>
<artifactId>standard</artifactId>
<version>1.1.2</version>
</dependency>
<dependency>
<groupId>javax.servlet.jsp.jstl</groupId>
<artifactId>jstl-api</artifactId>
<version>1.2</version>
</dependency>
<!-- 链接数据库-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.48</version>
</dependency>
</dependencies>
3.编写过滤器
在java下新建一个包名为com.sunsplanter.filter,在该包下新建一个类名为CharacterEncodingFilter.
由于已经有编写好的Filter接口,我们直接实现即可,但是注意要选中javax.servlet包下的Filter实现.
实现该接口强制要求重写三个方法,我们先重写,至于具体内容暂且搁置.
java包下新建一个包名为servlet,servlet下新建一个类名为ShowServlet,该类继承HttpServlet,并重写doGet和doPost方法,我们设置简单输出一句中文,内容如下:
public class ShowServlet extends HttpServlet {
@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
resp.getWriter().write("惟草木之零落兮");
}
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
doGet(req, resp);
}
}
注册servlet,这里设置两个映射路径,马上我们就们可以知道这里的具体作用:
<servlet>
<servlet-name>ShowServlet</servlet-name>
<servlet-class>servlet.ShowServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>ShowServlet</servlet-name>
<url-pattern>/servlet/show</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>ShowServlet</servlet-name>
<url-pattern>/show</url-pattern>
</servlet-mapping>
现在我们已经完成了一个输出一句中文的servlet的编写,但我们发现输出的是乱码,回忆起以前,我们解决乱码无非是利用resp/req.setCharacterEncoding来解决,但如果碰上许多类都要编写编码代码,类的内容就会显地臃肿,还好现在我们有了过滤器,我们将这些重复的代码放进过滤器中,CharacterEncodingFilter类中编写内容如下:
package com.sunsplanter.filter;
import javax.servlet.*;
import java.io.IOException;
public class CharacterEncoding implements Filter{
//Web服务器一启动就立刻初始化,随时等待过滤对象的出现
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("CharacterEncodingFilter initialized");
}
public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
servletRequest.setCharacterEncoding("utf-8");
servletResponse.setCharacterEncoding("utf-8");
servletResponse.setContentType("text/html;charset=UTF-8");
System.out.println("Before filter execute");
filterChain.doFilter(servletRequest,servletResponse);//让Filter过滤器接力转接给另一个过滤器,如果没有程序则到这里被拦截
System.out.println("After filter execute");
}
public void destroy() {
System.out.println("CharacterEncodingFilter destroyed");
}
}
与servlet类似,filter也需要注册:
<filter>
<filter-name>CharacterEncodingFilter</filter-name>
<filter-class>com.sunsplanter.filter.CharacterEncoding</filter-class>
</filter>
<filter-mapping>
<filter-name>CharacterEncodingFilter</filter-name>
<!-- 请求任何servlet下属的子页面都会经过此过滤器-->
<url-pattern>/servlet/*</url-pattern>
</filter-mapping>
运行后发现控制台在工件部署成功的前一刻输出了"“CharacterEncodingFilter initialized”,证明Filter已经完成初始化随时等待过滤对象的出现.
输入后缀show,展示的页面的页面是乱码,输入后缀servlet/show,正常展示.
这说明,如果我们对一些页面页面有特殊的过滤要求,那么我们注册servlet时把这些页面都作为/servlet的下属页面,相当于放到一个集合中,再对应上注册filter的/servlet/*映射路径,就可以实现对servlet这一集合全部页面的特定过滤请求.