Base-Jsp-14-servlet介绍

本文介绍了servlet与JSP结合使用可分离应用程序逻辑和外观,阐述了servlet API、生命周期、编译安装等内容。还讲述了将servlet作为控制器的要求,以及struts servlet的工作机制,包括请求处理、映射规则等,同时提及了servlet重定向和转发API等。

Base-Jsp-14-servlet介绍

v servlet

Ø servletJSP结合使用,可以把应用程序的逻辑和外观呈现部分清楚的分开。

Ø servlet API由两个程序包组成

       ª javax.servlet

       ª javax.servlet.http

Ø servlet的实质是实现了借口javax.servlet.Servlet的类

Ø web容器管理servlet生命周期的所有方面,它根据需要创建servlet类的实例,将请求传

       递给实例进行处理,最终删除实例。

Ø 容器会在servlet生命周期的适当时间调用下列方法

       ª public void init() throws ServletException

              在发送第一个请求之前调用一次。

       ª public void doGet(HttpServletRequest request, HttpServletResponse response)

throws ServletException,IOException

反复调用以使servlet处理GET请求。

       ª public void doPost(HttpServletRequest request, HttpServletResponse response)

throws ServletException,IOException

反复调用以使servlet处理POST请求。

       ª public void destroy()

              servlet停止服务前调用一次。

ª 容器只为每个servlet创建一个实例,这意味着servlet必须是线程安全的,即,能够同时

       处理多个请求,每个处理都通过servlet代码作为单独的线程来处理。

Ø 编译和安装servlet

       ª 要编译servlet,首先必须确保servlet.jar文件在CLASSPATH

       ª 编译完后,将类文件放在WEB-INF/classes目录中(容器自动在WEB-INF/classes

              录中查找类);也可以用程序包形式出现,此时目录结构为

              WEB-INF/classes/com/mycompany ;还可以将类打包到一个JAR文件中,拷贝到

              WEB-INF/lib目录中。

       ª 测试

              http://localhost:8080/servlet/com.mycompany.HelloWorld

Ø servlet作为所有应用程序请求的公共入口点时,可以获得对应用程序页面流的整体控

       制。

Ø 当使用servlet作为控制器时,必须处理下列基本要求

       ª 所有请求处理都必须传递到单独的控制器servlet中。

       ª servlet必须能够区分请求,以便进行不同类型的处理。

       ª 可以使用现成的struts servlet

ª struts servlet根据请求URI中的一部分来断定请求的类型,查找对应的行为类(使用

       配制信息),并调用execute()方法。

ª execute()方法不显示应答,只关心商务逻辑。该方法返回一个struts ActionForward

       例,其中包含应答应该调用以显示应答的JSP页面的相关信息。该页面由逻辑名称

       进行标示,并影射到配置文件中的实际页面逻辑上。因此可以通过重新配置,而不

       是改变代码,从而至少在某种程度上控制页面流。

Ø 使用servlet的最佳解决方案是定义servlet的映射规则

       而不是使用:/myapp/servlet开头的调用

       或是使用<form action=”/ora/servlet/controller/someAction”>

       以上方式的调用servlet将会导致安全问题和程序部署的问题。

Ø struts

       ª 配置描述符中映射规则确保了所有请求都可以到达struts servlet

       ª struts-config.xml中的行为映射提供了区分不同请求时所需的信息。

       ª 最后则有实现一些老式的编码并实现行为类。

       ª struts Action中的execute()方法执行请求处理,execute()方法返回后,struts servlet

              用指定的资源,一般情况下是JSP页面,内容是针对该请求的应答。

       ª ActionMapping类封装了所有可以在Struts配置文件中定义的映射信息。里面完成逻

              辑页面名称和实际页面名称之间的映射。可以同<forward>元素设置这些映射

              可以用如下方法取得ActionForward的实例:

              ActionForward nextPage=(ActionMapping)mapping.findForward(“main”);

              nextPage = new ActionForward(next,true);

              ActionForward构造函数中的第2个参数:

              True:使用重定向

              False:使用转发

       ª <global-forwards>定义可以用于所有行为的映射,而<action>中的<forward>则定义了

              仅可用于该行为的映射。

       ª struts servlet收到一个请求时,首先使用processPath()方法来提取映射到行为类的

              部分,然后查处匹配行为类的实例,并调用execute()方法。

       ª execute()方法返回的ActionForward实例由prcessActionForward()方法处理。该方法实

              现了如何转发控制。

       ª ActionForward包含了struts将控制传递给下一个组件时需要的所有信息。

       ª servlet重定向APIresponse.sendRedirect(response.encodeRedirectURL(path));

       ª servlet转发API: RequestDispatcher rd = getSevletContext().getRequestDispatcher(path);

                                   rd.forward(request,response);

              此行为与<jsp:forward>行为相同,永久的奖控制传递个目标。

              ª 它还包括另一个include()方法:该方法相同与<jsp:include>行为:临时将控制传

                     递给目标,生产一部分应答,但是不设置应答首部。

       ª encodeRedirectURL(path) API:如果浏览器不支持cookie,该方法将在URL中插入会

              ID

Ø所有请求处理都必须传递到单独的控制器servlet

web应用程序的配置描述符中可以定义3种映射规则:

       ª 完全匹配:是URI匹配与该URI完全相同的模式路径,

              例:请求/contextPath/exactMatch与模式/exactMatch向匹配

       ª 路径前缀匹配规则:使URI匹配与该URI一样具有最多路径元素的模式路径

              例:/contextPath/pathPrefix//contextPath/pathPrefix/pathInfo都与模式

                     /pathPrefix/*匹配

       ª 扩展名匹配规则:使URI匹配与该URI具有相同扩展名的扩展模式

              例:/contextPath/name.extension/contextPath/aPath/name.extension都与*.extension

                     匹配

       ª web容器以“完全匹配”、“路径前缀规则”、“扩展名规则”的顺序查找匹配项。

       ª “完全匹配”规则很少使用,struts servlet只使用“路径前缀匹配规则”和“扩展名

              匹配规则”

       例:

              <wep-app>

        ... ...

        <servlet>

            <servlet-name>action</servlet-name>

            <servlet-calss>

                org.apache.struts.action.ActionServlet

            </servlet-calss>  

        </servlet>

        <servlet-mapping>

            <servlet-name>action</servlet-name>

            <url-patterb>*.do</url-pattern>

        </servlet-mapping>

        ... ...

</wep-app>

此时匹配<form action=someAction.do>

ª 也可以使用路径前缀匹配规则

        <servlet-mapping>

            <servlet-name>action</servlet-name>

            <url-patterb>/ch18/do/*</url-pattern>

        </servlet-mapping>

此时匹配

/ch18/do

ª 在这里容器会为所有以.do结尾的请求调用struts servlet

Ø servlet必须能够区分请求,以便进行不同类型的处理

       ª Struts sevlet使用配置文件(sruts-config.xml),将具体请求映射到具体的行为类上来

              完成该任务。

       ª /ora/ch18/protected/do/storeMsg

              使用路径前缀匹配规则,经过struts processPath API处理后为

              /storeMsg

              这样处理会有安全问题,所以应该坚持使用扩展名匹配规则

       ª /ora/ch18/protected/storeMsg.do

              使用扩展名匹配规则,经过struts processPath API处理后为

              /ch18/protected/storeMsg

       ª cookiessetMaxAgemaxAge,如果maxAge-=0则告诉浏览器删除cookie

       ª servlet规范将保存throwable对象的请求属性命名为

              Javax.servlet.error.exception

       ª JSP规范将保存throwable对象的请求属性命名为

              Javax.servlet.jsp.jspException

在Spring MVC中,Servlet配置文件通常指的是`web.xml`和Spring MVC的配置文件(如`spring-mvc.xml`)。以下是配置方法和示例: ### `web.xml`配置 在`web.xml`中,需要配置`DispatcherServlet`,它是Spring MVC的核心Servlet,负责接收所有的HTTP请求并将其分发给相应的处理器。 ```xml <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_4_0.xsd" version="4.0"> <!-- 配置DispatcherServlet --> <servlet> <servlet-name>spring-mvc</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <!-- 指定Spring MVC配置文件的位置 --> <init-param> <param-name>contextConfigLocation</param-name> <param-value>/WEB-INF/spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!-- 将所有请求映射到DispatcherServlet --> <servlet-mapping> <servlet-name>spring-mvc</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> </web-app> ``` ### Spring MVC配置文件(`spring-mvc.xml`)配置 在Spring MVC配置文件中,需要配置一些必要的组件,如视图解析器、处理器映射器等。 ```xml <beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context" xmlns:mvc="http://www.springframework.org/schema/mvc" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc/spring-mvc.xsd"> <!-- 开启Spring MVC注解支持 --> <mvc:annotation-driven/> <!-- 扫描控制器所在的包 --> <context:component-scan base-package="com.example.controller"/> <!-- 配置视图解析器 --> <bean class="org.springframework.web.servlet.view.InternalResourceViewResolver"> <property name="prefix" value="/WEB-INF/views/"/> <property name="suffix" value=".jsp"/> </bean> </beans> ``` ### 控制器示例 以下是一个简单的控制器示例: ```java package com.example.controller; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; @Controller public class HelloController { @RequestMapping("/hello") @ResponseBody public String hello() { return "Hello, Spring MVC!"; } } ``` ### 总结 通过以上配置,`web.xml`将所有请求映射到`DispatcherServlet`,`DispatcherServlet`根据`contextConfigLocation`指定的配置文件加载Spring MVC的配置,配置文件中开启了注解支持、扫描控制器所在的包并配置了视图解析器,最后通过控制器处理请求并返回响应。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值