一、說一說Servlet的生命週期?
(更多相關面試題推薦:java面試題目)
Servlet有良好的生存期的定義,包括載入和實例化、初始化、處理請求以及服務結束。這個生存期由javax.servlet.Servlet介面的init(),service()和destroy方法表達。
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。
2、從資料共享來說
forward:轉送頁面和轉送到的頁面可以共用request裡面的資料
redirect:不能共用資料
redirect不僅可以重定向到目前應用程式的其他資源,還可以重定向到同一個網站上的其他應用程式中的資源,甚至是使用絕對URL重定向到其他網站的資源
forward方法只能在同一個網路應用程式內的資源之間轉送請求.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提交過來的參數
(影片教學推薦:java課程)
四、jsp靜態包含和動態包含的區別
1、<%@include file="xxx.jsp"%>為jsp中的編譯指令,其檔案的包含是發生在jsp向servlet轉換的時期,而
2、使用靜態包含只會產生一個class文件,而使用動態包含會產生多個class文件
3、使用靜態包含,包含頁面和被包含頁面的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 與請求相關的會話期
# 、application servlet 正在執行的內容
6、out 用來傳送回應的輸出
7、config servlet的架構元件
8、page JSP網頁本身
9、exception 針對錯誤網頁,未捕捉的例外
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是會話技術,將使用者的資訊儲存到瀏覽器的物件.
(相關推薦:
java入門)
區別:
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註冊時加上以上是java高頻率基礎面試題-(四)的詳細內容。更多資訊請關注PHP中文網其他相關文章!