建议先看jsp,因为jsp中有些提到过servlet,这里就没有再写了。。。。。。
一、Servlet生命周期
1. init() :初始化方法(第一次被创建时被调用)
2. service() :处理客户端的请求,并且返回到客户端
3. destroy() :在servlet生命周期结束时被调用(销毁作用)
4. doGet ,doPost方法用来处理表单请求(doGet还可以处理URL的正常请求)
二、第一个Servlet
创建servlet,取名HelloWorld。在doGet()中写下:
// 设置响应内容类型
response.setContentType("text/html");
// 实际的逻辑是在这里
PrintWriter out = response.getWriter();
out.println("
然后在 工程名/WebContent/WEB-INF/ 的 web.xml 文件中增加以下内容:
三、Servlet处理表单数据(Get & Post)
Get请求例如:(不太安全,信息容易泄露)
http://www.test.com/hello?key1=value1&key2=value2
Post请求:较安全,信息不放在url中。
Servlet读取表单数据:
1.getParameter():可以调用 request.getParameter() 方法来获取表单参数的值。
2.getParameterValues():如果参数出现一次以上,则调用该方法,并返回多个值,例如复选框。
3.getParameterNames():如果想要得到当前请求中的所有参数的完整列表,则调用该方法。
四、Servlet 过滤器
目的:
1.在客户端的请求访问后端资源之前,拦截这些请求。
2.在服务器的响应发送回客户端之前,处理这些响应。
过滤器:
· 身份验证过滤器(Authentication Filters)。
· 数据压缩过滤器(Data compression Filters)。
· 加密过滤器(Encryption Filters)。
· 触发资源访问事件过滤器。
· 图像转换过滤器(Image Conversion Filters)。
· 日志记录和审核过滤器(Logging and Auditing Filters)。
· MIME-TYPE 链过滤器(MIME-TYPE Chain Filters)。
· 标记化过滤器(Tokenizing Filters)。
· XSL/T 过滤器(XSL/T Filters),转换 XML 内容。
方法:
//完成实际过滤操作
public void doFilter (ServletRequest, ServletResponse, FilterChain)
//完成初始化操作(只执行一次)
public void init(FilterConfig filterConfig)
//Servlet在销毁过滤器实例时调用该方法
public void destroy()
FilterConfig使用:
eg:
public void init(FilterConfig config) throws ServletException {
// 获取初始化参数
String site = config.getInitParameter("Site");
// 输出初始化参数
System.out.println("网站名称: " + site); }
web.xml配置各节点说明:
1.
·
·
·
· 在过滤器中,可以使用FilterConfig接口对象来访问初始化参数。
2.
五、Servlet 重定向
1. String site = "http://www.runoob.com" ;
response.setStatus(response.SC_MOVED_TEMPORARILY);
response.setHeader("Location", site);
2. 服务器内部跳转:
request.getRequestDispatcher("/test.jsp").forward(request, response);
request.getRequestDispatcher("../test.jsp").forward(request, response);
3. response.sendRedirect(request.getContextPath()+"/test.jsp");