第一篇:servlet生命周期
Servlet生命周期
Servlet的生命周期是由servlet容器來控制的。Servlet周期分為三個階段:(一)初始化階段;(二)運行階段;(三)銷毀階段。
分階段講解:
(一)servlet初始化階段,調(diào)用init()方法。
在下列時刻servlet容器載入servlet:
1、servlet容器啟動時自動載入某些servlet,實現(xiàn)它只需要在web.XML
文件中的
2、在servlet容器啟動后,客戶首次向servlet發(fā)送請求。
3、Servlet類文件被更新后,重新載入servlet。
Servlet被載入后,servlet容器創(chuàng)建一個servlet實例并且調(diào)用servlet的init()方法進(jìn)行初始化。在servlet的整個生命周期內(nèi),init()方法只被調(diào)用一次。
(二)servlet運行階段,調(diào)用service()方法。
對于用戶到達(dá)servlet的請求,servlet容器會創(chuàng)建特定于這個請求的servletrequest對象和servletresponse對象,然后調(diào)用servlet的service方法。Service方法從servletrequest對象獲得客戶請求信息,處理該請求,并通過servletresponse對象向客戶返回響應(yīng)信息。
Servlet接口和GenericServlet是不特定于任何協(xié)議的,而HttpServlet是特定于HTTP協(xié)議的類,所以HttpServlet中實現(xiàn)了service()方法,并將請求ServletRequest,ServletResponse強(qiáng)轉(zhuǎn)為HttpRequest和HttpResponse。
代碼的最后調(diào)用了HTTPServlet自己的service(request,response)方法,然后根據(jù)請求去調(diào)用對應(yīng)的doXXX方法,因為HttpServlet中的doXXX方法都是返回錯誤信息。
(三)servlet銷毀(終止)階段,調(diào)用destroy()方法。
當(dāng)web應(yīng)用被終止,或servlet容器終止運行,或servlet容器重新載入servlet新實例時,servlet會先調(diào)用servlet的destroy()方法,在destroy()方法中可以釋放掉servlet所占用的內(nèi)存資源。
第二篇:servlet小結(jié)
Tomcat服務(wù)器 http工作原理:
http超文本傳輸協(xié)議
HTTP是一個客戶端和服務(wù)器端請求和應(yīng)答的標(biāo)準(zhǔn)(TCP)
http請求響應(yīng)步驟:
1客戶端鏈接到web服務(wù)器 2發(fā)送http請求
3服務(wù)器接收請求并返回http響應(yīng) 4釋放鏈接tcp 5客戶端瀏覽器解析html內(nèi)容 Web應(yīng)用程序 項目打包發(fā)布
1清緩存,重新生成.Class文件 2生成war包
3將war文件復(fù)制tomcat路徑下的webapps 文件下 4啟動項目
5通過瀏覽器訪問
在eclipse中配置tomcat并發(fā)布項目
Windows-prefrence-servers-runtime envirment Add
tomcat 安裝目錄 Server 安裝 運行
給servlet類 在Web.xml中配置servlet訪問路徑 Servlet生命周期
1在被訪問時進(jìn)行初始化 2請求到達(dá)時處理 3在應(yīng)用結(jié)束時注銷 Get與post請求的區(qū)別
1get請求不安全傳輸時,數(shù)據(jù)存放在url中,post傳輸對用戶來說,是不可見的 2get請求傳輸數(shù)據(jù)較小,受限url長度的限制,post可以傳輸大量的數(shù)據(jù),Httpservletrequest的getparameter 方法 獲取地址欄參數(shù),或者表單字段值 Servletcontext的getinitparameter Context-param設(shè)置全局變量
使用注解方式設(shè)置servlet訪問路徑 Loadonstartup設(shè)置初始化 轉(zhuǎn)發(fā)和重定向 區(qū)別:
轉(zhuǎn)發(fā)在服務(wù)器端完成,重定向在客戶端完成 轉(zhuǎn)發(fā)速度快,重定向速度慢
轉(zhuǎn)發(fā)是同一次請求,重定向是兩次請求 轉(zhuǎn)發(fā)地址欄沒有變化,重定向地址欄有變化 轉(zhuǎn)發(fā)不可以訪問其他外部資源,重定向可以
請求轉(zhuǎn)發(fā)可以訪問web-inf保護(hù)目錄下的頁面,重定向不能訪問到 轉(zhuǎn)發(fā)可以攜帶參數(shù),重定向不能攜帶參數(shù)
Web-inf為保護(hù)目錄,保護(hù)目錄下的文件不能直接訪問,如果要訪問保護(hù)目錄下的文件,只能通過轉(zhuǎn)發(fā)的方式訪問,重定向不能訪問 Jsp表達(dá)式<%= 表達(dá)式%> Jsp腳本<%腳本%> Jsp聲明<%!%> Jsp注釋<%--%>
第三篇:Servlet和JSP經(jīng)驗總結(jié)
Servlet和JSP經(jīng)驗總結(jié)
這里介紹Servlet和JSP經(jīng)驗總結(jié),包括在servlet的init()方法中緩存數(shù)據(jù)、禁止Servlet和JSP自動重載、將頁面輸出進(jìn)行壓縮和正確地確定javabean的生命周期等七種實用的方法。
在servlet的init()方法中緩存數(shù)據(jù)
當(dāng)應(yīng)用服務(wù)器初始化Servlet和JSP實例之后,為客戶端請求提供服務(wù)之前,它會調(diào)用這個servlet的init()方法。在一個servlet的生命周期中,init()方法只會被調(diào)用一次。通過在init()方法中緩存一些靜態(tài)的數(shù)據(jù)或完成一些只需要執(zhí)行一次的、耗時的操作,就可大大地提高系統(tǒng)性能。
例如,通過在init()方法中建立一個JDBC連接池是一個最佳例子,假設(shè)我們是用jdbc2.0的DataSource接口來取得數(shù)據(jù)庫連接,在通常的情況下,我們需要通過JNDI來取得具體的數(shù)據(jù)源。我們可以想象在一個具體的應(yīng)用中,如果每次SQL請求都要執(zhí)行一次JNDI查詢的話,那系統(tǒng)性能將會急劇下降。解決方法是如下代碼,它通過緩存DataSource,使得下一次SQL調(diào)用時仍然可以繼續(xù)利用它
1.2.3.publicclassControllerServletextendsHttpServlet{privatejavax.sql.DataSourcetestDS=null;publicvoidinit(ServletConfigconfig)throwsServletExcep
tion{
4.super.init(config);
5.Contextctx=null;
6.try{ctx=newInitialContext();
7.testDS=(javax.sql.DataSource)ctx.lookup(“jdbc/testDS”);
8.}
9.catch(NamingExceptionne){
10.ne.printStackTrace();
11.}
12.catch(Exceptione){
13.e.printStackTrace();
14.}
15.}
16.publicjavax.sql.DataSourcegetTestDS(){
17.returntestDS;
18.}
19.......20.}
禁止Servlet和JSP自動重載(auto-reloading)
Servlet和JSP提供了一個實用的技術(shù),即自動重載技術(shù),它為開發(fā)人員提供了一個好的開發(fā)環(huán)境,當(dāng)你改變servlet和JSP頁面后而不必重啟應(yīng)用服務(wù)器。然而,這種技術(shù)在產(chǎn)品運行階段對系統(tǒng)的資源是一個極大的損耗,因為它會給JSP引擎的類裝載器(classloader)帶來極大的負(fù)擔(dān)。因此關(guān)閉自動重載功能對系統(tǒng)性能的提升是一個極大的幫助。
不要濫用HttpSession
在很多應(yīng)用中,我們的程序需要保持客戶端的狀態(tài),以便頁面之間可以相互聯(lián)系。但不幸的是由于HTTP具有天生無狀態(tài)性,從而無法保存客戶端的狀態(tài)。因此一般的應(yīng)用服務(wù)器都提供了session來保存客戶的狀態(tài)。在JSP應(yīng)用服務(wù)器中,是通過HttpSession對像來實現(xiàn)session的功能的,但在方便的同時,它也給系統(tǒng)帶來了不小的負(fù)擔(dān)。因為每當(dāng)你獲得或更新session時,系統(tǒng)者要對它進(jìn)行費時的序列化操作。你可以通過對 HttpSession的以下幾種處理方式來提升系統(tǒng)的性能:
如果沒有必要,就應(yīng)該關(guān)閉JSP頁面中對HttpSession的缺省設(shè)置:如果你沒有明確指定的話,每個JSP頁面都會缺省地創(chuàng)建一個HttpSession。如果你的JSP中不需要使用session的話,那可以通過如下的JSP頁面指示符來禁止它:
21.<%@ page session=“false”%>
不要在HttpSession中存放大的數(shù)據(jù)對像:如果你在HttpSession中存放大的數(shù)據(jù)對像的話,每當(dāng)對它進(jìn)行讀寫時,應(yīng)用服務(wù)器都將對其進(jìn)行序列化,從而增加了系統(tǒng)的額外負(fù)擔(dān)。你在HttpSession中存放的數(shù)據(jù)對像越大,那系統(tǒng)的性能就下降得越快。
當(dāng)你不需要HttpSession時,盡快地釋放它:當(dāng)你不再需要session時,你可以通過調(diào)用HttpSession.invalidate()方法來釋放它。
盡量將session的超時時間設(shè)得短一點:在JSP應(yīng)用服務(wù)器中,有一個缺省的session的超時時間。當(dāng)客戶在這個時間之后沒有進(jìn)行任何操作的話,系統(tǒng)會將相關(guān)的session自動從內(nèi)存中釋放。超時時間設(shè)得越大,系統(tǒng)的性能就會越低,因此最好的方法就是盡量使得它的值保持在一個較低的水平。
將頁面輸出進(jìn)行壓縮
壓縮是解決數(shù)據(jù)冗余的一個好的方法,特別是在網(wǎng)絡(luò)帶寬不夠發(fā)達(dá)的今天。有的瀏覽器支持gzip(GNU zip)進(jìn)行來對HTML文件進(jìn)行壓縮,這種方法可以戲劇性地減少HTML文件的下載時間。因此,如果你將servlet或JSP頁面生成的HTML頁面進(jìn)行壓縮的話,那用戶就會覺得頁面瀏覽速度會非常快。但不幸的是,不是所有的瀏覽器都支持gzip壓縮,但你可以通過在你的程序中檢查客戶的瀏覽器是否支持它。下面就是關(guān)于這種方法實現(xiàn)的一個代碼片段:
22.publicvoiddoGet(HttpServletRequestrequest,HttpServlet
Responseresponse)
throwsIOException,ServletException{
23.OutputStreamout=null
24.Stringencoding=request.getHeader(“Accept-Encoding”);
25.if(encoding!=null&&encoding.indexOf(“gzip”)!=-1){
26.request.setHeader(“Content-Encoding”,“gzip”);
27.out=newGZIPOutputStream(request.getOutputStream());
28.}
29.elseif(encoding!=null&&encoding.indexOf(“compress”)!=
-1){
30.request.setHeader(“Content-Encoding”,“compress”);
31.32.33.34.35.36.37.out=newZIPOutputStream(request.getOutputStream());}else{out=request.getOutputStream();}......}
使用線程池
應(yīng)用服務(wù)器缺省地為每個不同的客戶端請求創(chuàng)建一個線程進(jìn)行處理,并為它們分派service()方法,當(dāng)service()方法調(diào)用完成后,與之相應(yīng)的線程也隨之撤消。由于創(chuàng)建和撤消線程會耗費一定的系統(tǒng)資源,這種缺省模式降低了系統(tǒng)的性能。但所幸的是我們可以通過創(chuàng)建一個線程池來改變這種狀況。另外,我們還要為這個線程池設(shè)置一個最小線程數(shù)和一個最大線程數(shù)。在應(yīng)用服務(wù)器啟動時,它會創(chuàng)建數(shù)量等于最小線程數(shù)的一個線程池,當(dāng)客戶有請求時,相應(yīng)地從池從取出一個線程來進(jìn)行處理,當(dāng)處理完成后,再將線程重新放入到池中。如果池中的線程不夠地話,系統(tǒng)會自動地增加池中線程的數(shù)量,但總量不能超過最大線程數(shù)。通過使用線程池,當(dāng)客戶端請求急劇增加時,系統(tǒng)的負(fù)載就會呈現(xiàn)的平滑的上升曲線,從而提高的系統(tǒng)的可伸縮性。
選擇正確的頁面包含機(jī)制
在JSP中有兩種方法可以用來包含另一個頁面
1、使用include指示符(< %@ includee file=”test.jsp” %>)。
2、使用jsp指示符(< jsp:includee
page=”test.jsp” flush=”true”/>)。在實際中我發(fā)現(xiàn),如果使用第一種方法的話,可以使得系統(tǒng)性能更高。
正確地確定javabean的生命周期
Servlet和JSP一個強(qiáng)大的地方就是對javabean的支持。通過在JSP頁面中使用<jsp:useBean>標(biāo)簽,可以將javabean直接插入到一個JSP頁面中。它的使用方法如下:
38.<
jsp:useBean id=“name” scope=“page|request|session|application”
class= “package.className” type=“typeName”>
39.</jsp:useBean>
其中scope屬性指出了這個bean的生命周期。缺省的生命周期為page。如果你沒有正確地選擇bean的生命周期的話,它將影響系統(tǒng)的性能。
舉例來說,如果你只想在一次請求中使用某個bean,但你卻將這個bean的生命周期設(shè)置成了session,那當(dāng)這次請求結(jié)束后,這個bean將仍然保留在內(nèi)存中,除非session超時或用戶關(guān)閉瀏覽器。這樣會耗費一定的內(nèi)存,并無謂的增加了JVM垃圾收集器的工作量。因此為bean設(shè)置正確的生命周期,并在bean的使命結(jié)束后盡快地清理它們,會使用系統(tǒng)性能有一個提高。
需要注意:
1.在字符串連接操作中盡量不使用“+”操作符:在java編程中,我們常常使用“+”操作符來將幾個字符串連接起來,但你或許從來沒有想到過它居然會對系統(tǒng)性能造成影響吧?由于字符串是常量,因此JVM會產(chǎn)生一些臨時的對像。你使用的“+”越多,生成的臨時對像就越多,這樣也會給系統(tǒng)性能帶來一些影響。解決的方法是用StringBuffer對像來代替“+”操作符。
2.避免使用System.out.println()方法:由于System.out.println()是一種同步調(diào)用,即在調(diào)用它時,磁盤I/O操作必須等待它的完成,因此我們要盡量避免對它的調(diào)用。但我們在調(diào)試程序時它又是一個必不可少的方便工具,為了解決這個矛盾,我建議你最好使用Log4j工具,它既可以方便調(diào)試,而不會產(chǎn)生System.out.println()這樣的方法。
3.ServletOutputStream 與 PrintWriter的權(quán)衡:使用PrintWriter可能會帶來一些小的開銷,因為它將所有的原始輸出都轉(zhuǎn)換為字符流來輸出,因此如果使用它來作為頁面輸出的話,系統(tǒng)要負(fù)擔(dān)一個轉(zhuǎn)換過程。而使用ServletOutputStream作為頁面輸出的話就不存在一個問題,但它是以二進(jìn)制進(jìn)行輸出的。
第四篇:生命周期分析法
2.生命周期分析(LCA)
產(chǎn)品生命周期分析法是對產(chǎn)品進(jìn)行“從搖籃到墳?zāi)埂钡姆治?,使組織全面了解自己的產(chǎn)品,包括從原材料生產(chǎn)到最終廢棄處置的全部生命過程中可能涉及的環(huán)境問題。
產(chǎn)品的生命周期通常分為五個階段,即:
1、原材料的生產(chǎn)與加工
2、產(chǎn)品的生產(chǎn)與加工
3、產(chǎn)品的運輸銷售
4、產(chǎn)品的使用與回用
5、產(chǎn)品的廢置與再生。
針對五個階段的環(huán)境因素識別原理,產(chǎn)品生命周期分析的一種簡單做法是運用產(chǎn)品生命周期矩陣。矩陣縱欄為產(chǎn)品的各個生命階段,其橫欄是可能存在的環(huán)境影響。表格內(nèi)填寫每一階段的環(huán)境因素。具體矩陣形式如表1。
為了對產(chǎn)品實現(xiàn)過程環(huán)境因素的充分識別,表1縱欄產(chǎn)品生命階段中各階段可根據(jù)組織產(chǎn)品實際情況再進(jìn)一步細(xì)化。以達(dá)到識別詳細(xì),環(huán)境因素描述明確、具體。
輸入 資源(原材料)能源(水、電、氣、煤、汽等)
下一工序(半成品或產(chǎn)品)
圖1。過程分析法示意圖
資源 產(chǎn)品
能源 副產(chǎn)品
水 社會服務(wù)
電力 水污染物
煤 大氣污染物
土地 固體廢物
人力 噪聲
其他產(chǎn)品 廢熱
第五篇:配置Struts2后如何使用servlet
配置Struts2后如何使用servlet 1.問題的提出
如果web.xml中struts2和servlet的配置如下:
.substring(target.lastIndexOf(“/”)+ 1);
if(this.includes.contains(target)){
RequestDispatcher rdsp = request.getRequestDispatcher(target);
rdsp.forward(req,resp);
} else
chain.doFilter(req, resp);
}
@Override
public void init(FilterConfig config)throws ServletException {
this.includes.addAll(Arrays.asList(config.getInitParameter(“includeServlets”).split(“,”)));
}
}
2.在web.xml中做適當(dāng)配置,在struts2的配置前加上下面的代碼:
includeServlets
ValidateEmail
其中,
中為web.xml中配置的要過濾的servlet名,多個之間用“,”逗號隔開。