JSP 表单处理

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


GET 方法

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

  1. //www.w3cschool.cn/hello?key1=value1&key2=value2

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

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


POST 方法

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

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

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


JSP 读取表单数据

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

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

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

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


使用URL的 GET 方法实例

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

  1. http://localhost:8080/main.jsp?first_name=ZARA&last_name=ALI

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

  1. <html>
  2. <head>
  3. <title>Using GET Method to Read Form Data</title>
  4. </head>
  5. <body>
  6. <center>
  7. <h1>Using GET Method to Read Form Data</h1>
  8. <ul>
  9. <li><p><b>First Name:</b>
  10. <%= request.getParameter("first_name")%>
  11. </p></li>
  12. <li><p><b>Last Name:</b>
  13. <%= request.getParameter("last_name")%>
  14. </p></li>
  15. </ul>
  16. </body>
  17. </html>

接下来我们通过浏览器访问http://localhost:8080/main.jsp?first_name=ZARA&last_name=ALI 输出结果如下所示:

  1. Using GET Method to Read Form Data
  2. First Name: ZARA
  3.  
  4. Last Name: ALI

使用表单的 GET 方法实例

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

  1. <html>
  2. <body>
  3. <form action="main.jsp" method="GET">
  4. First Name: <input type="text" name="first_name">
  5. <br />
  6. Last Name: <input type="text" name="last_name" />
  7. <input type="submit" value="Submit" />
  8. </form>
  9. </body>
  10. </html>

将以上HTML代码保存到Hello.htm文件中。 将该文件放置于/webapps/ROOT 目录下。 通过访问http://localhost:8080/Hello.htm,输出界面如下所示:

在"First Name" 与 "Last Name"两个表单中填入信息,并点击"Submit"按钮,它将输出结果。


使用表单的 POST 方法实例

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

main.jsp文件代码:

  1. <html>
  2. <head>
  3. <title>Using GET and POST Method to Read Form Data</title>
  4. </head>
  5. <body>
  6. <center>
  7. <h1>Using GET Method to Read Form Data</h1>
  8. <ul>
  9. <li><p><b>First Name:</b>
  10. <%= request.getParameter("first_name")%>
  11. </p></li>
  12. <li><p><b>Last Name:</b>
  13. <%= request.getParameter("last_name")%>
  14. </p></li>
  15. </ul>
  16. </body>
  17. </html>

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

  1. <html>
  2. <body>
  3. <form action="main.jsp" method="POST">
  4. First Name: <input type="text" name="first_name">
  5. <br />
  6. Last Name: <input type="text" name="last_name" />
  7. <input type="submit" value="Submit" />
  8. </form>
  9. </body>
  10. </html>

通过浏览器访问 http://localhost:8080/Hello.htm,输出如下:

在"First Name" 与 "Last Name"两个表单中填入信息,并点击"Submit"按钮,它将输出结果。


传递 Checkbox 数据到JSP程序

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

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

  1. <html>
  2. <body>
  3. <form action="main.jsp" method="POST" target="_blank">
  4. <input type="checkbox" name="maths" checked="checked" /> Maths
  5. <input type="checkbox" name="physics" /> Physics
  6. <input type="checkbox" name="chemistry" checked="checked" />
  7. Chemistry
  8. <input type="submit" value="Select Subject" />
  9. </form>
  10. </body>
  11. </html>

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

  1. <html>
  2. <head>
  3. <title>Reading Checkbox Data</title>
  4. </head>
  5. <body>
  6. <center>
  7. <h1>Reading Checkbox Data</h1>
  8. <ul>
  9. <li><p><b>Maths Flag:</b>
  10. <%= request.getParameter("maths")%>
  11. </p></li>
  12. <li><p><b>Physics Flag:</b>
  13. <%= request.getParameter("physics")%>
  14. </p></li>
  15. <li><p><b>Chemistry Flag:</b>
  16. <%= request.getParameter("chemistry")%>
  17. </p></li>
  18. </ul>
  19. </body>
  20. </html>

以上实例输出结果为:


读取所有表单参数

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

一旦我们有了一个Enumeration(枚举),我们就可以调用hasMoreElements()方法来确定何时停止使用和nextElement()方法来获得每个参数的名称。

  1. <%@ page import="java.io.*,java.util.*" %>
  2. <html>
  3. <head>
  4. <title>HTTP Header Request Example</title>
  5. </head>
  6. <body>
  7. <center>
  8. <h2>HTTP Header Request Example</h2>
  9. <table width="100%" border="1" align="center">
  10. <tr bgcolor="#949494">
  11. <th>Param Name</th><th>Param Value(s)</th>
  12. </tr>
  13. <% Enumeration paramNames = request.getParameterNames(); while(paramNames.hasMoreElements()) { String paramName = (String)paramNames.nextElement(); out.print("<tr><td>" + paramName + "</td>\n");
  14. String paramValue = request.getHeader(paramName);
  15. out.println("<td> " + paramValue + "</td></tr>\n");
  16. }
  17. %>
  18. </table>
  19. </center>
  20. </body>
  21. </html>

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

  1. <html>
  2. <body>
  3. <form action="main.jsp" method="POST" target="_blank">
  4. <input type="checkbox" name="maths" checked="checked" /> Maths
  5. <input type="checkbox" name="physics" /> Physics
  6. <input type="checkbox" name="chemistry" checked="checked" /> Chem
  7. <input type="submit" value="Select Subject" />
  8. </form>
  9. </body>
  10. </html>

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

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

JSP 表单处理向服务器提交信息的更多相关文章

  1. JSP表单提交 与 接受显示

    Demo01.jsp 提交表单输入的信息至 Demo02.jsp方法一 1 <%@ page language="java" contentType="text/h ...

  2. struts2 jsp表单提交后保留表单中输入框中的值 下拉框select与input

    原文地址:struts2 jsp表单提交后保留表单中输入框中的值 下拉框select与input jsp页面 1     function dosearch() {2         if ($(&q ...

  3. JSP表单提交与接收

    JSP表单提交与接收 在Myeclipse中新建web project,在webroot中新建userRegist1.jsp,代码如下 <%@ page contentType="te ...

  4. JSP 表单处理

    JSP 表单处理 我们在浏览网页的时候,经常需要向服务器提交信息,并让后台程序处理.浏览器中使用 GET 和 POST 方法向服务器提交数据. GET 方法 GET方法将请求的编码信息添加在网址后面, ...

  5. JSP-Runoob:JSP 表单处理

    ylbtech-JSP-Runoob:JSP 表单处理 1.返回顶部 1. JSP 表单处理 我们在浏览网页的时候,经常需要向服务器提交信息,并让后台程序处理.浏览器中使用 GET 和 POST 方法 ...

  6. jQuery form插件的使用--用 formData 参数校验表单,验证后提交(简单验证).

    Form Plugin API 里提供了很多有用的方法可以让你轻松的处理表单里的数据和表单的提交过程. 测试环境:部署到Tomcat中的web项目. 一.引入依赖js <script src=& ...

  7. 只有设置了 name 属性的表单元素才能在提交表单时传递它们的值

    $(function () { var wait = $("<img src=\"\" alt=\"正在上传\"/>"); $( ...

  8. from表单的分向提交

    一:需求: 思路:document.form.action,表单分向提交,javascript提交表单同一个表单可以根据用户的选择,提交给不同的后台处理程序.即,表单的分向提交.如,在编写论坛程序时, ...

  9. 第一百五十九节,封装库--JavaScript,表单序列化结合ajax提交数据

    封装库--JavaScript,表单序列化结合ajax提交数据 封装库,表单序列化方法 /** xu_lie_biao_dan()方法,表单序列化方法,将自动获取指定表单里面的各项字段name值和va ...

随机推荐

  1. 把我的漫画浏览器后台程序迁移到GAE上了

    这两天看了一下Python和GAE相关资料,作为练手,把我以前写的Windows 8下看漫画的程序的后台解析算法迁移到了GAE上了. 之前由于没有后台服务器,很多东西在本地实现起来不是很方便,现在拿G ...

  2. Android并发编程

    Android的并发编程,即多线程开发,而Android的多线程开发模型也是源于Java中的多线程模型.所以本篇也会先讲一些Java中的多线程理念,再讲解具体涉及的类,最后深入Android中的并发场 ...

  3. Android反编译调试源码

    Android反编译调试源码 1. 反编译得到源码 直接在windows 命令行下输入命令java -jar apktool_2.0.0.jar d -d 小米运动_1.4.641_1058.apk ...

  4. Javascript -- document的createDocumentFragment()方法

    在<javascript高级程序设计>一书的6.3.5:创建和操作节点一节中,介绍了几种动态创建html节点的方法,其中有以下几种常见方法: · crateAttribute(name): ...

  5. JAVA常见算法题(十六)

    package com.xiaowu.demo; //猴子吃桃问题:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾,又多吃了一个: //第二天早上又将剩下的桃子吃掉一半,而且又多吃了一个. //以后 ...

  6. 2017.7.18 windows下ELK环境搭建

    参考来自:Windows环境下ELK平台的搭建 另一篇博文:2017.7.18 linux下ELK环境搭建 0 版本说明 因为ELK从5.0开始只支持jdk 1.8,但是项目中使用的是JDK 1.7, ...

  7. 阻止右键菜单(阻止默认事件)&&跟随鼠标移动(大图展示)&&自定义右键菜单

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  8. VENOM cve-2015-3456 Qemu 虚拟机逃逸漏洞POC

    #include <sys/io.h> int main() { int i ; iopl(3); outb(0x8e, 0x3f5); outb(0x41, 0x3f5); outb(0 ...

  9. Jmeter返回org.apache.http.NoHttpResponseException: The target server failed to respond解决办法

    1.问题:这段时间使用jmeter压测时(300个请求,持续压300s,加速期10s),压力平稳时偶然错误,部分请求失败事务报错信息如下 org.apache.http.NoHttpResponseE ...

  10. windows 配置squid反向代理服务器

    发现Window版本的Squid 和 Linux 配置有点不一样 一.配置squid\etc目录1.squid.conf.default 拷贝一份重新命名为squid.conf2.cachemgr.c ...