2021-08-15 笔记

7.欢迎资源文件

  1. 前提:

    ​ 用户可以记住网站名,但是不会记住网站资源文件名

  2. 默认欢迎资源文件:

    ​ 用户发送了一个针对某个网站的【默认请求】时,此时由Http服务器自动从当前网站返回的资源文件

    ​ 正常请求:http://localhost:8080/myWeb/index.html

    ​ 默认请求:http://localhost:8080/myWeb/

  3. Tomcat对于默认欢迎资源文件定位规则:

    1. 规则位置:Tomcat安装位置/conf/web.xml

    2. 规则命令:

      ​ index.html

      ​ index.htm

      ​ index.jsp

  4. 设置当前网站的默认:

    1. 规则位置:网站/web/WEB-INF/web.xml

    2. 规则命令:

      ​ login.html

    3. 网站设置自定义默认文件定位规则,此时Tomcat自带定位规则将失效

8.Http状态码

  1. 介绍:

    1. 由三位数字组成的一个符号

    2. Http服务器在推送响应包之前,根据本次请求处理情况,将Http状态码写入到响应包中【状态行】上

    3. 如果Http服务器针对本次请求,返回了对应的资源文件。通过Http状态码通知浏览器应该如何处理这个结果

      如果Http服务器针对本次请求,无法返回对应的资源文件,通过Http状态码向浏览器解释不能提供服务的原因

  2. 分类:

    1. 组成100-599;分为5个大类

      1)1XX:

      ​ 最有特征100:通知浏览器本次返回的资源文件,并不是一个独立的资源文件,需要在浏览器接收响应包之后,继续向Http服务器所要依赖的其他资源文件

      2)2XX:

      ​ 最有特征200:通知浏览器本次返回的资源文件时一个完整的独立资源文件,浏览器在接收到之后不需要索要其他关联文化

      3)3XX:

      ​ 最有特征302:通知浏览器本次返回的不是一个资源文件内容,而是一个资源文件地址,需要浏览器根据这个地址自动发起请求来索要这个资源文件

      ​ response.sendRenirect(“资源文件地址”)写入到响应头中location,而这个行为倒是Tomcat将302状态码写入到状态行

      4)4XX:

      ​ 404:通知浏览器,由于在服务端没有定位到被访问的资源文件,因此无法提供帮助

      ​ 405:通知浏览器,在服务端已经定位到被访问的资源文件(Servlet)但是这个Servlet对于浏览器采用的请求方式不能处理

      5)5XX:

      ​ 500:通知浏览器,在服务端已经定位到被访问的资源文件(Servlet),这个Servlet可以接收浏览器采用请求方式,但是Servlet在处理请求期间,由于Java异常导致处理失败

9.多个Servlet之间调用规则

  1. 前提条件:

    某些来自于浏览器发送请求,往往需要服务端多个Servlet协同处理。但是浏览器一次只能访问一个Servlet,导致用户需要手动通过浏览器发起多次请求才能得到服务。

    这样增加用户获得难度,导致用户放弃访问当前网站

  2. 提高用户使用感受规则:

    无论本次请求涉及到多少个Servlet,用户只需要【手动】通知浏览器发起一次请求即可

  3. 多个Servlet之间调用规则:

    1. 重向解决方案
    2. 请求转法解决方案

10.重定向解决方案

  1. 工作原理 :

    ​ 用户第一次通过【手动方式】通知浏览器访问OneServlet,OneServlet工作完毕后,将TwoServlet地址写入到响应头location属性中,导致Tomcat将302状态码写入到状态行。

    ​ 在浏览器接收到响应包之后,会读取到302状态。此时浏览器自动根据响应头中location属性地址发起第二次请求,访问TwoServlet去完成请求中剩余任务。

  2. 实现命令:

    ​ response.sendRedirect(“请求地址”) 将地址写入到响应包中的响应头中location属性

  3. 特征:

    1. 请求地址:

      既可以把当前网站内部的资源文件地址发送给浏览器(/网站名/资源文件名)

      也可以把其他网站资源文件地址发送给浏览器(http://ip地址:端口号/网站名/资源文件名)

    2. 请求次数:

      浏览器至少发送两次请求,但是只有第一次请求是用户手动发送。后续请求都是浏览器自动发送的

    3. 请求方式:

      重定向解决方案中,通过地址栏通知浏览器发起下一次请求,因此通过重定向解决方案调用的资源文件接收的请求方式一定是【get】

  4. 缺点:

    重定向解决方案需要在浏览器与服务器之间进行多次往返,大量时间消耗在往返次数上,增加用户等待服务时间

11.请求转发解决方案

  1. 原理:

    用户第一次通过手动方式要求浏览器访问OneServlet。OneServlet工作完毕后,通过当前的请求对象代替浏览器向Tomcat发送请求,申请调用TwoServlet。TwoServlet在接收到这个请求之后,自动调用TwoServlet来完成剩余任务

  2. 实现命令:

    请求对象代替浏览器向Tomcat发送请求

    //1.通过当前请求对象生成资源文件申请报告对象

    ​ RequestDispatcher report= request.getRetquestDispatcher("/资源文件名");//一定要以“/”为开头

  3. 优点:

    1. 无论本次涉及到多少个Servlet,用户只需要手动通过浏览器发送一次请求
    2. Servlet之间调用发生在服务端计算机上,节省服务端与浏览器之间往返次数,增加处理服务速度
  4. 特征:

    1. 请求次数:

      在请求转发过程中,浏览器只发送一次请求

    2. 请求地址:

      只能向Tomcat服务器申请调用当前网站下的资源文件地址

      request.getRequestDispathcer("/资源文件名")不要写网站名

    3. 请求方式:

      在请求转发过程中,浏览器只发送了一个Http请求协议包。参与本次请求的所有Servlet共享同一个请求协议包,因此这些Servlet接收的请求方式与浏览器发送的请求方式保持一致

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值