JSP 表單處理

我們?cè)跒g覽網(wǎng)頁(yè)的時(shí)候,經(jīng)常需要向服務(wù)器提交信息,并讓后臺(tái)程序處理。瀏覽器中使用 GET 和 POST 方法向服務(wù)器提交數(shù)據(jù)。

GET 方法

GET方法將請(qǐng)求的編碼信息添加在網(wǎng)址后面,網(wǎng)址與編碼信息通過(guò)"?"號(hào)分隔。如下所示:

/hello?key1=value1&key2=value2

GET方法是瀏覽器默認(rèn)傳遞參數(shù)的方法,一些敏感信息,如密碼等建議不使用GET方法。

用get時(shí),傳輸數(shù)據(jù)的大小有限制 (注意不是參數(shù)的個(gè)數(shù)有限制),最大為1024字節(jié)。

POST 方法

一些敏感信息,如密碼等我們可以通過(guò)POST方法傳遞,POST提交數(shù)據(jù)是隱式的。

POST提交數(shù)據(jù)是不可見(jiàn)的,GET是通過(guò)在url里面?zhèn)鬟f的(可以看一下你瀏覽器的地址欄)。

JSP使用getParameter()來(lái)獲得傳遞的參數(shù),getInputStream()方法用來(lái)處理客戶端的二進(jìn)制數(shù)據(jù)流的請(qǐng)求。

JSP 讀取表單數(shù)據(jù)

  • getParameter(): 使用 request.getParameter() 方法來(lái)獲取表單參數(shù)的值。

  • getParameterValues(): 獲得如checkbox類(lèi)(名字相同,但值有多個(gè))的數(shù)據(jù)。   接收數(shù)組變量 ,如checkbox類(lèi)型

  • getParameterNames():該方法可以取得所有變量的名稱(chēng),該方法返回一個(gè) Enumeration。

  • getInputStream():調(diào)用此方法來(lái)讀取來(lái)自客戶端的二進(jìn)制數(shù)據(jù)流。

使用URL的 GET 方法示例

以下是一個(gè)簡(jiǎn)單的URL,并使用GET方法來(lái)傳遞URL中的參數(shù):

http://localhost:8080/testjsp/main.jsp?name=菜鳥(niǎo)教程&url=http://ww.(cainiaoplus.com)

testjsp 為項(xiàng)目地址。

以下是 main.jsp 文件的JSP程序用于處理客戶端提交的表單數(shù)據(jù),我們使用getParameter()方法來(lái)獲取提交的數(shù)據(jù):

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.io.*,java.util.*" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(cainiaoplus.com)</title>
</head>
<body>
<h1>使用 GET 方法讀取數(shù)據(jù)</h1>
<ul>
<li><p><b>站點(diǎn)名:</b>
   <%= request.getParameter("name")%>
</p></li>
<li><p><b>網(wǎng)址:</b>
   <%= request.getParameter("url")%>
</p></li>
</ul>
</body>
</html>

接下來(lái)我們通過(guò)瀏覽器訪問(wèn) http://localhost:8080/testjsp/main.jsp?name=JSP教程&url=http://ww.(cainiaoplus.com)輸出結(jié)果如下所示:

圖片.png

使用表單的 GET 方法示例

以下是一個(gè)簡(jiǎn)單的 HTML 表單,該表單通過(guò)GET方法將客戶端數(shù)據(jù)提交 到 main.jsp 文件中:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(cainiaoplus.com)</title>
</head>
<body>
<form action="main.jsp" method="GET">
站點(diǎn)名: <input type="text" name="name">
<br />
網(wǎng)址: <input type="text" name="url" />
<input type="submit" value="提交" />
</form>
</body>
</html>

將以上HTML代碼保存到test.htm文件中。 將該文件放置于當(dāng)前jsp項(xiàng)目的 WebContent 目錄下(與 main.jsp 同一個(gè)目錄)。

通過(guò)訪問(wèn) http://localhost:8080/testjsp/test.html 提交表單數(shù)據(jù)到 main.jsp 文件,圖如下所示:

圖片.png

在 "站點(diǎn)名" 與 "網(wǎng)址" 兩個(gè)表單中填入信息,并點(diǎn)擊 "提交" 按鈕,它將輸出結(jié)果。

使用表單的 POST 方法示例

接下來(lái)讓我們使用POST方法來(lái)傳遞表單數(shù)據(jù),修改main.jsp與Hello.htm文件代碼,如下所示:

main.jsp文件代碼:

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.io.*,java.util.*" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(cainiaoplus.com)</title>
</head>
<body>
<h1>使用 POST 方法讀取數(shù)據(jù)</h1>
<ul>
<li><p><b>站點(diǎn)名:</b>
<%
// 解決中文亂碼的問(wèn)題
String name = new String((request.getParameter("name")).getBytes("ISO-8859-1"),"UTF-8");
%>
   <%=name%>
</p></li>
<li><p><b>網(wǎng)址:</b>
   <%= request.getParameter("url")%>
</p></li>
</ul>
</body>
</html>

代碼中我們使用 new String((request.getParameter("name")).getBytes("ISO-8859-1"),"UTF-8")來(lái)轉(zhuǎn)換編碼,防止中文亂碼的發(fā)生。

以下是test.htm修改后的代碼:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(cainiaoplus.com)</title>
</head>
<body>
<form action="main.jsp" method="POST">
站點(diǎn)名: <input type="text" name="name">
<br />
網(wǎng)址: <input type="text" name="url" />
<input type="submit" value="提交" />
</form>
</body>
</html>

通過(guò)訪問(wèn) http://localhost:8080/testjsp/test.html 提交表單數(shù)據(jù)到 main.jsp 文件,如下所示:

圖片.png

傳遞 Checkbox 數(shù)據(jù)到JSP程序

復(fù)選框 checkbox 可以傳遞一個(gè)甚至多個(gè)數(shù)據(jù)。

以下是一個(gè)簡(jiǎn)單的HTML代碼,并將代碼保存在test.htm文件中:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(cainiaoplus.com)</title>
</head>
<body>
<form action="main.jsp" method="POST" target="_blank">
<input type="checkbox" name="google" checked="checked" /> Google
<input type="checkbox" name="nhooo"  /> 菜鳥(niǎo)教程
<input type="checkbox" name="taobao" checked="checked" /> 淘寶
<input type="submit" value="選擇網(wǎng)站" />
</form>
</body>
</html>

以上代碼在瀏覽器訪問(wèn)如下所示:

以下為main.jsp文件代碼,用于處理復(fù)選框數(shù)據(jù):

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.io.*,java.util.*" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(cainiaoplus.com)</title>
</head>
<body>
<h1>從復(fù)選框中讀取數(shù)據(jù)</h1>
<ul>
<li><p><b>Google 是否選中:</b>
   <%= request.getParameter("google")%>
</p></li>
<li><p><b>菜鳥(niǎo)教程是否選中:</b>
   <%= request.getParameter("nhooo")%>
</p></li>
<li><p><b>淘寶是否選中:</b>
   <%= request.getParameter("taobao")%>
</p></li>
</ul>
</body>
</html>

通過(guò)訪問(wèn) http://localhost:8080/testjsp/test.html 提交表單數(shù)據(jù)到 main.jsp 文件,如下所示:

圖片.png

點(diǎn)擊"選擇網(wǎng)站"后:

圖片.png

讀取所有表單參數(shù)

以下我們將使用 HttpServletRequestgetParameterNames() 來(lái)讀取所有表單參數(shù),該方法可以取得所有變量的名稱(chēng),該方法返回一個(gè)枚舉。

一旦我們有了一個(gè) Enumeration(枚舉),我們就可以調(diào)用 hasMoreElements() 方法來(lái)確定是否還有元素,以及使用nextElement()方法來(lái)獲得每個(gè)參數(shù)的名稱(chēng)。

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ page import="java.io.*,java.util.*" %>
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(cainiaoplus.com)</title>
</head>
<body>
<h1>讀取所有表單參數(shù)</h1>
<table width="100%" border="1" align="center">
<tr bgcolor="#949494">
<th>參數(shù)名</th><th>參數(shù)值</th>
</tr>
<%
   Enumeration paramNames = request.getParameterNames();
   while(paramNames.hasMoreElements()) {
      String paramName = (String)paramNames.nextElement();
      out.print("<tr><td>" + paramName + "</td>\n");
      String paramValue = request.getParameter(paramName);
      out.println("<td> " + paramValue + "</td></tr>\n");
   }
%>
</table>
</body>
</html>

以下是test.htm文件的內(nèi)容:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鳥(niǎo)教程(cainiaoplus.com)</title>
</head>
<body>
<form action="main.jsp" method="POST" target="_blank">
<input type="checkbox" name="google" checked="checked" /> Google
<input type="checkbox" name="nhooo"  /> 菜鳥(niǎo)教程
<input type="checkbox" name="taobao" checked="checked" /> 
                                                淘寶
<input type="submit" value="選擇網(wǎng)站" />
</form>
</body>
</html>

現(xiàn)在我們通過(guò)瀏覽器訪問(wèn) test.htm 文件提交數(shù)據(jù),輸出結(jié)果如下:

通過(guò)訪問(wèn) http://localhost:8080/testjsp/test.html 提交表單數(shù)據(jù)到 main.jsp 文件,如下所示:


圖片.png

點(diǎn)擊 "選擇網(wǎng)站"后:


圖片.png

你可以嘗試使用以上的JSP代碼讀取其它對(duì)象,如文本框,單選按鈕或下拉框等等其他形式的數(shù)據(jù)。

丰满人妻一级特黄a大片,午夜无码免费福利一级,欧美亚洲精品在线,国产婷婷成人久久Av免费高清