一、Servlet的两个Map

  当请求到达后,web容器是如何查找Servlet的呢?执行流程又是什么?

  可能很多人和我一样,只知道在web,xml中配置拦截规则,然后反射+映射就完事了?

  当Servlet实列被创建后,会将该Servlet实列的引用存放到一个Map中,该Map的K是url,V是Servlet的实列引用+

  即Map<String,Servlet>

  当Web容器从用户请求中分离出URI 后,会首先在这个Map查找是否又对应的Value,即Servlet引用

  如果存在的话,就会调用其的service方法,若不存在,则需要创建该Servlet实列

  若请求的Servlet实列不存在,就有下面这一波操作

  在web容器的内存中,还存了一个Map集合该Map的K为URI,V为在web.xml中配置的与之对应的Servlet的全限定名

  即Map<String,String>

  当Web容器从用户的请求中分离出URI后,到第一个Map中又没有找到对应的Servlet引用,

  于是跑到第二个Map中去找,从中找到其所对应的类名,再根据反射机制,创造这个Servlet实列,

  最后还得把这个实列引用存入到第一个Map中,前人种树后人乘凉。

二、Filter的一个Map一个数组

  像存放Servlet信息的两个Map一样,在服务器中同样存在用于存放Filter相关信息的Map

  但Map只有一个,因为Filter的创建时机不同于Servlet,其是由在服务器启动时由Web容器自动创建的

  这个Map的K是Filter的<url-pattern/>,

  当然,若Filter没有设置<url-pattern>,而是使用了<servlet-name/>

  则会将制定的Servlet的<url-pattern>值放到Map中作为K

  Map的V为该Filter的引用

  在应用被启动时,服务器会自动的创建所有的Filter实列,并将他们一一存入Map

  在服务器中,对于每一个请求还存在一个数组,用于存储满足当前请求的所有Filter及最终的目标资源

  当请求到达服务器后,服务器会解析出URI,首先查询Map中与该请求匹配的Filter

  每找到一个满足要求的Filter,就将其放入到数组中,直到过滤完所有的Filter

  这个数组中存放的是与请求匹配的Filter,可以看作一个“链”,服务器会按照顺序对请求进行依次过滤处理

三、注意

  对于Filter的Map而言,会查询过滤所有的Key,将所有符合匹配的都装入到数组中

  而Servlet的Map的查询过程是,只要找到一个匹配的Key,就不会再往后面找了

最新文章

  1. python之路:Day02 --- Python基础2
  2. 关于一个程序的编译过程 zkjg面试
  3. 【转】快速理解Kafka分布式消息队列框架
  4. 获取SHA1和MD5
  5. Linux进程启动过程简析
  6. centos 安装phantomjs
  7. VC error LNK2005 解决办法
  8. saltstack实战4--综合练习4
  9. mac下烦人的eclipse安装svn插件
  10. Mysql内存表的用处
  11. Android ToolBar详解
  12. java基础进阶:SQL的运用
  13. perl 当前包会覆盖父类的同名方法
  14. [补档][Poi2010]Monotonicity 2
  15. 201521123037 《Java程序设计》第14周学习总结
  16. Tornado异步
  17. 【翻译】Ext JS最新技巧
  18. Node中包的加载机制
  19. 对Entity Framework Core的一次误会:实体状态不跟踪
  20. windows下使用python操作redis(Visual Studio Code)

热门文章

  1. python 基本输入输出
  2. python中常见的内置函数
  3. tf-idf 词条权重计算
  4. quartz的使用(三)
  5. python代码自动补全
  6. SQL Server中配置ODBC数据源
  7. tomcat部署安全证书文件(阿里云SSL证书)
  8. NOIp2018集训test-9-17(pm)
  9. NX二次开发-创建圆弧(起点-终点-半径)UF_CURVE_create_arc_point_point_radius
  10. NXOpenC#_Training_1(cn)【转载】