ServletRequest HttpServletRequest 請求方法 獲取請求參數 請求轉發 請求包含 請求轉發與重定向區別 獲取請求頭字段...

原文地址:ServletRequest HttpServletRequest 請求方法 獲取請求參數 請求轉發 請求包含 請求轉發與重定向區別 獲取請求頭字段

ServletRequest?基本概念

?
JavaWeb中的 "Request"對象?
實際為?? HttpServletRequest? 或者? ServletRequest,?? 兩者都為接口
服務器接收請求后,將請求數據進行對象封裝
image_5b680acc_2dc8
image_5b680acc_71fa

功能大致分類

request的功能可以分為以下幾種:
  • 封裝了請求頭數據;
  • 封裝了請求正文數據,如果是GET請求,那么就沒有正文;
  • request是一個域對象,可以把它當成Map來添加獲取數據;
  • request提供了請求轉發和請求包含功能。

request是四大域對象之一
其他是ServletContext? Session? PageContext

Request的域方法

?
用來存儲一個對象,也可以稱之為存儲一個域屬性
void setAttribute(String name, Object value);
例如:servletContext.setAttribute(“xxx”, “XXX”),在request中保存了一個域屬性,域屬性名稱為xxx,域屬性的值為XXX。
請注意,如果多次調用該方法,并且使用相同的name,那么會覆蓋上一次的值,這一特性與Map相同;
用來獲取request中的數據
Object getAttribute(String name);
當前在獲取之前需要先去存儲才行,
例如:
String value = (String)request.getAttribute(“xxx”);,獲取名為xxx的域屬性;
用來移除request中的域屬性,如果參數name指定的域屬性不存在,那么本方法什么都不做;
void removeAttribute(String name);
獲取所有域屬性的名稱;
Enumeration getAttributeNames();

獲取請求頭數據

獲取指定名稱的請求頭;
String getHeader(String name);
獲取所有請求頭名稱;
Enumeration getHeaderNames();
獲取值為int類型的請求頭。
int getIntHeader(String name);

獲取請求相關的其它方法

還提供了與請求相關的其他方法,有些方法是為了我們更加便捷的方法請求頭數據而設計,有些是與請求URL相關的方法
獲取請求體的字節數,GET請求沒有請求體,沒有請求體返回-1;
int getContentLength();
獲取請求類型,如果請求是GET,那么這個方法返回null;
如果是POST請求,那么默認為application/x-www-form-urlencoded,表示請求體內容使用了URL編碼;
String getContentType();
返回請求方法,例如:GET
String getMethod();
返回當前客戶端瀏覽器的Locale。java.util.Locale表示國家和言語,這個東西在國際化中很有用;
Locale getLocale();
獲取請求體編碼,如果沒有setCharacterEncoding(),那么返回null,表示使用ISO-8859-1編碼;
String getCharacterEncoding();
設置請求編碼,只對請求體有效!注意,對于GET而言,沒有請求體!!!所以此方法只能對POST請求中的參數有效!
void setCharacterEncoding(String code);
返回請求協議,例如:http;
String getScheme();
返回主機名,例如:localhost?? 或者 127.0.0.1
String getServerName();
返回服務器端口號,例如:8080
int getServerPort();
返回請求URI路徑,例如:/servlet/ServletA
String getRequestURI();
返回請求URL路徑,例如:http://localhost:8080/servlet/ServletA,
即返回除了參數以外的路徑信息;
StringBuffer getRequestURL();
返回請求URL中的參數,例如:name=zhangsan&age=28
String getQueryString();
返回上下文路徑,例如:/servlet
String getContextPath();
返回Servlet路徑,例如:/ServletA
String getServletPath();
返回當前客戶端的IP地址;
String getRemoteAddr();
返回當前客戶端的主機名,但這個方法的實現還是獲取IP地址;
String getRemoteHost();
上面的路徑示例?? 假定請求地址為:
http://127.0.0.1:8080/servlet/ServletA?name=zhangsan&age=28
image_5b680acd_1c23

獲取請求參數

最為常見的客戶端傳遞參數方式有兩種GET 和 POST:
瀏覽器地址欄直接輸入:一定是GET請求;
超鏈接:一定是GET請求;
表單:可以是GET,也可以是POST,這取決與<form>的method屬性值;
GET請求和POST請求的區別
GET請求:
請求參數會在瀏覽器的地址欄中顯示,所以不安全;
請求參數長度限制長度在1K之內;
GET請求沒有請求體,無法通過request.setCharacterEncoding()來設置參數的編碼;
POST請求:
請求參數不會顯示瀏覽器的地址欄,相對安全;
請求參數長度沒有限制;
?
獲取請求參數的具體方法
根據參數名稱獲取參數
public String getParameter(String name);?
?
頁面一個超鏈接一個表單
image_5b680acd_f98
復制代碼
<body><a href="/servlet/ServletA?name=zhangsan&age=28">超鏈接</a><hr/><form action="/servlet/ServletA" method="post">參數1:<input type="text" name="name"/><br/>參數2:<input type="text" name="age"/><br/><input type="submit" value="提交"/></form></body>
復制代碼

?

Servlet中java代碼(doGet? doPost? 都一樣可以)
System.out.println("request.getParameter(\"name\"): " + request.getParameter("name"));System.out.println("request.getParameter(\"age\"): " + request.getParameter("age"));
打印結果:
image_5b680acd_1cd7
當多個參數名稱相同時,可以使用方法來獲取
String[] getParameterValues(String name);
?
http://127.0.0.1:8080/servlet/ServletA?name=zhangsan&name=lisi
復制代碼
System.out.println("request.getParameter(\"name\"): " + request.getParameter("name"));String[] names = request.getParameterValues("name");System.out.println(Arrays.toString(names));
復制代碼

?

打印結果:
image_5b680acd_45f0?
可以看得出來request.getParameter("name")? 打印的是第一個
獲取所有參數的名稱
public Enumeration getParameterNames();
http://127.0.0.1:8080/servlet/ServletA?name=zhangsan&age=28&sex=male
復制代碼
Enumeration pNames = request.getParameterNames();while(pNames.hasMoreElements()) {System.out.println(pNames.nextElement());}
復制代碼

?

打印信息
image_5b680acd_115
獲取所有參數封裝到Map中,其中key為參數名,value為參數值
因為一個參數名稱可能有多個值,所以參數值是String[],而不是String
public Map getParameterMap();
http://127.0.0.1:8080/servlet/ServletA?name=zhangsan&age=28&sex=male&name=lisi&age=18
復制代碼
//轉換為MapMap<String,String[]> paramMap = request.getParameterMap();//獲取鍵,根據鍵獲取值數組for(String name : paramMap.keySet()) {String[] values = paramMap.get(name);System.out.println(name + ": " + Arrays.toString(values));}
復制代碼

?

打印結果:
image_5b680acd_7188

請求轉發和請求包含??

RequestDispatcher??????? forward??? include

無論是請求轉發還是請求包含,都表示由多個Servlet共同來處理一個請求。
請求轉發與請求包含比較
1.如果在AServlet中請求轉發到BServlet,那么在AServlet中就不允許再輸出響應體,
即不能再使用response.getWriter()和response.getOutputStream()向客戶端輸出,這一工作應該由BServlet來完成;
如果是使用請求包含,那么沒有這個限制;
2.請求轉發雖然不能輸出響應體,但還是可以設置響應頭的
例如:response.setContentType(”text/html;charset=utf-8”);
3.請求包含大多是應用在JSP頁面中,完成多頁面的合并;
4.請求轉發大多是應用在Servlet中,轉發目標大多是JSP頁面;
ServletA中代碼如下:
復制代碼
response.getWriter().println("ServletA");//獲取“調度器”,其中參數為BServlet綁定的URL,即BServlet的<url-pattern>值。RequestDispatcher rd = request.getRequestDispatcher("/ServletB");rd.forward(request, response);
復制代碼

?

B中僅僅響應信息
image_5b680acd_2afc
請求http://127.0.0.1:8080/servlet/ServletA
頁面數據為:
image_5b680acd_4ceb
可以看得到,雖然A中有response.getWriter().println("ServletA");? 但是沒有任何的結果,請求直接被轉發了
請求 http://127.0.0.1:8080/servlet/ServletA
ServletA中代碼如下:
復制代碼
response.getWriter().println("ServletA");//獲取“調度器”,其中參數為BServlet綁定的URL,即BServlet的<url-pattern>值。RequestDispatcher rd = request.getRequestDispatcher("/ServletB");rd.include(request, response);
復制代碼

?

頁面數據為:
image_5b680acd_7029
此時A和B??? Servlet的響應都可以正常輸出,也就是響應進行了合并
image_5b680acd_69c2

請求轉發與重定向比較

請求轉發是一個請求,而重定向是兩個請求;
請求轉發后瀏覽器地址欄不會有變化,而重定向會有變化,因為重定向是兩個請求;
請求轉發的目標只能是本應用中的資源,重定向的目標可以是其他應用;
請求轉發對ServletA和ServletB的請求方法是相同的,即要么都是GET,要么都是POST,因為請求轉發是一個請求;
重定向的第二個請求一定是GET;

轉載于:https://www.cnblogs.com/JonaLin/p/11090010.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/386576.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/386576.shtml
英文地址,請注明出處:http://en.pswp.cn/news/386576.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

c#掃描圖片去黑邊(掃描儀去黑邊)

/// <summary> /// 自動去除圖像掃描黑邊 /// </summary> /// <param name"fileName"></param> public static void AutoCutBlackEdge(string fileName) { //打開圖像 Bit…

已成功拿下字節、騰訊、脈脈offer,算法太TM重要了

一、背景介紹 從實用角度梳理一篇能夠幫大家快速掃盲的CMake基礎教程&#xff0c;也是對我目前負責項目的一次學習總結。既然選擇從項目實用性考慮&#xff0c;下面的講解內容可能并不一定完整&#xff0c;更多的是符合項目目前使用到的一些特性。 接下來正面回答這個問題&am…

SpringBoot2.0 Actuator 監控參數說明

主要內容更 監控參數說明 Maven坐標 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-actuator</artifactId> </dependency> <dependency><groupId>io.micrometer</groupId>&…

帶你一步一步深入Handler源碼,醍醐灌頂!

開頭 最近有粉絲反應&#xff0c;不想做安卓了&#xff0c;有朋友轉到前端了&#xff0c;安卓不行了&#xff0c;問我怎么辦&#xff1f; 自從RN&#xff0c;Weex這種跨平臺編程語言出來以后&#xff0c;安卓將死的言論總是不絕于耳。隨著頗有摧枯拉朽之勢Flutter的出現&…

Spring基于狀態機squirrel-foundation簡單使用

squirrel-foundation的一些使用方法在百度上資料還是比較少&#xff0c;我是根據以下三個大佬寫的文章借鑒的&#xff0c;在這里記錄一下。 1、squirrel-foundation-demo 2、Squirrel使用&#xff08;中文文檔&#xff09; 3、squirrel-foundation狀態機的使用細節 我在這里直接…

記得把每一次面試當做經驗積累,深夜思考

開頭 Android開發&#xff0c;假如開始沒有任何的開發經驗的話&#xff0c; 千萬不要著急&#xff0c;不要想著在短時間內就把一個語言學習好&#xff0c; 因為你之前沒有任何的學習經驗&#xff0c; 在這個過程中需要有耐心地學習完JAVA的基礎知識&#xff0c; 然后才開始踏上…

squirrel-foundation-demo

一個簡單的squirrel-foundation-demo 利用狀態機模擬一個訂單的支付過程。 squirrel-foundation沒有任何嚴重的依賴關系&#xff0c;因此基本上它應該是高度可嵌入的。squirrel-foundation沒有整合spring框架&#xff0c;所以首先要用spring集成squirrel-foundation。spring集成…

MongoDB學習目錄

MongoDB基礎篇 MongoDB 之 $ 關鍵字 python操作MongoDB 轉載于:https://www.cnblogs.com/yanzhi-1996/p/11095016.html

講的真透徹!還有人不知道什么是AndroidX的嗎?已拿offer入職

前言 春招已經接近尾聲了&#xff0c;不知道各位小伙伴有沒有收獲自己心儀的offer呢。筆者疫情被裁后在家LeetCode狂刷了800多題&#xff0c;加之自己以為工作總結的知識、經驗&#xff0c;系統化的整理了一下。在五一期間已經收獲了字節的offer。廢話不多說&#xff0c;下面是…

docker 啟動的 jenkins 中調用宿主機docker進行build

前言 期初有這個需求感覺就跟套娃一樣&#xff0c;你在docker 中調用docker&#xff0c;笑哭……這個也太逗了。 不過的確遇到了&#xff0c;因為jenkins 容器中沒有docker &#xff0c;所以在編譯 docker build 的時候 會出現 docker command 不存在。 好吧&#xff0c;解決他…

Codeforces 773D Perishable Roads 最短路 (看題解)

Perishable Roads 智商題&#xff0c; 不會啊。。 貼個官方題解 https://codeforces.com/blog/entry/51883 #include<bits/stdc.h> #define LL long long #define LD long double #define ull unsigned long long #define fi first #define se second #define mk make_p…

Rancher中的服務升級實驗

創建一個空的應用myAPP&#xff0c;在myAPP 應用中&#xff0c;創建一個服務nginx-test&#xff0c;包含2個容器副本&#xff0c;使用nginx:1.13.0鏡像。假設使用一段時期以后&#xff0c;nginx的版本升級到1.13.1了&#xff0c;如何將該服務的鏡像版本升級到新的版本&#xff…

該如何高效實用Kotlin?看這一篇就夠了!

前言 說起程序員人們的第一印象就是工資高、加班兇、話少錢多頭發少。再加上現在科技互聯網公司太吃香&#xff0c;bat、華為小米等公司程序員加班情況被廣泛傳播&#xff0c;程序員用生命在敲代碼的印象刻在了很多人的心里。 與其它行業一樣&#xff0c;凡是有高級和普通&…

apply()與call()

JavaScript中的每一個Function對象都有一個apply()方法和一個call()方法&#xff0c;它們的語法分別為&#xff1a; /*apply()方法*/ function.apply(thisObj[, argArray])/*call()方法*/ function.call(thisObj[, arg1[, arg2[, [,...argN]]]]); 它們各自的定義&#xff1a; a…

Java基于redis實現分布式鎖(SpringBoot)

前言 分布式鎖&#xff0c;其實原理是就是多臺機器&#xff0c;去爭搶一個資源&#xff0c;誰爭搶成功&#xff0c;那么誰就持有了這把鎖&#xff0c;然后去執行后續的業務邏輯&#xff0c;執行完畢后&#xff0c;把鎖釋放掉。 可以通過多種途徑實現分布式鎖&#xff0c;例如…

請談下Android消息機制,復習指南

談起Android框架體系架構&#xff0c;我先提個問&#xff1a;什么是Android框架體系架構 &#xff1f; Android系統構架是安卓系統的體系結構&#xff0c;android的系統架構和其操作系統一樣&#xff0c;采用了分層的架構&#xff0c;共分為四層&#xff0c;從高到低分別是And…

SVN Cannot merge into a working copy that has local modifications

我嘗試了 主支&#xff0c;分支都提交&#xff0c;但是依然無法合并。 最終&#xff0c;我在服務器上將分支刪除&#xff0c;然后主支在拷貝過去。 一&#xff0c;打開服務器資源 二&#xff0c;刪除分支 三&#xff0c;拷貝主支到分支 四&#xff0c;刷新分支&#xff0c;就能…

資深Android開發帶你入門Framework,再不刷題就晚了!

想要成為一名優秀的Android開發&#xff0c;你需要一份完備的知識體系&#xff0c;在這里&#xff0c;讓我們一起成長為自己所想的那樣。 本文參考了目前大部分 Android 應用啟動優化的方案&#xff0c;將大家的方案做一個匯總&#xff0c;如果你有這方面的需求&#xff0c;只…

K8S相關內容

常用工具&#xff1a;docker linux k8s kubeadm 概念 etcd 數據庫 類似redis api server 接口對外提供api 調用 可以命令 kubectl 或者 kube-proxy&#xff0c;能訪問etcd&#xff0c;事件總線 scheduler 調度決策的組件 掌握新的情況&#xff0c;進行決策及分布pod放在哪些n…

資深Android開發帶你入門Framework,架構師必備技能

開頭 先說一下我大概的情況吧。渣本畢業&#xff0c;工作已經有快兩年了&#xff0c;從高中就開始玩小破站。無論是學習還是日常放松都是在b站。大學主學的軟件技術專業&#xff0c;所以&#xff0c;進大學校門那一刻起&#xff0c;去上海bilibili工作就在心里埋下了種子。在學…