1. 程式人生 > >基於javaWeb階段下的Servlet總結

基於javaWeb階段下的Servlet總結

tro ddc quest 在服務器 接收數據 根據 數據 ren 都是

1.Servlet概述
Servlet是用Java語言編寫的服務端的程序,采用request--response模式提供Web服務,並且支持標準ServletAPI,Servlet就一個運行在
web服務器上的小的Java程序,用於處理從web客戶端發送的請求,並且對請求作出響應。現在目前最新版本為3.1。
2.Servlet實現過程
1).客戶端向服務器端發送請求;
2).服務器端發送請求到Servlet;
3).Servlet生成響應內容並再傳給服務器端(一般生成的響應內容是根據從服務器中客戶端的請求而決定的);
4).從服務器再響應返回客戶端;
3.Servlet生命周期
簡單來講,Servlet的生命周期就是在服務器內從創建到請求響應再到銷毀的全部過程。
在eclipse來看,init()方法就是Servlet實例化,也就是被創建,註意:無論Servlet在服務器請求或者響應多少次,init()只會執行一次;
service()方法,會根據客戶端(一般指前段)的請求方式,會調用doPost或者doGet方法;而執行服務器的請求和響應;destroy()方法是Servlet
從服務器移除或者關閉時,就代表Servlet已經被銷毀了。
4.Servlet啟動時加載
ervlet對象是第一次被訪問的時候會被創建的,init方法就會執行,從而會銷耗一些時間,在eclipse配置web.xml文件將Servlet的實例化
的過程放在服務器啟動的時候(讓服務器啟動的時候創建Servlet的對象)。用<load-on-startup>來配置,註意,在Tomcat服務器加載是1秒,
因而我們配置的時間最好不要小於1秒。
在web.xml中配置Servlet
<servlet>
<serlvet-name>自定義名稱</serlvet-name>
<servlet-class>帶包名的類路徑</servlet-class>
<load-on-startup>時間單位:秒</load-on-startup>
</servlet>
<servlet-mapping>
<serlvet-name>自定義名稱</serlvet-name>
<url-pattern>/路徑 出現在地址欄中</url-pattern>
</servlet-mapping>
5.Servlet訪問路徑的配置
完全路徑匹配 以"/"開頭
目錄匹配 以"/"開頭,以"*"結尾
擴展名匹配 以"*"開頭
作用域的範圍大小:完全路徑匹配 > 目錄匹配 > 擴展名匹配
6.Servlet和HttpServlet的區別
HttpServlet是繼承於Servlet,同時HttpServlet滿足Servlet所有的方法,HttpServlet是個類,而Servlet是個接口。HttpServlet是一個
與協議相關的Servlet是專門用來處理Http協議的請求。通常編寫一個Servlet一般都會讓這個Servlet繼承HttpServlet重寫service方法。所以
往往繼承了HttpServlet之後不需要重寫service方法,只需要重寫doGet和doPost方法即可。往往請求要處理的內容的代碼都是一致的,所以需
要讓doGet和doPost相互調用可以簡化編程。
7.ServletConfig和ServletContext的區別
ServletConfig是在Servlet的配置文件中,在使用<url-pattern>標簽來配置Servlet的一些初始化參數,後為了創建Servlet實例對象時,
這些數據會封裝到ServletConfig中;而ServletContext是在整個web應用時,從而初始化的參數就會封裝在ServletContext,同時也包含
ServletConfig的所有參數,在多個Servlet對象之間的通訊就用ServletContext來聯系。
總之,簡單來說ServletConfig是獲得Servlet的相關的配置的對象,相當於一個類,而ServletContext是獲得整個web的相關的配置的對象,
相當於整個項目。
8.ServletConfig和ServletContext的各自的方法
1).ServletConfig的方法
獲取ServletConfig對象: getServletConfig()
獲取Servlet的初始化參數: getInitparameterNames()
獲取Servlet的初始化參數(單個): getInitparameter(String name)
獲取ServletContext對象: getServletContext()
獲取Servlet的名稱: getServletName()
2).ServletContext的方法
獲取ServletContext對象: getServletContext()
獲取文件的MIME類型: getMimeType(String file)
獲取web項目請求工程名: getContextPath()
獲取全局的初始化參數: getInitparameterNames()
獲取全局的初始化參數(單個): getInitparameter(String name)
9.ServletContext作用域及方法
作用域:指的是將數據存入到域對象中,而這個數據就會有一定的作用範圍。作用域指的是一定的作用範圍。所以,ServletContext作用
域是整個全局,及web整個項目
方法:
存入數據: setAttribute(String name, Object object)
獲取數據: getAttribute(String name)
移除數據: removeAttribute(String name)
10.Response請求數據
ServletResponse接口和HttpServletResponse接口的區別:HttpServletResponse是繼承於ServletResponse,同時HttpServletResponse滿
足ServletResponse所有的方法,HttpServletResponse是帶有Http協議的,與HttpServlet一致。
一般常用的響應的狀態碼:200 正確;302 重定向;304 查找本地緩存;404 請求資源不存在;500 服務器內部錯誤
11.Response的方法
設置響應狀態碼: setStatus(int so)
設置響應頭: setHeader(String name, String value)
添加響應頭: addHeader(String name, String value)
字符流寫入響應體: getWriter()
字節流寫入響應體: getOutoutStream()
重定向: sendRedirect(String string)
設置瀏覽器采用的字符集: setContentType(String string)
設置響應字符流的緩沖區字符集: setCharacterEncoding(String charset)
服務器向瀏覽器回寫Cookie: addCookie(Cookie cookie)
12.Request接收數據
ServletRequest接口和HttpServletRequest接口的區別:與ServletResponse接口和HttpServletResponse接口的區別一致。
13.Request的方法
獲取請求方式: getMethed()
獲得請求路徑後的提交參數的字符串: getQueryString()
獲得請求路徑的URL: getRequestURL()
獲得請求路徑的URI: getRequestURI()
獲得客戶端的IP地址: getRemoteAddr()
獲得一個key對應一個value的請求頭: getHeader(String name)
獲得一個key對應多個value的請求頭: getHeaders(String names)
提交的參數(一個name對應一個value): getParameter(String name)
提交的參數(一個name對應多個value): getParameterValues(String names)
提交的參數(Map集合方式): getParameterMap()
存儲數據: setAttribute(String name, Object object)
獲取數據: getAttribute(String name)
移除數據: removeAttribute(String name)
14.Response和Request的中文亂碼
因為,Servlet的語言設置是ISO-8850-1,是不支持中文的,因而在請求和響應是出現中文亂碼。
1).Response解決中文亂碼
a.字節流響應中文
原因:其實這個亂碼的產生與中文轉成字節數組及瀏覽器打開方式(打開的時候采用的默認字符集)有關。
解決:將中文轉成字節數組的時候和瀏覽器默認打開的時候采用的字符集一致即可,都轉換UTF-8。
解決代碼:
ServletOutoutStream out = response.getOutoutStream();
response.setHeader("Content-Type","text/html;charset=utf-8");
out.write("中文的字符串".getBytes("utf-8"));
b.字符流響應中文
原因:字符流是有緩沖區的,response獲得字符流,response設計默認的緩沖區編碼是ISO-8859-1。
解決:設置response獲得字符流緩沖區的編碼和設置瀏覽器默認打開時候采用的字符集一致即可。
解決代碼:
response.setHeader("Content-Type","text/html;charset=utf-8");
response.setCharacterEncoding("utf-8");
response.getWriter().println("中文的字符串");
簡化版:
response.setContentType("text/html;charset=utf-8");
response.getWriter().println("中文的字符串");
2).Request解決中文亂碼
a.Post方式接收中文
原因:post提交數據的方式是在請求體中,request對象在接受數據之後,放入到緩沖區中,就會產生緩沖區的編碼是ISO-8859-1。
解決:修改request的緩沖區編碼
解決代碼:
request.setCharacterEncoding("utf-8");
String str = request.getInitparameter("//要修改的參數");
System.out.println(str);
b.Get方式接收中文
原因:post提交數據的方式是在請求行url後面,則會在地址欄進行url編碼
解決:存入到緩沖區的值將ISO-8859-1,以UTF-8解碼
解決代碼:
String encode = URLEncoder.encode(//要修改的參數,"ISO-8859-1");
String decode = URLDecoder.decode(encode,"utf-8");
System.out.println(decode);
解決二:
String //要修改的參數 = request.getParameter("//要修改的參數");
String str = new String(//要修改的參數.getBytes("ISO-8859-1"),"utf-8");
System.out.println(str);

基於javaWeb階段下的Servlet總結