JavaWeb-day15-请求转发、重定向、Filter、访问域

请求转发

实现

request.getRequestDispatcher("/regist_error.html").forward(request, response);

特点

  1. 在服务器内部完成,用户感知不到
  2. 浏览器地址栏不变
  3. 整个过程浏览器只发出了一个请求
  4. 目标资源可以在WEB-INF目录下

具体流程

在这里插入图片描述

请求的重定向

实现

response.sendRedirect("./regist_success.html");
response.sendRedirect("/MyNews/regist_success.html");
response.sendRedirect(request.getContextPath() + "/MyNews/regist_success.html");

特点

  1. 服务器以302状态码通知浏览器访问新地址
  2. 浏览器地址栏改变
  3. 整个过程浏览器发出两次请求
  4. 目标资源不可以在WEB-INF目录下

具体流程

在这里插入图片描述

请求转发和重定向的区别

  1. 访问次数
    转发:1次
    重定向: 2次
  2. url 地址
    转发:没变
    重定向:发生变化
  3. 是否可以携带数据(servlet -> jsp 的数据传递)
    转发 :可以携带数据
    重定向 :不可以携带数据

Filter

前序:

request.setCharacterEncoding("UTF-8");// 重复性代码
response.setContentType("text/html;charset=UTF-8");
像字符编码这种代码,每个Servlet都需要编码,就属于冗余代码,可以抽取出来放到拦截器里面

简介.

  1. Filter翻译为中文是过滤器的意思。
  2. Filter是JavaWeb的三大web组件之一Servlet、Filter、Listener
  3. Filter的作用是在请求到达WEB资源(HTML、CSS、Servlet、JSP)之前进行拦截。
  4. Filter需要交给Tomcat访问器来管理

Filter的作用:

  1. Filter可以在请求到达目标资源之前进行拦截

  2. Filter也可以放行请求

  3. Filter可以在响应到达浏览器之前做一个预处理

    Filter的生命周期
    一个请求的发送,到响应返回是一个线程。
    Filter的生命周期,指的是Filter对象由被创建到被销毁的过程。
    Filter的生命周期方法:

  • 构造器:Filter的构造器在服务器启动时调用。 构造器只会调用一次,说明Filter也是单例多线程的。
  • init():在构造器被调用后,紧接着被调用。作用:用来初始化Filter。
  • doFilter():每一次拦截请求时都会调用。
    参数
    ServletRequest request
    请求报文
    ServletResponse response
    响应报文
    FilterChain chain

该对象的作用就是放行请求:
可以通过 chain.doFilter(request,response) 放行请求。
当调用chain.doFilter()就相当于调用目标的资源的service方法。
destroy方法在项目停止时调用,用来在对象被销毁前做一些收尾工作。

  1. url-pattern的设置规则
  • 精确匹配:只有当目标资源的地址和url-pattern的地址一模一样时,Filter才会拦截资源
    例子:/2.jsp , 只有当浏览器访问项目根目录下的2.jsp时,才会调用Filter

  • 路径匹配:当访问的资源在url-pattern配置的路径下时,Filter就会拦截资源。
    例子1:/hello/* , 只要访问项目根目录下hello下的资源,就会调用Filter。
    例子2:/* , 会拦截项目根目录下所有资源

  • 后缀匹配:只要访问的资源地址和url-pattern的后缀一样就会调用Filter
    例子:*.jsp 只要是以jsp结尾的请求都会拦截

    • 以上规则适用于Servlet的url-pattern配置
    • 当使用Filter拦截一个Servlet时,可以将Filter的url-pattern和Servlet的url-pattern一样
      这样Filter就会拦截发送到Servlet的请求。
    • 也可以通过在filter-mapping中添加一个servlet-name标签来设置要拦截的Servlet的name
  1. Filter的执行顺序
  • 当我们为一个资源设置了多个过滤器时,这些过滤器就组成一个Filter链的结构。
    当我们去掉用chain.doFilter(),如果该过滤器后边还有其他的过滤,
    相当于调用了下一个过滤器doFilter()方法
    如果过滤器后没有其他的过滤器,我们调用chain.doFilter()
    相当于调用了目标资源的service()方法。

  • 多个Filter的执行顺序,有filter-mapping标签的配置顺序决定,
    filter-mappint靠前,则filter先执行,靠后则后执行。

  • 我们可以通过修改filter-mapping的顺序来修改Filter的执行顺序,

  • 但是注意,filter-mapping不能写在filter标签的前边。

访问域

  1. 访问域都包含哪些
    request
    Session
    applicationContext

  2. 访问域的优先级

     优先级(在没有指定的情况下)
      request > Session > Context
    
  3. 访问域的访问范围

    范围大小: applicationContext > session > request

    request (访问范围只在一次servlet中有效)
    session(访问范围只在同一个浏览器里面有效)
    applicationContext(访问范围只在同一个tomcat服务里面)
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值