說一說Servlet的生命週期?java
Servlet有良好的生存期的定義,包括加載和實例化、初始化、處理請求以及服務結束。這個生存期由javax.servlet.Servlet接口的init(),service()和destroy方法表達。web
Servlet被服務器實例化後,容器運行其init方法,請求到達時運行其service方法,service方法自動派遣運行與請求對應的doXXX方法(doGet,doPost)等,當服務器決定將實例銷燬的時候調用其destroy方法。面試
web容器加載servlet,生命週期開始。經過調用servlet的init()方法進行servlet的初始化。經過調用service()方法實現,根據請求的不一樣調用不一樣的do***()方法。結束服務,web容器調用servlet的destroy()方法。數據庫
Servlet API中forward()與redirect()的區別? 設計模式
1.從地址欄顯示來講瀏覽器
forward是服務器請求資源,服務器直接訪問目標地址的URL,把那個URL的響應內容讀取過來,而後把這些內容再發給瀏覽器.瀏覽器根本不知道服務器發送的內容從哪裏來的,因此它的地址欄仍是原來的地址.緩存
redirect是服務端根據邏輯,發送一個狀態碼,告訴瀏覽器從新去請求那個地址.因此地址欄顯示的是新的URL.因此redirect等於客戶端向服務器端發出兩次request,同時也接受兩次response。tomcat
2.從數據共享來講安全
forward:轉發頁面和轉發到的頁面能夠共享request裏面的數據.服務器
redirect:不能共享數據.
redirect不只能夠重定向到當前應用程序的其餘資源,還能夠重定向到同一個站點上的其餘應用程序中的資源,甚至是使用絕對URL重定向到其餘站點的資源.
forward方法只能在同一個Web應用程序內的資源之間轉發請求.forward 是服務器內部的一種操做.
redirect 是服務器通知客戶端,讓客戶端從新發起請求.
因此,你能夠說 redirect 是一種間接的請求, 可是你不能說"一個請求是屬於forward仍是redirect "
3.從運用地方來講
forward:通常用於用戶登錄的時候,根據角色轉發到相應的模塊.
redirect:通常用於用戶註銷登錄時返回主頁面和跳轉到其它的網站等.
4.從效率來講
forward:高.
redirect:低.
request.getAttribute()和 request.getParameter()有何區別?
1,request.getParameter()取得是經過容器的實現來取得經過相似post,get等方式傳入的數據。
request.setAttribute()和getAttribute()只是在web容器內部流轉,僅僅是請求處理階段。
2,getAttribute是返回對象,getParameter返回字符串
3,getAttribute()一貫是和setAttribute()一塊兒使用的,只有先用setAttribute()設置以後,纔可以經過getAttribute()來得到值,它們傳遞的是Object類型的數據。並且必須在同一個request對象中使用纔有效。
而getParameter()是接收表單的get或者post提交過來的參數
jsp靜態包含和動態包含的區別
一、<%@include file="xxx.jsp"%>爲jsp中的編譯指令,其文件的包含是發生在jsp向servlet轉換的時期,而<jsp:include page="xxx.jsp">是jsp中的動做指令,其文件的包含是發生在編譯時期,也就是將java文件編譯爲class文件的時期
二、使用靜態包含只會產生一個class文件,而使用動態包含會產生多個class文件
三、使用靜態包含,包含頁面和被包含頁面的request對象爲同一對象,由於靜態包含只是將被包含的頁面的內容複製到包含的頁面中去;
而動態包含包含頁面和被包含頁面不是同一個頁面,被包含的頁面的request對象能夠取到的參數範圍要相對大些,不只能夠取到傳遞到包含頁面的參數,一樣也能取得在包含頁面向下傳遞的參數
MVC的各個部分都有那些技術來實現?如何實現?
MVC是Model-View-Controller的簡寫。Model表明的是應用的業務邏輯(經過JavaBean,EJB組件實現),View是應用的表示面(由JSP頁面產生),Controller是提供應用的處理過程控制(通常是一個Servlet),經過這種設計模型把應用邏輯,處理過程和顯示邏輯分紅不一樣的組件實現。這些組件能夠進行交互和重用。
jsp有哪些內置對象?做用分別是什麼?
JSP共有如下9個內置的對象:
1,request 用戶端請求,此請求會包含來自GET/POST請求的參數
2,response 網頁傳回用戶端的迴應
3,pageContext 網頁的屬性是在這裏管理
4,session 與請求有關的會話期
5,application servlet 正在執行的內容
6,out 用來傳送回應的輸出
7,config servlet的構架部件
8,page JSP網頁自己
9,exception 針對錯誤網頁,未捕捉的例外
Http中,get和post方法的區別
1,Get是向服務器發索取數據的一種請求,而Post是向服務器提交數據的一種請求
2,Get是獲取信息,而不是修改信息,相似數據庫查詢功能同樣,數據不會被修改
3,Get請求的參數會跟在url後進行傳遞,請求的數據會附在URL以後,以?分割URL和傳輸數據,參數之間以&相連,%XX中的XX爲該符號以16進製表示的ASCII,若是數據是英文字母/數字,原樣發送,若是是空格,轉換爲+,若是是中文/其餘字符,則直接把字符串用BASE64加密。
4,Get傳輸的數據有大小限制,由於GET是經過URL提交數據,那麼GET可提交的數據量就跟URL的長度有直接關係了,不一樣的瀏覽器對URL的長度的限制是不一樣的。
5,GET請求的數據會被瀏覽器緩存起來,用戶名和密碼將明文出如今URL上,其餘人能夠查到歷史瀏覽記錄,數據不太安全。
在服務器端,用Request.QueryString來獲取Get方式提交來的數據
Post請求則做爲http消息的實際內容發送給web服務器,數據放置在HTML Header內提交,Post沒有限制提交的數據。Post比Get安全,當數據是中文或者不敏感的數據,則用get,由於使用get,參數會顯示在地址,對於敏感數據和不是中文字符的數據,則用post。
6,POST表示可能修改變服務器上的資源的請求,在服務器端,用Post方式提交的數據只能用Request.Form來獲取。
什麼是cookie?Session和cookie有什麼區別?
Cookie是會話技術,將用戶的信息保存到瀏覽器的對象.
區別:
(1)cookie數據存放在客戶的瀏覽器上,session數據放在服務器上
(2)cookie不是很安全,別人能夠分析存放在本地的COOKIE並進行COOKIE欺騙,若是主要考慮到安全應當使用session
(3)session會在必定時間內保存在服務器上。當訪問增多,會比較佔用你服務器的性能,若是主要考慮到減輕服務器性能方面,應當使用COOKIE
(4)單個cookie在客戶端的限制是3K,就是說一個站點在客戶端存放的COOKIE不能3K。
結論:
將登錄信息等重要信息存放爲SESSION;其餘信息若是須要保留,能夠放在COOKIE中。
jsp和servlet的區別、共同點、各自應用的範圍?
JSP是Servlet技術的擴展,本質上就是Servlet的簡易方式。JSP編譯後是「類servlet」。
Servlet和JSP最主要的不一樣點在於:Servlet的應用邏輯是在Java文件中,而且徹底從表示層中的HTML裏分離開來。而JSP的狀況是Java和HTML能夠組合成一個擴展名爲.jsp的文件。
JSP側重於視圖,Servlet主要用於控制邏輯。在struts框架中,JSP位於MVC設計模式的視圖層,而Servlet位於控制層.
tomcat容器是如何建立servlet類實例?用到了什麼原理?
當容器啓動時,會讀取在webapps目錄下全部的web應用中的web.xml文件,而後對xml文件進行解析,並讀取servlet註冊信息。而後,將每一個應用中註冊的servlet類都進行加載,並經過反射的方式實例化。(有時候也是在第一次請求時實例化)
在servlet註冊時加上<load-on-startup>1</load-on-startup>若是爲正數,則在一開始就實例化,若是不寫或爲負數,則第一次請求實例化。
以上就是JavaWeb面試題目的詳細內容,但願對你有所幫助。