您的位置:首页 > Web前端 > JavaScript

[Servlet&JSP] 部署描述设置

2015-12-16 16:21 651 查看

Servlet的设置

以下是在web.xml中设置servlet的范例片段:

<servlet>
<servlet-name>Some</servlet-name>
<servlet-class>club.chuxing.SomeServlet</servlet-class>
<load-on-startup>1</load-on-startup>
<init-param>
<param-name>param1</param-name>
<param-value>value1</param-value>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>Some</servlet-name>
<url-pattern>/Some.do</url-pattern>
</servlet-mapping>


当web应用程序启动后,事实上并没有加载所有的Servlet。容器会在请求时,才将对应的Servlet类加载、实例化并进行初始动作,然后再调用service()方法来处理请求。

如果希望在应用程序启动时,就先把Servlet类加载、实例化并做好初始化动作,就可以使用
<load-on-startup>
设置。设置大于0的值,表示在启动应用程序后就要初始化Servlet。数字表示了Servlet的初始化顺序,如果有多个Servlet在设置
<load-on-startup>
时使用了相同的数字,则按其在web.xml中设置的顺序来初始化Servlet。

别尝试在所有的Servlet上都设置
<load-on-startup>
。越多的Servlet在应用程序启动时被初始化,表示应用程序的启动越花时间。只有在那些初始时会加载比较多资源的Servlet上才设置
<load-on-startup>
,像是web框架(Framework)中担任前端控制器(Front Controller)角色的Servlet。

可以在
<url-pattern>
中设置三种模式:

完全符合模式

必须以斜杠(/)作为开头,也就是以web应用程序环境根目录开始,指定完整的URL模式。如:
<url-pattern>/admin/login.do</url-pattern>


目录符合模式

指定某个目录下的所有URL都交由某个Servlet来处理,则可以在目录斜杠(/)后加上星号(
*
)。如
<url-pattern>/guest/*</url-pattern>


扩展名符合模式

指定以某个扩展名为结尾的所有URL请求都交由对应的Servlet处理,则可以使用星号(
*
)作为开头,并加上扩展名。
<url-pattern>*.do</url-pattern>


不能混用目录符合模式与扩展名符合模式,即不能出现如
<url-pattern>/admin/*.do</url-pattern>
这样的URL模式设置。

如果有URL模式设置比对的规则在某些URL请求时有所重叠,则请求时比对的原则依完全模式、目录模式、扩展名模式的顺序来决定,也就是从最严格的模式开始符合。

在设置过滤器时,
<filter-mapping>
上也可以设置
<url-pattern>
标签,设置的原则与
<servlet-mapping>
上的
<url-pattern>
是相同的。在Servlet2.5版本之后,可以直接在同一个
<servlet-mapping>
中设置多个
<url-pattern>
。例如:

<servlet-mapping>
<servlet-name>Some</servlet-name>
<utl-pattern>/something.do</utl-pattern>
<utl-pattern>/someone.do</utl-pattern>
</servlet-mapping>


同样的,也可以在
<filter-mapping>
中设置多个
<url-pattern>
<servlet-name>
。例如:

<filter-mapping>
<filter-name>Some</filter-name>
<utl-pattern>/something.do</utl-pattern>
<utl-pattern>/someone.do</utl-pattern>
<servlet-name>Other</servlet-name>
</filter-mapping>


设置欢迎与错误处理页面

如果用户用户请求某个类似于/BookmarkOnline/user的URL,而user在Servlet的URL模式设置中并不存在,它只是一个目录,若不想用户看到资源不存在之类的错误信息,则可以设置默认的欢迎页面,在用户请求某个目录时可以自动挑选欢迎页面加以显示。

<web-app ...>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
<welcome-file>index.html</welcome-file>
</welcome-file-list>
</web-app>


设置
<welcome-file>
时,注意態用斜杠(/)作为开头(这不是在设置整个应用程序的默认首页)。在请求某个目录名称时,容器会自动依
<welcome-file>
中的文件顺序,看看时候可找到对应的文件,找到的话就显示给用户。

如果在存取应用程序的时候发生了异常或者错误,而没有在Servlet/JSP中处理这个异常或错误,则最后会由容器加以处理,一般容器就是直接显示异常信息与堆栈跟踪信息。如果希望容器发现这类异常或者错误时,可以自动转发到某个URL,则可以在web.xml中使用
<error-page>
进行设置。

例如,若想要在容器收到某个类型的异常对象时进行转发,则可以做如下设置:

<web-app ...>
<error-page>
<exception-type>java.lang.NullPointerException</exception-type>
<location>/report.view</location>
</error-page>
</web-app>


如果想要基于HTTP的错误代码转发到处理页面,则要搭配
<error-code>
来设置。例如:

<web-app ...>
<error-page>
<error-code>404</error-code>
<location>/404.jsp</location>
</error-page>
</web-app>


这个设置在自行使用HttpServletResponse的sendError()送出错误状态码时也有作用,因为sendError()只是告知容器,以容器的默认方式或web.xml中的设置来产生错误状态码的信息。

MIME与扩展名的对应

当自动响应串流给浏览器时,为了让浏览器知道如何处理收到的串流对象,必须告知MIME类型。若应用程序中使用到了MIME类型,可以在web.xml中设置扩展名与MIMIE类型对应。例如:

<web-app ...>
<mime-mapping>
<extension>pdf</extension>
<mime-type>application/pdf</mime-type>
</mime-mapping>
</web-app>


<extension>
设置文件的扩展名,而
<mime-type>
设置对应的MIME类型名称。如果想要知道某个文件的MIME类型名称,则可使用ServletContext的getMimeType()方法,这个方法让你指定文件名称,然后根据web.xml总设置的对应扩展名,取得MIME类型的名称。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: