1、什么是servlet

第一个servlet应用程序,实现servlet接口

定义:凡是实现了servlet api接口(或者继承servlet api接口的实现类)的类就是servlet应用程序;

命周期:

  1. 创建servlet应用程序的实例:只会执行一次,在首次通过url-pattern映射访问时,创建实例;
  2. 初始化init方法:只会执行一次,在创建完servlet应用程序的实例后,立刻调用,一般都是用户初始化servlet应用程序;
  3. 业务处理service方法:执行多次,每当访问请求映射到servlet应用程序时,都会调用service方法,进行请求处理;
  4. 销毁destroy方法:只会执行一次,在web应用程序卸载时,统一调用,多用户释放服务器资源;

2、创建Servlet的三种方式

2.1 实现 servlet接口

public class HelloServlet implements Servlet {
// 空参构造
public HelloServlet() {
System.out.println("---------HelloServlet 空参构造--------------");
} @Override
public void destroy() {
System.out.println("---------HelloServlet destroy--------------");
} @Override
public ServletConfig getServletConfig() {
System.out.println("---------HelloServlet getServletConfig--------------");
return null;
} @Override
public String getServletInfo() {
System.out.println("---------HelloServlet getServletInfo--------------");
return null;
} @Override
public void init(ServletConfig config) throws ServletException {
System.out.println("---------HelloServlet init--------------");
} @Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
System.out.println("---------HelloServlet service--------------");
} }

2.1.1 servlet的生命周期

//第一次访问映射路径:
---------HelloServlet 空参构造---------
---------HelloServlet init-----------(//如果配置了load-on-startup 项目启动前面两步就会立刻执行) ---------HelloServlet service--------(//每次访问映射路径都会调用此方法) ---------HelloServlet destroy--------(//关闭服务才会调用)

2.2 继承 GenericServlet

public class HelloServlet2 extends GenericServlet{
@Override
public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {
}
}

2.3 继承 HttpServlet

public class StudentInfoServlet extends HttpServlet{
@Override
protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
} @Override
protected void doGet(HttpServletRequest req, HttpServletResponse res) throws ServletException, IOException {
// 一般直接在get请求处理方法中,直接调用post方法,实现两种请求统一处理
//doPost(request, response);
}
}

3、Servlet 的注册配置

3.1 注册

  <!-- 注册第一个 servlet应用程序 -->
<servlet>
<!-- servlet应用程序的别名 -->
<servlet-name>helloServlet</servlet-name>
<!-- servlet应用程序的全类名 -->
<servlet-class>com.kgc.servlet.HelloServlet</servlet-class>
</servlet> <!-- 映射第一个servlet应用程序 -->
<servlet-mapping>
<servlet-name>helloServlet</servlet-name>
<url-pattern>/hello</url-pattern>
</servlet-mapping>

3.2 模糊映射

 <servlet-mapping>
<servlet-name>helloServlet</servlet-name>
<!-- 匹配方法 前匹配 /user/* 等等 -->
<!-- <url-pattern>/*</url-pattern> -->
<!-- 匹配方法 后匹配 -->
<!--<url-pattern>*.do</url-pattern>-->
<!-- 不能 /*.xx 两种一起使用 -->
</servlet-mapping>

3.3 初始化参数

3.3.1 单个servlet内部初始化参数

 <servlet>
<servlet-name>helloServlet</servlet-name>
<servlet-class>com.kgc.servlet.HelloServlet</servlet-class>
<!-- 指定servlet内部初始化参数,必须在load-on-startup之前 -->
<init-param>
<param-name>key</param-name>
<param-value>value</param-value>
</init-param>
</servlet>

3.3.2 获取单个servlet内部初始化参数

@Override
public void init(ServletConfig config) throws ServletException {
System.out.println("---------HelloServlet init--------------"); //获取当前servelt初始化参数
//通过 config 对象获取
String encoding = config.getInitParameter("encoding");
System.out.println("******* servlet内部初始化参数 encoding = "+encoding+"******");
}

3.3.3 全局servlet初始化参数

<context-param>
<param-name> key </param-name>
<param-value> value </param-value>
</context-param>

3.3.4 获取全局servlet初始化参数

//获取全局servelt初始化参数
//通过ServletContext 对象获取
String encodingContext = config.getServletContext().getInitParameter("encoding");
System.out.println("**** servlet全局初始化参数 encodingContext = "+encodingContext+"*****");

3.3.5 servlet 的启动优先级

默认情况下,启动是不会创建实例和初始化

配置了load-on-startup,servlet应用程序就会在服务器启动时创建实例并初始化

允许值为正整数(可以为0)负数不可以,一般为1,值的作用是指定servlet应用程序的创建时机,值越小优先级,越高,越早创建实例并初始化

 <load-on-startup>1</load-on-startup>

3.3.6 欢迎页面

<!-- 欢迎页面可以设计多个,在web.xml中越靠上优先级越高 -->
<welcome-file-list>
<welcome-file>login.html</welcome-file>
</welcome-file-list>

3.3.7错误页面

<error-page>
<error-code>404</error-code>
<location>/404.jsp</location>
</error-page>

4、相对路径和绝对路径

通过servlet的跳转使用相对路径,容易出错,会导致缺少部分路径,而找不到资源

一般使用绝对路径,进行跳转;

//获取项目跟路径
<%=request.getContextPath()%> //获取跟路径后再根据实际情况进行路径拼接

5、filter

5.1 创建过滤器

实现Filter的应用就是过滤器;

public class MyFirstFilter implements Filter{
public MyFirstFilter() {
System.out.println("-----MyFirstFilter 空参构造 ------");
}
@Override
public void destroy() {
System.out.println("-----MyFirstFilter destroy ------");
} @Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {
System.out.println("-----MyFirstFilter doFilter ------");
//FilterChain 是决定请i去是否放行的操作对象,如果请求放行,必须要调用FilterChain的请求过滤方法doFilter
chain.doFilter(request, response);
} @Override
public void init(FilterConfig filterConfig) throws ServletException {
System.out.println("-----MyFirstFilter init ------");
}
}

5.2 filter 注册与映射

<!-- 注册过滤器first:配置内容和servlet基本一样,就是标签不一样 -->
<filter>
<filter-name>myFirstFilter</filter-name>
<filter-class>com.kgc.filter.MyFirstFilter</filter-class>
</filter>
<!-- 过滤器first映射 -->
<filter-mapping>
<filter-name>myFirstFilter</filter-name>
<url-pattern>/filter01.jsp</url-pattern>
<!-- filter的映射也可以模糊匹配 /* 等等 -->
</filter-mapping>

5.3 filter 的初始化参数

<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>

获取参数:

//一些配置的初始化参数可以通过 filterConfig.getInitParameter(key) 获取
@Override
public void init(FilterConfig filterConfig) throws ServletException {
this.encoding = filterConfig.getInitParameter("encoding");
System.out.println("获取字符集过滤器中的初始化编码:"+this.encoding);
}

5.4 filter 的执行顺序

web.xml中映射顺序,越上面的越先执行;

MySecondFilter

public class MySecondFilter implements Filter {
@Override
public void destroy() {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {
System.out.println("-----1.MySecondFilter doFilter before ------");
chain.doFilter(request, response);
System.out.println("-----2.MySecondFilter doFilter after ------");
}
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
}

MyThridFilter

public class MyThridFilter implements Filter {
@Override
public void destroy() {
}
@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)throws IOException, ServletException {
System.out.println("-----3.MyThridFilter doFilter before ------");
chain.doFilter(request, response);
System.out.println("-----4.MyThridFilter doFilter after ------");
}
@Override
public void init(FilterConfig filterConfig) throws ServletException {
}
}

filterTarget.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
</head>
<body>
<%
System.out.println("-----5.Filter Target Page-----");
%>
<h2>Filter Target Page</h2>
</body>
</html>

web.xml

<!-- second -->
<filter>
<filter-name>mySecondFilter</filter-name>
<filter-class>com.kgc.filter.MySecondFilter</filter-class>
</filter> <filter-mapping>
<filter-name>mySecondFilter</filter-name>
<url-pattern>/web3filter01/filterTarget.jsp</url-pattern>
</filter-mapping> <!-- third -->
<filter>
<filter-name>myThridFilter</filter-name>
<filter-class>com.kgc.filter.MyThridFilter</filter-class>
</filter> <filter-mapping>
<filter-name>myThridFilter</filter-name>
<url-pattern>/web3filter01/filterTarget.jsp</url-pattern>
</filter-mapping>

运行结果顺序:

//执行顺序
-----1.MySecondFilter doFilter before ----
-----3.MyThridFilter doFilter before ------
-----5.Filter Target Page-----
-----4.MyThridFilter doFilter after -------
-----2.MySecondFilter doFilter after ------

5.5 编码过滤器

@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain)
throws IOException, ServletException {
//this.encoding 编码名可以存放在过滤器初始化参数中,通过filterConfig.getInitParameter("encoding");获取
//poet请求乱码处理
request.setCharacterEncoding(this.encoding);
//响应编码
response.setContentType("text/html; charset=UTF-8");
response.setCharacterEncoding(this.encoding); //请求放行
chain.doFilter(request, response);
}

Javaweb03-servlet&filter的更多相关文章

  1. servlet/filter/listener/interceptor区别与联系

    转自:http://www.cnblogs.com/doit8791/p/4209442.html servlet.filter.listener是配置到web.xml中(web.xml 的加载顺序是 ...

  2. java Servlet Filter 拦截Ajax请求

    /** * 版权:Copyright 2016-2016 AudaqueTech. Co. Ltd. All Rights Reserved. * 描述: * 创建人:赵巍 * 创建时间:2016年1 ...

  3. Java-maven异常-cannot be cast to javax.servlet.Filter 报错, 原因servlet-api.jar冲突

    使用maven开发web应用程序, 启动的时候报错: jar not loaded. See Servlet Spec . Offending class: javax/servlet/Servlet ...

  4. 理解Servlet过滤器 (javax.servlet.Filter)

    过滤器(Filter)的概念 过滤器位于客户端和web应用程序之间,用于检查和修改两者之间流过的请求和响应. 在请求到达Servlet/JSP之前,过滤器截获请求. 在响应送给客户端之前,过滤器截获响 ...

  5. 使用Servlet Filter做Login checking

    1) 建一个Login Servlet: Login.java package com.my; import java.io.*; import javax.servlet.*; import jav ...

  6. Servlet Filter 2

    10.Filter常见应用 )统一全站字符编码的过滤器 通过配置参数encoding指明使用何种字符编码,以处理Html Form请求参数的中文问题 案例:编写jsp 输入用户名,在Servlet中获 ...

  7. Servlet Filter 1

    1.Filter简介 )Filter也称之为过滤器,它是Servlet技术中最实用的技术,WEB开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图 ...

  8. Java Servlet Filter(转)

    做web开发的人对于Filter应该不会陌生,一直在很简单的使用,但是一直没有系统的总结一下,随着年纪的慢慢长大,喜欢总结一些事情,下面说说我对Filter的理解,官方给出的Filter的定义是在请求 ...

  9. JavaWeb三大组件(Servlet,Filter,Listener 自己整理,初学者可以借鉴一下)

    JavaWeb三大组件(Servlet,Filter,Listener 自己整理,初学者可以借鉴一下) Reference

  10. java.lang.ClassCastException: org.springframework.web.filter.CharacterEncodingFilter cannot be cast to javax.servlet.Filter

    java.lang.ClassCastException: org.springframework.web.filter.CharacterEncodingFilter cannot be cast ...

随机推荐

  1. 个人冲刺(七)——体温上报app(二阶段)

    冲刺任务:完成特殊情况功能 MoreActivity.java package com.example.helloworld; import android.content.Intent; impor ...

  2. 第06组Alpha冲刺(3/6)

    目录 1.1 基本情况 1.2 冲刺概况汇报 1.郝雷明 2.鲍凌函 3.曾丽莉 4. 曹兰英 5. 方梓涵 6.董翔云 7.杜筱 8.黄少丹 9. 詹鑫冰 10.吴沅静 1.3 冲刺成果展示 1.1 ...

  3. Java面试宝典学习笔记【2020】

    Java面试题总结 一.Java基础 1)Java有没有goto? goto是C语言中的,通常与条件语句配合使用,可用来实现条件转移, 构成循环,跳出循环体等功能.Java保留了这个关键字但是没有使用 ...

  4. drools动态增加、修改、删除规则

    目录 1.背景 2.前置知识 1.如何动态构建出一个kmodule.xml文件 2.kmodule.xml应该被谁加载 3.我们drl规则内容如何加载 4.动态构建KieContainer 3.需求 ...

  5. 【leetcode 206】 反转链表(简单)

    链表 概念: 区别于数组,链表中的元素不是存储在内存中连续的一片区域,链表中的数据存储在每一个称之为「结点」复合区域里,在每一个结点除了存储数据以外,还保存了到下一个结点的指针(Pointer). 由 ...

  6. C++ 智能指针浅析

    C++ 智能指针浅析 为了解决 C++ 中内存管理这个老大难问题,C++ 11 中提供了三种可用的智能指针.(早期标准库中还存在一种 auto_ptr,但由于设计上的缺陷,已经被 unique_ptr ...

  7. ElasticSearch6.4.2

    做一个简单的API记录 1.依赖为6.4.2  比较老的版本 2.指定ES集群,可接多个Put(); Setting setting=Setting.builder().put("clust ...

  8. 使用Group By子句的时候,一定要记住下面的一些规则

    使用Group By子句的时候,一定要记住下面的一些规则:(1)不能Group By非标量基元类型的列,如不能Group By text,image或bit类型的列(2)Select指定的每一列都应该 ...

  9. vue基本原理

    当一个Vue实例创建时,Vue会遍历data中的属性,用Object.defineProperty(vue3.0使用proxy)将它们转为getter/setter,并且在内部追踪相关依赖,在属性被访 ...

  10. OpenAPI 3.0 规范-食用指南

    概述 OpenAPI 3.0 规范由 8 个根对象组成: openapi info servers paths components security tags externalDocs OpenAP ...