Servlet学习(二)

Servlet学习(二)

七、欢迎资源文件

​ 1.前提:
​ 用户可以记住网站名,但是不会记住网站资源文件名

​ 2.默认欢迎资源文件:

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

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

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

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

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

  • 规则命令:

    <welcome-file-list>
        <welcome-file>index.html</welcome-file>
        <welcome-file>index.htm</welcome-file>
        <welcome-file>index.jsp</welcome-file>
    </welcome-file-list>
    

    4.设置当前网站的默认欢迎资源文件规则

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

  • 规则命令:

    <welcome-file-list>
        <welcome-file>login.html</welcome-file>
    </welcome-file-list>
    
  • 网站设置自定义默认文件定位规则,此时Tomcat自带定位规则将失效

示范写法:

 <!--自定义默认欢迎资源文件-->
    <welcome-file-list>
        <welcome-file>login.html</welcome-file>
    <!--动态资源文件也可以是欢迎文件 ,但是要去除别名最前面的 / -->
        <welcome-file>user/login</welcome-file>
    </welcome-file-list>

八、Http状态码

1.介绍:
1)由三位数字组成的一个符号。
2)Http服务器在推送响应包之前,根据本次请求处理情况
将Http状态码写入到响应包中【状态行】上

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

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

2.分类:

  • 1)组成 100—599;分为5个大类

  • 2)1XX :

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

  • 3) 2XX:

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

  • 4)3xx:

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

    response.sendRedirect(“资源文件地址”)写入到响应头中
    location
    而这个行为导致Tomcat将302状态码写入到状态行

  • 5)4XX:

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

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

  • 6)5xx:

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

九、多个Servlet之间调用规则:

​ 1.前提条件:
某些来自于浏览器发送请求,往往需要服务端中多个Servlet协同处理。
但是浏览器一次只能访问一个Servlet,导致用户需要手动通过浏览器
发起多次请求才能得到服务。
这样增加用户获得服务难度,导致用户放弃访问当前网站

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

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

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

​ 1)重定向解决方案

​ 2)请求转发解决方案

十。重定向解决方案:

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

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

​ 2.实现命令:

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

​ 3.特征:

​ 1)请求地址:
​ 既可以把当前网站内部的资源文件地址发送给浏览器 (/网站名/资源文件名)
​ 也可以把其他网站资源文件地址发送给浏览器(http://ip地址:端口号/网站名/资源文件名)

​ 2)请求次数

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

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

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

例子:

package com.controller.chongdingxiang;

import java.io.IOException;

public class oneServlet extends javax.servlet.http.HttpServlet {
    protected void doPost(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException, IOException {

    }

    protected void doGet(javax.servlet.http.HttpServletRequest request, javax.servlet.http.HttpServletResponse response) throws javax.servlet.ServletException, IOException {
        System.out.println("gogogo1");
        //重定向
        response.sendRedirect("/servlet/two");
        System.out.println("gogogo2");
    }
}



package com.controller.chongdingxiang;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

public class twoServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        PrintWriter out = response.getWriter();
        out.println("<p1>现在是two的doget</p1>");
    }
}

执行截图:

在这里插入图片描述

十一、请求转发解决方案:

​ 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接收的请求方式与浏览器发送的请求方式保持一致

例子:

package com.controller.zhuanfa;

import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

public class threeServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        PrintWriter out = response.getWriter();
        out.println("Three页面");
        //1.通过当前请求对象生成资源文件申请报告对象
        System.out.println("gogogo3");
        RequestDispatcher report = request.getRequestDispatcher("/four");
        report.forward(request, response);
        System.out.println("gogogo4");
    }
}


package com.controller.zhuanfa;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.io.PrintWriter;

public class fourServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        response.setContentType("text/html;charset=utf-8");
        
        PrintWriter out = response.getWriter();
        out.println("<p1>现在是four的doGet</p1>");


    }
}


执行截图:

在这里插入图片描述

十二、多个Servlet之间数据共享实现方案:

​ 1.数据共享:OneServlet工作完毕后,将产生数据交给TwoServlet来使用

​ 2.Servlet规范中提供四种数据共享方案

  • 1.ServletContext接口

  • 2.Cookie类

  • 3.HttpSession接口

  • 4.HttpServletRequest接口

十三、ServletContext接口:

1.介绍:
​ 1)来自于Servlet规范中一个接口。在Tomcat中存在servlet-api.jar
​ 在Tomcat中负责提供这个接口实现类

​ 2)如果两个Servlet来自于同一个网站。彼此之间通过网站的ServletContext
​ 实例对象实现数据共享

​ 3)开发人员习惯于将ServletContext对象称为【全局作用域对象】

2.工作原理:

​ 每一个网站都存在一个全局作用域对象。
​ 这个全局作用域对象【相当于】一个Map.
​ 在这个网站中OneServlet可以将一个数据
​ 存入到全局作用域对象,当前网站中其他
​ Servlet此时都可以从全局作用域对象得到
​ 这个数据进行使用

3.全局作用域对象生命周期:

​ 1)在Http服务器启动过程中,自动为当前网站在内存中创建
​ 一个全局作用域对象
​ 2)在Http服务器运行期间时,一个网站只有一个全局作用域对象

​ 3)在Http服务器运行期间,全局作用域对象一直处于存活状态

​ 4)在Http服务器准备关闭时,负责将当前网站中全局作用域对象
​ 进行销毁处理
全局作用域对象生命周期贯穿网站整个运行期间

4.命令实现:

 【同一个网站】OneServlet将数据共享给TwoServlet

    OneServlet {

        public void doGet (HttpServletRequest request, HttpServletResponse response){

//1.通过【请求对象】向Tomcat索要当前网站中【全局作用域对象】
            ServletContext application = request.getServletContext();
//2.将数据添加到全局作用域对象作为【共享数据】
            application.setAttribute("key1", 数据)

        }

    }


 TwoServlet {

        public void doGet (HttpServletRequest request, HttpServletResponse response){

//1.通过【请求对象】向Tomcat索要当前网站中【全局作用域对象】
            ServletContext application = request.getServletContext();
//2.从全局作用域对象得到指定关键字对应数据
            Object 数据 = application.getAttribute("key1");

        }

    }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

LvhaoIT

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值