课程表

JSP 基础教程

JSP 高级教程

工具箱
速查手册

JSP 表单处理

当前位置:免费教程 » Java相关 » JSP

我们在浏览网页的时候,经常需要向服务器提交信息,并让后台程序处理。浏览器中使用 GET 和 POST 方法向服务器提交数据。


GET 方法

GET方法将请求的编码信息添加在网址后面,网址与编码信息通过"?"号分隔。如下所示:

  1. //www.w3xue.com/hello?key1=value1&key2=value2

GET方法是浏览器默认传递参数的方法,一些敏感信息,如密码等建议不使用GET方法。

用get时,传输数据的大小有限制 (注意不是参数的个数有限制),最大为1024字节。


POST 方法

一些敏感信息,如密码等我们可以通过POST方法传递,POST提交数据是隐式的。

POST提交数据是不可见的,GET是通过在url里面传递的(可以看一下你浏览器的地址栏)。

JSP使用getParameter()来获得传递的参数,getInputStream()方法用来处理客户端的二进制数据流的请求。


JSP 读取表单数据

  • getParameter(): 使用 request.getParameter() 方法来获取表单参数的值。

  • getParameterValues(): 获得如checkbox类(名字相同,但值有多个)的数据。 接收数组变量 ,如checkbox类型

  • getParameterNames():该方法可以取得所有变量的名称,该方法返回一个Emumeration。

  • getInputStream():调用此方法来读取来自客户端的二进制数据流。


使用URL的 GET 方法实例

以下是一个简单的URL,并使用GET方法来传递URL中的参数:

  1. http://localhost:8080/testjsp/main.jsp?name=W3xue教程&url=http://ww.w3xue.com

testjsp 为项目地址。

以下是 main.jsp 文件的JSP程序用于处理客户端提交的表单数据,我们使用getParameter()方法来获取提交的数据:

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ page import="java.io.*,java.util.*" %>
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta charset="utf-8">
  8. <title>W3xue教程(w3xue.com)</title>
  9. </head>
  10. <body>
  11. <h1>使用 GET 方法读取数据</h1>
  12. <ul>
  13. <li><p><b>站点名:</b>
  14. <%= request.getParameter("name")%>
  15. </p></li>
  16. <li><p><b>网址:</b>
  17. <%= request.getParameter("url")%>
  18. </p></li>
  19. </ul>
  20. </body>
  21. </html>

接下来我们通过浏览器访问 http://localhost:8080/testjsp/main.jsp?name=W3学教程&url=//www.w3xue.com 输出结果如下所示:


使用表单的 GET 方法实例

以下是一个简单的 HTML 表单,该表单通过GET方法将客户端数据提交 到 main.jsp 文件中:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>W3xue教程(w3xue.com)</title>
  6. </head>
  7. <body>
  8.  
  9. <form action="main.jsp" method="GET">
  10. 站点名: <input type="text" name="name">
  11. <br />
  12. 网址: <input type="text" name="url" />
  13. <input type="submit" value="提交" />
  14. </form>
  15.  
  16. </body>
  17. </html>

将以上HTML代码保存到test.htm文件中。 将该文件放置于当前jsp项目的 WebContent 目录下(与 main.jsp 同一个目录)。

通过访问 http://localhost:8080/testjsp/test.html 提交表单数据到 main.jsp 文件,演示 Gif 图如下所示:

在 "站点名" 与 "网址" 两个表单中填入信息,并点击 "提交" 按钮,它将输出结果。


使用表单的 POST 方法实例

接下来让我们使用POST方法来传递表单数据,修改main.jsp与Hello.htm文件代码,如下所示:

main.jsp文件代码:

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ page import="java.io.*,java.util.*" %>
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta charset="utf-8">
  8. <title>W3xue教程(w3xue.com)</title>
  9. </head>
  10. <body>
  11. <h1>使用 POST 方法读取数据</h1>
  12. <ul>
  13. <li><p><b>站点名:</b>
  14. <%
  15. // 解决中文乱码的问题
  16. String name = new String((request.getParameter("name")).getBytes("ISO-8859-1"),"UTF-8");
  17. %>
  18. <%=name%>
  19. </p></li>
  20. <li><p><b>网址:</b>
  21. <%= request.getParameter("url")%>
  22. </p></li>
  23. </ul>
  24. </body>
  25. </html>

代码中我们使用 new String((request.getParameter("name")).getBytes("ISO-8859-1"),"UTF-8")来转换编码,防止中文乱码的发生。

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>W3xue教程(w3xue.com)</title>
  6. </head>
  7. <body>
  8.  
  9. <form action="main.jsp" method="POST">
  10. 站点名: <input type="text" name="name">
  11. <br />
  12. 网址: <input type="text" name="url" />
  13. <input type="submit" value="提交" />
  14. </form>
  15.  
  16. </body>
  17. </html>

通过访问 http://localhost:8080/testjsp/test.html 提交表单数据到 main.jsp 文件,演示 Gif 图如下所示:


传递 Checkbox 数据到JSP程序

复选框 checkbox 可以传递一个甚至多个数据。

以下是一个简单的HTML代码,并将代码保存在test.htm文件中:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>W3xue教程(w3xue.com)</title>
  6. </head>
  7. <body>
  8.  
  9. <form action="main.jsp" method="POST" target="_blank">
  10. <input type="checkbox" name="google" checked="checked" /> Google
  11. <input type="checkbox" name="W3xue" /> W3xue教程
  12. <input type="checkbox" name="taobao" checked="checked" />
  13. 淘宝
  14. <input type="submit" value="选择网站" />
  15. </form>
  16.  
  17. </body>
  18. </html>

以上代码在浏览器访问如下所示:

以下为main.jsp文件代码,用于处理复选框数据:

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ page import="java.io.*,java.util.*" %>
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta charset="utf-8">
  8. <title>W3xue教程(w3xue.com)</title>
  9. </head>
  10. <body>
  11. <h1>从复选框中读取数据</h1>
  12. <ul>
  13. <li><p><b>Google 是否选中:</b>
  14. <%= request.getParameter("google")%>
  15. </p></li>
  16. <li><p><b>W3xue教程是否选中:</b>
  17. <%= request.getParameter("W3xue")%>
  18. </p></li>
  19. <li><p><b>淘宝是否选中:</b>
  20. <%= request.getParameter("taobao")%>
  21. </p></li>
  22. </ul>
  23. </body>
  24. </html>

通过访问 http://localhost:8080/testjsp/test.html 提交表单数据到 main.jsp 文件,演示 Gif 图如下所示:


读取所有表单参数

以下我们将使用 HttpServletRequestgetParameterNames() 来读取所有表单参数,该方法可以取得所有变量的名称,该方法返回一个枚举。

一旦我们有了一个 Enumeration(枚举),我们就可以调用 hasMoreElements() 方法来确定是否还有元素,以及使用nextElement()方法来获得每个参数的名称。

  1. <%@ page language="java" contentType="text/html; charset=UTF-8"
  2. pageEncoding="UTF-8"%>
  3. <%@ page import="java.io.*,java.util.*" %>
  4. <!DOCTYPE html>
  5. <html>
  6. <head>
  7. <meta charset="utf-8">
  8. <title>W3xue教程(w3xue.com)</title>
  9. </head>
  10. <body>
  11. <h1>读取所有表单参数</h1>
  12. <table width="100%" border="1" align="center">
  13. <tr bgcolor="#949494">
  14. <th>参数名</th><th>参数值</th>
  15. </tr>
  16. <%
  17. Enumeration paramNames = request.getParameterNames();
  18.  
  19. while(paramNames.hasMoreElements()) {
  20. String paramName = (String)paramNames.nextElement();
  21. out.print("<tr><td>" + paramName + "</td>\n");
  22. String paramValue = request.getParameter(paramName);
  23. out.println("<td> " + paramValue + "</td></tr>\n");
  24. }
  25. %>
  26. </table>
  27. </body>
  28. </html>

以下是test.htm文件的内容:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="utf-8">
  5. <title>W3xue教程(w3xue.com)</title>
  6. </head>
  7. <body>
  8.  
  9. <form action="main.jsp" method="POST" target="_blank">
  10. <input type="checkbox" name="google" checked="checked" /> Google
  11. <input type="checkbox" name="W3xue" /> W3xue教程
  12. <input type="checkbox" name="taobao" checked="checked" />
  13. 淘宝
  14. <input type="submit" value="选择网站" />
  15. </form>
  16.  
  17. </body>
  18. </html>

现在我们通过浏览器访问 test.htm 文件提交数据,输出结果如下:

通过访问 http://localhost:8080/testjsp/test.html 提交表单数据到 main.jsp 文件,演示 Gif 图如下所示:

你可以尝试使用以上的JSP代码读取其它对象,如文本框,单选按钮或下拉框等等其他形式的数据。

转载本站内容时,请务必注明来自W3xue,违者必究。
 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号