問題集錦:Servlets/JSP開發技術問答
2024-09-05 00:20:09
供稿:網友
為什么genericservlet在init(servletconfig config)基礎上增加了一個init()方法?
init()方法被genericservlet.init(servletconfig config)方法調用。
init()方法方便了開發人員定制servlet的初始化,而無須去維護servletconfig對象的存儲工作。
重寫genericservlet.init(servletconfig config)必須要顯示的調用super.init(config)方法。
servletcontext.getcontect(java.lang.string uripath)的作用是什么?
返回同一server中指定的path對應的servletcontext對象,通過該對象可以實現與server中的其他context打交道。
uripath必須是以"/"開始(該路徑的含義是相對于整個servlet文檔的根路徑,而不是當前servletcontext的根路徑)。
servlet生命周期是什么?
一般的servlet(genericservlet,即與協議無關的servlet)的生命周期:init() --> genericservlet.service(servletrequest req, servletresponse res) --> destroy.
httpservlet的生命周期: init() --> genericservlet.service(servletrequest req, servletresponse res)---> service(httpservletrequest req, httpservletresponse resp) --> doxxxx()-->destroy.
有沒有必要重寫genericservlet.service()方法?
對于httpservlet來說沒有必要。只需要重寫它的doxxxx()方法就可以了。httpservlet中service()方法會自動的根據用戶請求類型把請求轉發給相應的doxxxx()方法(例如doget()方法)。
servletrequest.getreader()和servletrequest.getinputstream()如何使用?
注意兩個方法不能同時使用。
servletrequest.getrealpath(string path)方法已經不推薦使用。
請使用servletcontext.getrealpath(string path)方法。
servletresponse缺省的字符集(charset)是什么?
servletresponse缺省的字符集(charset)是iso-8859-1,可以通過setcontenttype(java.lang.string)方法改變新的字符集。
例如:setcontenttype("text/html; charset=shift_jis").
關于字符集信息,可以瀏覽rfc 2045
httpservletrequest.getrequesturi()和httpservletrequest.getrequesturl()區別是什么?
request.getrequesturi() 返回值類似:/xuejava/requestdemo.jsp
request.getrequesturl() 返回值類似:http://localhost:8080/xuejava/requestdemo.jsp
httpservletrequest.encodeurl()和httpservletrequest.encoderedirecturl(()區別是什么?為什么要有兩個不同的方法呢?
當用url-rewriting方式來管理session的時候,需要用到以上的兩個方法。
兩個方法的不同點是:兩個方法確定是否需要包含session id的邏輯不同。
在調用httpservletresponse.sendredirect前,應該先調用encoderedirecturl()方法,否則可能會丟失sesssion信息。 ...
如何使你的servlet或者jsp實現single thread model?
對于servlet實現javax.single.singlethreadmodel接口。
對于jsp,在page directive中寫如下的語句<%@ page isthreadsafe="false" %>
jsp tag 和 jsp xml-based tag
...
如何把某一個jsp page定義成為error page?為什么要這樣做?
實現方法: <%@ page iserrorpage="true" %>
為什么? 因為需要獲取exception 對象(缺省情況下,在jsp page中是不能直接使用“隱含對象” exception的)。
jsp page的執行順序是如何的?
jsp page的執行順序如下:
jsp page translation. jsp page --> servlet source code.
jsp page compilation. servlet source code --> servlet class.
load class(first time or the server restarted)
create instance(可能會很多次,如果jsp page中聲明了<%@ page isthreadsafe="false" %>)
call jspinit method(一般的jsp page都沒有重寫這個方法,重寫需要在聲明語句段中)。
call _jspservice method(類似與一般httpservlet的doget和dopost方法,但是可以同時用來處理post和getq請求)。
call jspdestroy method(server在卸載servet的時候,例如當servlet很久沒有使用的情況)。
jsp page中有哪些隱含對象(implicity object)?各自的類型和作用是什么?
request --
reponse --
session --
application --
out --
page --
pagecontext --
exception -- 只有在當前jsp page為error page的時候才有效。
config --
<jsp:include page="/foo/foo.jsp" %> 和 <@ include file="/foo/foo.jsp" %>的區別是什么?
<jsp:include ... -- request time.
<@ include ... -- page translation time.
servlets/jsp container(engine)有幾種運行方式?
standalone
tomcat standalone mode
in-process
tomcat running inside apache web server.
out-of-process
apache + mod_jk + tomcat
servlet,servlet開發人員,servlet api, servlet container的關系是什么?
servlet,servlet開發人員 --->servlet api --> servlet container
the parts of an http message
message part description
the initial line: specifies the purpose of the request or response message
例子:get /reports/sales/index.html http/1.0
the header section:specifies the meta-information, such as size, type, and encoding,
about the content of the message
a blank line:
an optional message body: the main content of the request or response message
下面是一個response的例子:
http/1.0 200 ok
date: tue, 01 dec 2001 23:59:59 gmt
content-type: text/html
content-length: 52
<html>
<body>
<h1>hello, john!</h1>
</body>
</html>
http規范中定義了哪些方法?各自有什么用途?
get
head
post
從 http 1.1規范開始,增加了以下的方法:
put
options
trace
delete
connect
servetrequest中為什么要定義:getcontenttype(),getcontentlength()方法。
根據http協議規范,request 和 response一樣也有這些必不可少的內容!
所以需要首先了解 http message的概念和其內容的格式,這些東西對于request和reponse是一樣的。
對于get方式發送的請求,其內容類型為:null
對于post方式發送的請求,其內容類型為:application/x-www-form-urlencoded
post方式發送請求的內容類似于:username=xuejava.
requestdispatcher.forward()和httpservletresponse.sendredirect()的區別是什么?
requestdispatcher.forward()是在服務器端運行;httpservletresponse.sendredirect()是通過向客戶瀏覽器發送命令來完成。
所以requestdispatcher.forward()對于瀏覽器來說是“透明的”;而httpservletresponse.sendredirect()則不是。
另外,還要注意requestdispatcher.forward()在調用的時候response不能已經commit了(response.iscommitted())。
servletcontext.getrequestdispatcher(string url)和servletrequest.getrequestdispatcher(string url)的區別是什么?為什么?
servletcontext.getrequestdispatcher(string url)中的url只能使用絕對路徑;而servletrequest.getrequestdispatcher(string url)中的url可以使用相對路徑。
因為servletrequest具有相對路徑的概念;而servletcontext對象無次概念。
如何把請求轉移到另外一個web app中的某個地址?
servletcontext.getrequestdispatcher(string url)和servletrequest.getrequestdispatcher(string url)只能把請求轉移到同一個web app中的地址。
如果需要把請求轉移到另外一個web app中的某個地址,可以按下面的做法:
1. 獲得另外一個web app的servletconext對象(currentservletcontext.getcontext(uripath)).
2. 調用servletcontext.getrequestdispatcher(string url)方法。