servlet知识点

本文介绍了Servlet中的请求转发机制,包括forward与include方法的区别及应用场景,并详细解释了RequestDispatcher对象的作用。此外,还探讨了ServletRequest与ServletResponse接口的相关方法,如sendRedirect与forward的区别。最后,文章还介绍了几种常用的监听器和过滤器(Filter)的功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. RequestDispatcher对象,可以将请求转发给另外一个Servlet或JSP页面,甚至是HTML页面,来处理对请求的响应。
  (1)RequestDispatcher对象由Servlet容器来创建,封装一个由路径所标识的服务器资源。    
     RequestDispatcher接口中定义了二种方法用于请求转发:    
           forward(ServletRequest,ServletResponse)方法,将请求转发给服务器上资源处理,必须在响应被提交给客户端之前调用,否则抛出异常。方法调用后在响应中的没有提交的内容被自动消除。    
           include(ServletRequest,ServletResponse)方法 :用于在响应中包含其他资源的内容。即请求转发后,转发到的Servlet对请求做出的响应将并入原先Servlet的响应对象中。      
     forward方法和include方法的区别:
                  forward方法调用后主导权在另一个资源中,在响应中的没有提交的内容被自动消除。   include方法:被调用的Servlet虽然可以处理这个HTTP请求,但是最后的主导权仍然是在原来的Servlet。换言之,被调用的Servlet如果产生任何HTTP回应,将会并入原来的HttpResponse对象。   

   (2) 得到RequestDispatcher对象  
             1,利用ServletRequest接口中的getRequestDispatcher(String  path)方法。   
             2,ServletContext接口中getNamedDispatcher(String  path)和getRequestDispatcher(String  path)方法。
     ServletRequest接口和ServletContext接口中getRequestDispatcher方法区别:   
              1,参数的区别    
                      参数虽然都是资源路径名,ServletContext接口的中参数路径必须以“/”开始,是相对于当前Servlet上下文根,    ServletRequest接口中的参数路径不仅可以相对于当前Servlet上下文根,还可以相对与当前Servlet路径    
             2,跨WEB应用程序访问资源    
                      通过ServletContext.getContext()方法获取另个WEB应用程序的上下文环境对象来    调用getRequestDispatcher(String  path)方法将请求转发到另个WEB应用程序的资源。还需要在当前WEB应用程序配置中设置<context>元素,指定crossContext属性值为true。

    (3),ServletResqonse接口中的sendRedirect()方法和forward()方法的区别  
       sendRedirect()方法原理:   
              1,客户端发送请求,Servlet1做出处理。   
              2,Servlet1调用sendReadirect()方法,将客户端的请求 重新定位 到Servlet2。   
              3,客户端浏览器访问Servlet2.  
              4,Servlet2对客户端浏览器做出响应。
       forward()方法原理:  
             1,客户端发送请求,Servlet1做出处理。  
             2,Servlet1调用forward()方法,将请求转发给Servlet2来处理请求,为客户端服务。   
             3,Servlet2对客户端浏览器做出响应。      
      区别: 1,定位与转发   
                    sendRedirect()方法实际上是告诉浏览器Servlet2所在的位置,让浏览器重新访问Servlet2。调用 sendRedirect()方法,会在响应中设置Location响应报头。显示的URL是重定向之后的URL,
                   forward()方法是转发到另外一个资源来处理请求。URL不会变化。隐藏了处理对象的变化。   
           2,处理请求的资源的范围   
                  sendReadirect()方法可以跨WEB应用程序和服务器重新定位资源来处理请求。forward()方法只能在应用程序内部转发。

 

 

2.

127.0.0.1         request..getRemoteAddr();

                        request.getRemoteHost();

/oa/HelloWorldServlet              request.getRequestURI()
http://127.0.0.1:8080/oa/HelloWorldServlet            request.getRequestURL().toString();
/HelloWorldServlet                  request.getServletPath();
/oa                request.getContextPath()

 

3.监听器

     (1)种类

          1) 监听web应用

                a)  ServletContextListener:用于监听WEB 应用启动和销毁的事件,监听器类需要实现javax.servlet.ServletContextListener 接口。
                b).ServletContextAttributeListener:用于监听WEB应用属性改变的事件,包括:增加属性、删除属性、修改属性,监听器类需要实现javax.servlet.ServletContextAttributeListener接口。

          2)监听会话

                c).HttpSessionListener:用于监听Session对象的创建和销毁,监听器类需要实现,只要有用户与 server连接,就算连接的是一个空白的jsp页面,会触发session事件,用来统计当前在线用户数最合适        
                d).HttpSessionActivationListener:用于监听Session对象的钝化/活化事件,监听器类需要实现 javax.servlet.http.HttpSessionListener接口或者 javax.servlet.http.HttpSessionActivationListener接口,或者两个都实现。
                e).HttpSessionAttributeListener:用于监听Session对象属性的改变事件,监听器类需要实现javax.servlet.http.HttpSessionAttributeListener接口。


         3)监听客户端请求
             ServletRequestListener :ServletRequestAttributeListener和其他相关类。这些类可以用来管理和控制与ServletRequest动作有关的事件。
             ServletRequestAttributeListener

 

   eg:

   public   class   SessionCount   implements   HttpSessionListener{  
    private   static   int   count=0;  
    public   void   sessionCreated(HttpSessionEvent   se){  
        count++;  
        System.out.println(“session创建:”+new   java.util.Date());  
    }  
    public   void   sessionDestroyed(HttpSessionEvent   se){  
        count--;  
        System.out.println(“session销毁:”+new   java.util.Date());  
    }  
    public   static   int   getCount(){  
        return(count);  
    }  
}  

3. Filter

可以对客户提交的数据进行重新编码,可以从系统中获得配置的信息,可以过滤掉客户的某些不应出现的词汇,可以验证客户是否已经登陆,可以记录系统的日志等

init(FilterConfig config)
void doFilter(ServletRequest srequest, ServletResponse  sresponse, FilterChain chain)
destroy()

 

<filter>
     <filter-name>encoding</filter-name>
     <filter-class>com.jspdev.ch8.EncodingFilter</filter-class>
     <init-param>
     <param-name>encoding</param-name>
        <param-value>gb2312</param-value>
      </init-param>
</filter>
 <filter-mapping>
       <filter-name>encoding</filter-name>
       <url-pattern>/security/*</url-pattern>
</filter-mapping>

 

 

1. 用户与权限管理模块 角色管理: 学生:查看实验室信息、预约设备、提交耗材申请、参与安全考核 教师:管理课题组预约、审批学生耗材申请、查看本课题组使用记录 管理员:设备全生命周期管理、审核预约、耗材采购与分发、安全检查 用户操作: 登录认证:统一身份认证(对接学号 / 工号系统,模拟实现),支持密码重置 信息管理:学生 / 教师维护个人信息(联系方式、所属院系),管理员管理所有用户 权限控制:不同角色仅可见对应功能(如学生不可删除设备信息) 2. 实验室与设备管理模块 实验室信息管理: 基础信息:实验室编号、名称、位置、容纳人数、开放时间、负责人 功能分类:按学科(计算机实验室 / 电子实验室 / 化学实验室)标记,关联可开展实验类型 状态展示:实时显示当前使用人数、设备运行状态(正常 / 故障) 设备管理: 设备档案:名称、型号、规格、购置日期、单价、生产厂家、存放位置、责任人 全生命周期管理: 入库登记:管理员录入新设备信息,生成唯一资产编号 维护记录:记录维修、校准、保养信息(时间、内容、执行人) 报废处理:登记报废原因、时间,更新设备状态为 "已报废" 设备查询:支持按名称、型号、状态多条件检索,显示设备当前可用情况 3. 预约与使用模块 预约管理: 预约规则:学生可预约未来 7 天内的设备 / 实验室,单次最长 4 小时(可设置) 预约流程:选择实验室→选择设备→选择时间段→提交申请(需填写实验目的) 审核机制:普通实验自动通过,高危实验(如化学实验)需教师审核 使用记录: 签到 / 签退:到达实验室后扫码签到,离开时签退,系统自动记录实际使用时长 使用登记:填写实验内容、设备运行情况(正常 / 异常),异常情况需详细描述 违规管理:迟到 15 分钟自动取消预约,多次违规限制预约权限 4. 耗材与安全管理模块 耗材管理: 耗材档案:名称、规格、数量、存放位置、
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值