一.request和response簡介:
- request和response的作用執(zhí)行流程
Web服務器收到客戶端的http請求,會針對每一次請求,分別創(chuàng)建一個用于代表請求的request對象、和代表響應的response對象。
故:當需要獲取客戶機提交過來的數據時,找request對象就行了。
當需要向客戶機輸出數據,找response對象。
請求響應的具體現實流程:
1.瀏覽器發(fā)送請求
2.服務器接收請求,創(chuàng)建兩個對象(request和response),將請求的信息封裝request對象
3.找到對應的servlet,將這兩個對象傳遞給servlet
4.Servlet收到請求,執(zhí)行service方法,處理自己的業(yè)務邏輯,生成動態(tài)的內容,將內容返回給服務器
5.服務器收到內容之后,進行拆分,生成響應信息,返回給瀏覽器
6.瀏覽器解析
2.關于 request和response的體系結構:
httpServlet實現了service方法。
Servlet的service方法中有兩個參數servletRequest和servletResponse
httpServlet實現了service方法
將兩個對象進行了強轉
ServletRequest==>HttpServletRequest
ServletResponse==>HttpServletResponse
//具體的實現類是由服務器幫我們創(chuàng)建的
tomact的實現類(了解)
org.apache.catalina.connector.RequestFacade
org.apache.catalina.connector.ResponseFacade
javax.servlet.Servlet接口中的service方法
public abstract void service(ServletRequest req, ServletResponse res)
javax.servlet.GenericServlet類中的service方法
public abstract void service(ServletRequest req, ServletResponse res)
javax.servlet.http.HttpServlet類中的service方法
在這個類中對service方法進行了重載
public void service(ServletRequest req, ServletResponse res)
protected void service(HttpServletRequest req, HttpServletResponse resp)
二.response
響應:用于向瀏覽器寫東西
1.response常用方法:
2.response操作響應行(操作狀態(tài)碼)
格式:協議/版本 狀態(tài)碼 狀態(tài)碼說明
例如:HTTP/1.1 200 OK
在http響應行中,包括協議,版本號,以及有一個很重要的值,它叫做響應狀態(tài)碼.響應行中我們主要就是操作這些狀態(tài)碼,它可以有五種類型取值:
100-199
200-299
300-399
400-499
500-599
常用狀態(tài)碼
200請求成功(其后是對GET和POST請求的應答文檔。)
302所請求的頁面已經臨時轉移至新的url。(重定向)(配合location響應頭使用)
304未按預期修改文檔。(讓瀏覽器讀緩存)
客戶端有緩沖的文檔并發(fā)出了一個條件性的請求(一般是提供If-Modified-Since(什么時候修改的))頭表示客戶只想比指定日期更新的文檔)。服務器告訴客戶,原來緩沖的文檔還可以繼續(xù)使用。
404沒有找到文件或目錄。(用戶操作錯誤)
405請求中指定的方法不被允許
500請求未完成。服務器遇到不可預知的情況(代碼錯誤)
504網關錯誤.
HttpServletResponse操作狀態(tài)碼方法
void setStatus(int sc): 設置狀態(tài)代碼.針對于非錯誤的狀態(tài)碼
例如:setstatus 200
void sendError(int status,String msg) throws IOException 設置錯誤狀態(tài)碼及信息
例如:response.sendError(404);報404錯誤
response.sendError(404,一不小心走丟了.........);報錯誤并且有錯誤信息
3.response操作響應頭
http響應頭的格式是 key/value的格式,可以有多個value值,以”,”分開.
例如:
Content-Encoding: gzip
Content-Length: 123
Content-Language: zh-cn
Content-Type: text/html; charset=GB2312
Last-Modified: Tue, 11 Jul 2000 18:23:51 GMT
HttpServletResponse操作響應頭 API
public void setHeader(String name,String value)
用給定名稱和值設置響應頭。如果已經設置了頭,則新值將重寫以前的值
(設置字符串形式的響應頭 注意:若設置過,會覆蓋)
public void addHeader(String name, String value)
用給定名稱和值添加響應頭。此方法允許響應頭有多個值
(追加字符串形式的響應頭 注意:若沒有設置過則設置,若設置過則追加)
public void setIntHeader(String name, int value)
用給定名稱和整數值設置響應頭。如果已經設置了頭,則新值將重寫以前的值。
(設置整型的響應頭)
public void addIntHeader(String name, int value)
用給定名稱和整數值添加響應頭。此方法允許響應頭有多個值。
(添加整型的響應頭)
public voidsetDateHeader(String name, long date)
用給定名稱和日期值設置響應頭。該日期根據距歷元時間的毫秒數指定。如果已經設置了頭,則新值將重寫以前的值。(設置時間類型的響應頭)
public void addDateHeader(String key, long date)
用給定名稱和日期值添加響應頭。該日期根據距歷元時間的毫秒數指定。此方法允許響應頭有多個值。(添加時間類型的響應頭)
三.request
請求:要想獲取瀏覽器發(fā)送過來的參數,通過request就可以了
1.HttpServletRequest對象用于封裝http請求,對于http請求它有三部分組成,http請求行,http請求頭及請求正文,
常用方法:
2.request操作請求行
格式:請求方式 請求資源 協議/版本
例子:GET /day10 HTTP/1.1
public String getMethod()獲取請求方式例如 GET、POST
public String getRequestURI()獲取去請求資源(不帶參數) 是uri 例如:/day10/r
public String getProtocol()獲取協議的名稱和版本。(例如 HTTP/1.1)
public String getQueryString()
返回包含在請求 URL 中路徑后面的查詢字符串。如果 URL 沒有查詢字符串,則此方法返回 null。
例如:
//獲取請求方式
String m= request.getMethod();
//獲取請求資源
String url=request.getRequestURI();
//獲取協議版本
String pro=request.getProtocol();
☆public String getContextPath()獲取的是項目名
public StringBuffer getRequestURL() 獲取請求的完整路徑
重新構造客戶端用于發(fā)出請求的 URL。返回的 URL 包含一個協議、服務器名稱、端口號、服務器路徑,但是不包含查詢字符串參數。
public String getRemoteAddr()獲取請求的ip地址
返回發(fā)送請求的客戶端或最后一個代理的 Internet Protocol (IP) 地址
- request操作請求頭
格式:key/value(value可以為多個)
☆public String getHeader(String name) 獲取字符串格式的請求頭
以 String 的形式返回指定請求頭的值。
public java.util.Enumeration<E> getHeaders(String name)獲取多個值的請求頭
以 String 對象的 Enumeration 的形式返回指定請求頭的所有值。
public java.util.Enumeration<E> getHeaderNames()獲取所有請求頭的名稱
返回此請求包含的所有頭名稱的枚舉。如果該請求沒有頭,則此方法返回一個空枚舉。
public int getIntHeader(String name) 獲取整型格式的請求頭
以 int 的形式返回指定請求頭的值。如果該請求沒有指定名稱的頭,則此方法返回 -1。如果無法將頭轉換為整數,則此方法拋出 NumberFormatException。
public long getDateHeader(String name)獲取時間類型的請求頭
以表示 Date 對象的 long 值的形式返回指定請求頭的值
案例:防盜鏈
- request獲取請求參數(只有post有請求體)
Get請求 地址欄
http://localhost:端口/day10/1.html?username=tom&password=1234&hobby=eat&hobby=sleep
Post請求里面放的是?號后面的東西
請求參數是瀏覽器發(fā)送請求時攜帶的信息。
Get和Post請求的區(qū)別:
GET:參數會追加到地址欄上,post不會
請求參數大小有限制(一般不超過1kb),post沒有
POST:相對于get請求安全
有請求體,存放請求參數,get沒有
dopost方法里面訪問doget方法內容
只要在post方法里調用就可以了反之亦然
doget(request,response);
☆public String getParameter(String name)(獲取單一的值)
以 String 形式返回請求參數的值,如果該參數不存在,則返回 null
public String[] getParameterValues(String name)(獲取多個值)
返回包含給定請求參數擁有的所有值的 String 對象數組,如果該參數不存在,則返回 null。
☆public java.util .Map<String, String[]> getParameterMap()(以map方式返回的所有的參數和值)
返回此請求的參數的 java.util.Map。請求參數是與請求一起發(fā)送的額外信息。對于 HTTP servlet,參數包含在查詢字符串或發(fā)送的表單數據中。
public java.util.Enumeration<E> getParameterNames()
返回包含此請求中所包含參數的名稱的 String 對象的 Enumeration。如果該請求沒有參數,則此方法返回一個空的 Enumeration。
- request獲取參數中文出現亂碼
原因:
漢字在不同的編碼表中的碼值不一樣,那么在使用不同的編碼表進行解碼與編碼操作時,就會出現亂碼問題.
瀏覽器在提交的時候使用utf-8編碼
Tomcat得到請求參數是使用iso8859-1進行了解碼,封裝到了request中。
在通過request獲取請求信息就是亂碼。
解決:
先使用iso8859-1進行編碼
在使用utf-8進行解碼
每個參數都要new才行(get,post方法都可行)
username= new String(username.getBytes(“iso8859-1”),”utf-8”);
如果請求方式是POST,
可以直接使用request.setCharacterEncoding(“utf-8”);就可以解決。
- request域對象的介紹
request對象同時也是一個域對象,開發(fā)人員通過request對象在實現轉發(fā)時,把數據通過request對象帶給其它web資源處理.
request
xxxAttribute();
生命周期:一次請求開始,到響應結束之前
setAttribute方法 設置
getAttribute方法 獲取
removeAttribute方法 刪除
getAttributeNames方法
request對象提供了一個getRequestDispatcher方法,該方法返回一個RequestDispatcher對象,調用這個對象的forward方法可以實現請求轉發(fā),從而共享請求中的數據
request.getRequestDispatcher("內部路徑").forward(request,response)。
請求轉發(fā)和重定向的區(qū)別
1.請求轉發(fā)是服務器內部跳轉,地址欄不會發(fā)生改變
重定向地址欄會發(fā)生改變。
2.請求轉發(fā),只有一次請求,一次響應.
重定向,有兩次請求,兩次響應。
3.請求轉發(fā)存在request域,可以共享數據.
重定向不存在request域。
4.請求轉發(fā)只能在服務器的內部跳轉,簡單說,只能訪問本站內資源。
重定向可以訪問站外資源,也可以訪問站內資源.
5.請求轉發(fā)是由request 發(fā)起的 . request.getRequestDispatcher().forward()
重定向是由response 發(fā)起的 response.sendRedirect();
6.請求轉發(fā)與重定向時路徑寫法不一樣.
重定向要跳轉的路徑是瀏覽器在次發(fā)起的,是瀏覽器端路徑:寫法: /工程名/資源
請求轉發(fā)是服務器內部跳轉,這時它與瀏覽器無關 寫法:/資源
- 請求包含
RequestDispatcher.include()方法用于將RequestDispatcher對象封裝的資源內容作為當前響應內容的一部分包含進來,從而實現可編程的服務器端包含功能
被包含的Servlet程序不能改變響應消息的狀態(tài)碼和響應頭,如果它里面存在這樣的語句,這些語句的執(zhí)行結果將被忽略.include在程序執(zhí)行上效果類似forward,但是使用forward只有一個程序可以生成響應,include可以由多個程序一同生成響應 ----- 常用來頁面布局
New兩個html頁面分別為 i1.html&i2.html
i1內容1111111111
i2內容22222222222
New一個Servlet get方法下
request.getRequestDispatcher(“/i1.html”).include(request,response);
request.getRequestDispatcher(“/i2.html”).include(request,response);
最后在頁面輸出的內容為111111111122222222222是兩個頁面的所用內容.