JSP表单处理

转载声明:http://www.runoob.com/jsp/jsp-form-processing.html


JSP表单处理

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

GET方法

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

http://www.runoob.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类型.
  • getParameterNames():该方法可以取得所有变量的名称.该方法返回一个Emumeration.
使用URL的GET方法实例

以下是个简单的url,并使用get方法传递数据:

http://localhost:8080/testjsp/main.jsp?name=菜鸟教程&url=http://ww.runoob.com

testjsp是项目名称.

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

<%@ 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>菜鸟教程(runoob.com)</title>
</head>
<body>
<h1>使用 GET 方法读取数据</h1>
<ul>
<li><p><b>站点名:</b>
   <%= request.getParameter("name")%>
</p></li>
<li><p><b>网址:</b>
   <%= request.getParameter("url")%>
</p></li>
</ul>
</body>
</html>

接下来我们通过浏览器访问:
http://localhost:8080/testjsp/main.jsp?name=菜鸟教程&url=http://ww.runoob.com

输出结果如下所示:
输出结果


使用表单的GET实例

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

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body>

<form action="main.jsp" method="GET">
站点名: <input type="text" name="name">
<br />
网址: <input type="text" name="url" />
<input type="submit" value="提交" />
</form>

</body>
</html>

将以上代码保存到test.html文件中,将此文件放到main.jsp的同等级目录下.
通过访问:

http://localhost:8080/testjsp/test.html

提交表单到main.jsp文件,演示gif图如下所示:
这里写图片描述
在站点名和网址两个表单里填写信息并点击提交按钮,它将输出结果.


使用表单的POST方法实例

修改main.jsp文件和test.html文件内容
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>菜鸟教程(runoob.com)</title>
</head>
<body>
<h1>使用 POST 方法读取数据</h1>
<ul>
<li><p><b>站点名:</b>
<%
// 解决中文乱码的问题
String name = new String((request.getParameter("name")).getBytes("ISO-8859-1"),"UTF-8");
%>
   <%=name%>
</p></li>
<li><p><b>网址:</b>
   <%= request.getParameter("url")%>
</p></li>
</ul>
</body>
</html>

代码中我们使用 new String((request.getParameter(“name”)).getBytes(“ISO-8859-1”),”UTF-8”)来转换编码,防止中文乱码的发生。
以下是test.html修改后的代码:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body>

<form action="main.jsp" method="POST">
站点名: <input type="text" name="name">
<br />
网址: <input type="text" name="url" />
<input type="submit" value="提交" />
</form>

</body>
</html>

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

传递Chexckbox数据到jsp页面

复选框checkbox可以传递一个或多个数据.
以下是一个简单的HTML代码,并将代码保存到test.html文件中:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body>

<form action="main.jsp" method="POST" target="_blank">
<input type="checkbox" name="google" checked="checked" /> Google
<input type="checkbox" name="runoob"  /> 菜鸟教程
<input type="checkbox" name="taobao" checked="checked" /> 
                                                淘宝
<input type="submit" value="选择网站" />
</form>

</body>
</html>

以下为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>菜鸟教程(runoob.com)</title>
</head>
<body>
<h1>从复选框中读取数据</h1>
<ul>
<li><p><b>Google 是否选中:</b>
   <%= request.getParameter("google")%>
</p></li>
<li><p><b>菜鸟教程是否选中:</b>
   <%= request.getParameter("runoob")%>
</p></li>
<li><p><b>淘宝是否选中:</b>
   <%= request.getParameter("taobao")%>
</p></li>
</ul>
</body>
</html>

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

读取所有表单参数

以下我们将使用HttpServletRequest的getPatameterNames()方法来读取所有的表单参数,该方法可以取得所有参数的名称,返回值是个枚举.
一旦我们有了一个 Enumeration(枚举),我们就可以调用hasMoreElements() 来确定是否还有元素,以及使用nextElement()来获得每个参数的名称.

<%@ 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>菜鸟教程(runoob.com)</title>
</head>
<body>
<h1>读取所有表单参数</h1>
<table width="100%" border="1" align="center">
<tr bgcolor="#949494">
<th>参数名</th><th>参数值</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.html文件的内容:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>菜鸟教程(runoob.com)</title>
</head>
<body>

<form action="main.jsp" method="POST" target="_blank">
<input type="checkbox" name="google" checked="checked" /> Google
<input type="checkbox" name="runoob"  /> 菜鸟教程
<input type="checkbox" name="taobao" checked="checked" /> 
                                                淘宝
<input type="submit" value="选择网站" />
</form>

</body>
</html>

过访问 http://localhost:8080/testjsp/test.html 提交表单数据到 main.jsp 文件,演示 Gif 图如下所示:
这里写图片描述
可以使用以上的代码读取其他对象,如文本框,单选按钮或者下拉框等等其它形式的数据.

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值