可以看到web容器一启动就会实例化监听器的contextInitialized(ServletContextEvent event)方法,然后是过滤器的init()方法,最后在用户访问web应用的 时候会先执行过滤器的doFilter()方法,以及过滤器链,最后执行继承了HttpServlert的自定义Servlet里复写的doPost()方法或者doGet方法。

1 web容器初始化:

初始化顺序:

a.监听器ServletContextListener接口实现类复写的

 public void contextInitialized(ServletContextEvent event) {

 }

b.过滤器Filter接口的实现类复写的

public void init(FilterConfig filterConfig) throws ServletException {
String para1 = filterConfig.getInitParameter("para1");
System.out.println("卫永乐WylFilter.init()...");
}

如果有多个过滤器,那么过滤器的初始化顺序是web.xml中配置由下到上的(注意:容器启动的时候的初始化顺序是由下到上,但是在用户进行资源的访问的时候,过滤器复写的

public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain)方法是由上至下的,也就是还是按照web.xml中配置的顺序由上到下执行,只是初始化的时候的顺序是相反的

)。

2 用户访问web资源:

 容器的执行顺序:

a.过滤器的doFilter方法,

@SuppressWarnings("all")
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
System.out.println("卫永乐WylFilter.doFilter() begin..."); /**
* 设置编码集,统一为UTF-8,这样就不会有乱码的存在,因为除了web容器启动完成后,
* 每次的请求都会最先被WylFilter先拦截,所以只要在这个地方设置一下字符集就行了,
* 不需要每次都在自定义的Servlet里设置字符集
*/
HttpServletRequest httpReq = (HttpServletRequest)request;
HttpServletResponse resp = (HttpServletResponse)response;
resp.setCharacterEncoding("UTF-8");
resp.setHeader("Content-type", "text/html;charset=UTF-8"); //增加登录校验
checkLoginStatus(request,response); String requestURI = httpReq.getRequestURI().substring(
httpReq.getRequestURI().indexOf("/", 1),
httpReq.getRequestURI().length());
System.out.println("requestURI:"+requestURI);
//如果请求uri不包含 login.jsp,那么就检查是否已经登录了。
if(requestURI.indexOf("login.jsp")==-1){
//获取请求内容,对请求内容进行过滤
String reqContent = httpReq.getQueryString();
List<String> list = UtilProperties.GetContentByKeytoStringArr("keyContent.properties","invalidWords");
//先清空
response.getWriter().write("");
//只有reqContent不等于null的时候才能对其进行内容的过滤
if(null!=reqContent){
for(int i=0;i<list.size();i++){
if(reqContent.indexOf(list.get(i))!=-1){
response.getWriter().write("the request is not valid because it contains:"+list.get(i));
System.out.println("the request is not valid because it contains: "+list.get(i));
}
}
}
//getParameterValues()获取键为df的所有值,返回值是数组
String[] paraValues = request.getParameterValues("df");
String sss = request.getParameter("df");
System.out.println("sss:"+sss);
request.getScheme();//获取请求使用的通讯协议,比如通过http请求,那么返回值就是"http"
request.getServerName();//获取服务器主机名,实际上就是获取服务器ip地址
request.getServerPort();//获取服务器端口号
Enumeration em = request.getAttributeNames();
Map map = new HashMap();
if(em.hasMoreElements()){
Object o = em.nextElement();
map.put(""+o, o);
}
System.out.println("map:"+map);
}
chain.doFilter(request, response);
System.out.println("卫永乐WylFilter.doFilter() end...");
}

b.Servlet的doGet(HttpServletRequest req, HttpServletResponse resp)方法或者protected void doPost(HttpServletRequest req, HttpServletResponse resp)方法。

如果有多个过滤器,那么在第一个过滤器中执行了chain.doFilter(request,response)这行代码后就会执行下一个过滤器的doFilter(request,response)方法,直到执行最后一个过滤器的doFilter(request,response)方法,然后执行Servlet里的doGet(HttpServletRequest req, HttpServletResponse res)方法,

例如:

@Override
protected void doGet(HttpServletRequest req, HttpServletResponse resp)
throws ServletException, IOException {
System.out.println("卫永乐WylServlet1.doGet() begin...");
Enumeration<Object> em = req.getHeaderNames();
if(em.hasMoreElements()){
String headName = (String)em.nextElement();
String head = req.getHeader(headName);
System.out.println("卫永乐WylServlet1.doGet()方法执行中...,header:"+head);
}
String path = req.getContextPath();
/*resp.setCharacterEncoding("UTF-8");
resp.setHeader("Content-type", "text/html;charset=UTF-8"); */
String content = "我是PrintWriter对象输入到页面的内容,哈哈哈哈,HttpServletRequest.getContextPath()"+path;
PrintWriter out = resp.getWriter();
out.write(content);
System.out.println("卫永乐WylServlet1.doGet() end..."); }

web项目中的监听器,过滤器以及自定义servlet的执行顺序的更多相关文章

  1. php课程 1-3 web项目中php、html、js代码的执行顺序是怎样的(详解)

    php课程 1-3 web项目中php.html.js代码的执行顺序是怎样的(详解) 一.总结 一句话总结:b/s结构 总是先执行服务器端的先.js是客户端脚本 ,是最后执行的.所以肯定是php先执行 ...

  2. 【Filter 不登陆无法访问】web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面的功能

    在web项目中写一个过滤器实现用户不登陆,直接给链接,无法进入页面,而重定向到登陆界面的功能. 项目是用springMVC+spring+hibernate实现 (和这个没有多大关系) 第一步: 首先 ...

  3. web.xml 中的listener、 filter、servlet 加载顺序及其详解

    在项目中总会遇到一些关于加载的优先级问题,近期也同样遇到过类似的,所以自己查找资料总结了下,下面有些是转载其他人的,毕竟人家写的不错,自己也就不重复造轮子了,只是略加点了自己的修饰. 首先可以肯定的是 ...

  4. 过滤器(filter),监听器(listener),与servlet的执行顺序

    创建: 加载顺序 监听器-->过滤器-->Servlet.项目启动后,容器会首先创建声明的各种监听器,为后继的各个事件监听做准备,然后创建过滤器,最后是Servlet.销毁的时候是反序进行 ...

  5. web.xml 中的listener、filter、servlet 加载顺序及其【配置详解】

    在项目中总会遇到一些关于加载的优先级问题,近期也同样遇到过类似的,所以自己查找资料总结了下,下面有些是转载其他人的,毕竟人家写的不错,自己也就不重复造轮子了,只是略加点了自己的修饰. 首先可以肯定的是 ...

  6. 转:web.xml 中的listener、 filter、servlet 加载顺序及其详解

    在项目中总会遇到一些关于加载的优先级问题,刚刚就遇到了一个问题,由于项目中使用了quartz任务调度,quartz在web.xml中是使用listener进行监听的,使得在tomcat启动的时候能马上 ...

  7. web.xml 中的listener、 filter、servlet 加载顺序及其详解(转)

    在项目中总会遇到一些关于加载的优先级问题,近期也同样遇到过类似的,所以自己查找资料总结了下,下面有些是转载其他人的,毕竟人家写的不错,自己也就不重复造轮子了,只是略加点了自己的修饰. 首先可以肯定的是 ...

  8. web.xml 中的listener、 filter、servlet 加载顺序

    在项目中总会遇到一些关于加载的优先级问题,近期也同样遇到过类似的,所以自己查找资料总结了下,下面有些是转载其他人的,毕竟人家写的不错,自己也就不重复造轮子了,只是略加点了自己的修饰. 首先可以肯定的是 ...

  9. 1.ssm web项目中的遇到的坑--自定义JQuery插件(slide menu)

    自定义的JQuery插件写的回调函数不执行: 写好了回调函数,将函数打印出来是原形,就是不执行 function () { console.log("---onClickItem---&qu ...

随机推荐

  1. Unix/Linux环境C编程新手教程(21) 各个系统HelloWorld跑起来效果怎样?

    版权声明:本文为博主尹成联系QQ77025077,微信18510341407原创文章,欢迎转载侵权不究. https://blog.csdn.net/yincheng01/article/detail ...

  2. 转://利用从awr中查找好的执行计划来优化SQL

    原文地址:http://blog.csdn.net/zengxuewen2045/article/details/53495613 同事反应系统慢,看下是不是有锁了,登入数据库检查,没有异常锁定,但发 ...

  3. redis单例模式写法

    <?php /**只看红色重点 * =========================================================== * ZW_Memory_Cache * ...

  4. (五)JavaScript 变量

    JavaScript 变量 与代数一样,JavaScript 变量可用于存放值(比如 x=5)和表达式(比如 z=x+y). 变量可以使用短名称(比如 x 和 y),也可以使用描述性更好的名称(比如 ...

  5. ORA-27154: post/wait create failed ORA-27300 ORA-27301 ORA-27302

    今天刚装了Oracle 11g,配制好了之后启动数据库时遇到下面的错误:SQL> startupORA-27154: post/wait create failedORA-27300: OS s ...

  6. Java虚拟机垃圾收集器

    一.判断对象存活的算法 1.引用计数(Reference Counting)算法 给对象添加一个引用计数器,每当有一个地方引用时,计数器加1.当引用失效时,计数器减1.当计数器的值为0的时候说该对象不 ...

  7. linux学习问题总结

    目录 一.环境变量和普通变量的区别 二.rsyslog和logrotate会不会丢记录的问题 三.为什么有些文件夹大小不是4096的整数倍 四.reboot和shutdown等软链接实现原理 五.sy ...

  8. RichTextbox下Hyperlink的Click无效

    原文:RichTextbox下Hyperlink的Click无效 两种方式解决: 1.<RichTextBox IsReadOnly="True" IsDocumentEna ...

  9. 读写分离子系统 - C# SQL分发子系统 - Entity Framework支持

    A2D Framework增加了EF支持,加上原先支持ADO.NET: 支持EF方式 支持ADO.NET方式 这次来讲如何让Entity Framework变成nb的读写分离 1. 先设计EF模型, ...

  10. 人生就像一条加速奔向死亡的贪吃蛇【winform版】

    群里聊天的时候,一个学妹说她在做贪吃蛇的小作业,于是昨晚(5.20无聊只好撸代码/(ㄒoㄒ)/~~)花了2个小时撸了一个出来,早上又花了些时间完善功能,就有了这个还算比较完善的版本,当然代码结构比较混 ...