Servlet的欢迎资源文件、状态码以及多个Servlet之间调用规则【Part2】

98 阅读6分钟

本文已参与[新人创作礼]活动,一起开启掘金创作之路。

哈喽,大家好!我是Why,一名在读学生,目前刚刚开始进入自己的编程学习生涯。虽然学习起步较晚,但我坚信做了才有0或1的可能。学了一段时间以后也是选择在掘金上分享自己的日常笔记,也希望能够在众多道友的大家庭中打成一片。 本文主要讲解Servlet的欢迎资源文件、状态码以及多个Servlet之间调用规则,如果大家读后觉得有用的话,还请大家多多支持博主:欢迎 ❤️点赞👍、收藏⭐、留言💬 ✨✨✨个人主页:JinHuan

欢迎资源文件

 1、默认欢迎资源文件:
 ​
         用户发送了一个针对某个网站的【默认请求】时,
         此时由Http服务器自动从当前网站返回的资源文件
 ​
         正常请求: http://localhost:8080/myWeb/index.html
 ​
         默认请求: http://localhost:8080/myWeb/
 ​
 2、Tomcat对于默认欢迎资源文件定位规则
 ​
         1)规则位置:Tomcat安装位置/conf/web.xml
 ​
         2)规则命令:<welcome-file-list>
             <welcome-file>index.html</welcome-file>
             <welcome-file>index.htm</welcome-file>
             <welcome-file>index.jsp</welcome-file>
         </welcome-file-list>
 ​
 3、设置当前网站的默认欢迎资源文件规则
 ​
         1)规则位置:  网站/web/WEB-INF/web.xml
 ​
         2)规则命令:  <welcome-file-list>
             <welcome-file>login.html</welcome-file>
         </welcome-file-list>
         3)网站设置自定义默认文件定位规则,此时Tomcat自带定位规则将失效

HTTP状态码

 1、介绍:
     1)由三位数字组成的一个符号
     2)HTTP服务器在推送响应包的之前,根据本次请求处理情况
         将HTTP状态码写到响应包中的【状态行】上
     3)如果HTTP服务器针对本次请求,返回了对应的资源文件
         通过HTTP状态码通知浏览器应该怎样处理这个结果
        如果HTTP服务器针对本次请求,无法返回对应的资源文件
         通过HTTP状态码向浏览器解释不能提供服务的原因
 2、分类:
     1)组成:
         100--599;分为五个大类
         a1XX:
             最有特征:100
                 通知浏览器本次返回的资源文件并不是一个独立的资源文件,需要浏览器在接收响应包之后,继续向HTTP服务器索要依赖                 的其他资源文件。
         b2XX
             最有特征:200
                 通知浏览器本次返回的是一个完整的独立的资源文件,浏览器在接收后不需再向HTTP服务器索要其他关联的资源文件
         c:3XX
             最有特征:302
                 通知浏览器本次返回的不是一个资源文件内容,而是一个资源文件地址,需要浏览器根据这个地址自动发起请求来索要对                应的资源文件
         d:4XX
             最有特征:404
                 通知浏览器,由于在服务端没有定位到被访问的资源文件 因此无法提供帮助
               405:
                 通知浏览器,在服务端已经定位到被访问的资源文件(Servlet) 但是这个Servlet对于浏览器采用的请求方式不能处理
          e:5XX
             最有特征500:
                 通知浏览器,在服务端已经定位到被访问的资源文件(Servlet)这个Servlet可以接收浏览器采用请求方式,但是                   Servlet在处理 请求期间,由于Java异常导致处理失败

多个Servlet之间调用规则

 1.前提条件:
     某些来自于浏览器发送请求,往往需要服务端中多个Servlet协同处理。
     但是浏览器一次只能访问一个Servlet,导致用户需要手动通过浏览器发起'多次请求'才能得到服务。这样增加用户获得服务难度,导致用户  放弃访问当前网站【98k,AKM】
 2.提高用户使用感受规则:
     无论本次请求涉及到多少个Servlet,用户只需要【手动】通知浏览器发起'一次请求即可
 3.多个Servlet之间调用规则:
     1)重定向解决方案
     2)请求转发解决方案
重定向解决方案
 1.工作原理: 用户第一次通过【手动方式】通知浏览器访问OneServlet。
      OneServlet工作完毕后,将TwoServlet地址写入到响应头 location属性中,导致Tomcat302状态码写入到状态行。
      在浏览器接收到响应包之后,会读取到302状态。此时浏览器自动根据响应头中location属性地址发起第二次请求,访问
      TwoServlet去完成请求中剩余任务
 2.实现命令:
             response.sendRedirect("请求地址")
             将地址写入到响应包中响应头中location属性
 3.特征:
     1)请求地址:
             既可以把当前网站内部的资源文件地址发送给浏览器 (/网站名/资源文件名)
             也可以把其他网站资源文件地址发送给浏览器(http://ip地址:端口号/网站名/资源文件名)
     2)请求次数
             浏览器至少发送两次请求,但是只有第一次请求是用户手动发送。
             后续请求都是浏览器自动发送的。
     3) 请求方式:
             重定向解决方案中,通过地址栏通知浏览器发起下一次请求,因此
             通过重定向解决方案调用的资源文件接收的请求方式一定是【GET】
  4.缺点:
          重定向解决方案需要在浏览器与服务器之间进行多次往返,大量时间
          消耗在往返次数上,增加用户等待服务时间
请求转发解决方案
 1.原理:   用户第一次通过手动方式要求浏览器访问OneServlet。
             OneServlet工作完毕后,'通过当前的请求对象代替浏览器' 向Tomcat发送请求,申请调用TwoServlet。
             Tomcat在接收到这个请求之后,自动调用TwoServlet来完成剩余任务
 ​
 2.实现命令: 请求对象代替浏览器向Tomcat发送请求
             //1.通过当前请求对象生成资源文件申请报告对象
             RequestDispatcher  report = request.getRequestDispatcher("/资源文件名");一定要以"/"为开头
             //2.将报告对象发送给Tomcat
             report.forward(当前请求对象,当前响应对象)
 3.优点:      
     1)无论本次请求涉及到多少个Servlet,用户只需要手动通过浏览器发送一次请求
     2) Servlet之间调用发生在服务端计算机上,节省服务端与浏览器之间往返次数增加处理服务速度
 4.特征:
     1)请求次数:
     在请求转发过程中,浏览器只发送'一次请求
     2)请求地址:
     只能向Tomcat服务器申请调用当前网站下资源文件地址
     request.getRequestDispathcer("/资源文件名") ****不要写网站名****
     3)请求方式:
     在请求转发过程中,浏览器只发送一个了个Http请求协议包。
     参与本次请求的所有Servlet共享同一个请求协议包,因此
     这些Servlet接收的请求方式与浏览器发送的请求方式'保持一致