当前位置:首页 > JSP教程 > JSP基础教程

JSP表单处理

在本章中,我们将讨论jsp中的表单处理。当需要从浏览器将一些传递到web服务器的信息处理并最终传递到后端程序时,可能会遇到一些情况。浏览器使用两种方法将此信息传递到web服务器。 这些方法是分别是:get方法和post方法。

表格数据处理方法

现在我们来介绍表单处理中的方法。

get方法

get方法将附加的用户数据信息编码并发送到请求的页面。页面和编码信息被分隔符 - ?字符分隔开,如下 -

http://www.51frw.cn/hello?key1=value1&key2=value2

get方法是将信息从浏览器传递到web服务器的默认方法,它生成一个长字符串,出现在浏览器的地址栏框中。如果有密码或其他敏感信息传递到服务器,建议最好不要使用get方法。

get方法具有大小限制:请求字符串中最多只能有1024个字符。

该信息使用query_string标头传递,并且可以通过query_string环境变量进行访问,该变量可以使用getquerystring()和getparameter()方法来处理请求对象。

post方法

通常更可靠的将信息传递给后端程序是使用post方法。

post方法与get方法将信息打包的方式完全相同,而不是将使用?作为分隔符组成文本字符串并在url中发送。 此消息以标准输入的形式发送到后端程序,可以解析并用于处理。

jsp使用getparameter()方法处理这种类型的请求,以读取简单参数的值,而getinputstream()方法来读取客户端的二进制数据流。

使用jsp读取表单数据

jsp根据情况使用以下方法自动处理表单数据 -

  • getparameter() - 调用request.getparameter()方法来获取表单参数的值。
  • getparametervalues() - 如果参数出现多次并返回多个值(例如复选框),则调用此方法。
  • getparameternames() - 如果想要当前请求中的所有参数的完整列表,则调用此方法。
  • getinputstream() - 调用此方法读取客户端的二进制数据流。

get方法使用url示例

为了方便演示,打开eclipse创建一个项目:formprocessing 。其完整的目录结构如下所示 -

以下url将使用get方法将两个值传递给helloform程序。

http://localhost:8080/formprocessing/main.jsp?username=maxsu&email=maxsu@51frw.com

以下是jsp程序(main.jsp )处理由web浏览器请求给出的输入。这里使用getparameter()方法,这样很容易访问传递的信息 -

文件: main.jsp -

<%@ page language="java" contenttype="text/html; charset=utf-8"
    pageencoding="utf-8"%>
<!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title>使用get方法读取url请求数据</title>
</head>
<body>
    <h1>使用get方法读取url请求数据</h1>
    <ul>
        <li><p>
                <b>username:</b>
                <%=request.getparameter("username")%>
            </p></li>
        <li><p>
                <b>email:</b>
                <%=request.getparameter("email")%>
            </p></li>
    </ul>
</body>
</html>

现在打开浏览器,在地址栏中输入:http://localhost:8080/formprocessing/main.jsp?username=maxsu&email=maxsu@51frw.com 。 这将产生以下结果 -

get方法处理表单示例

以下是使用html form和提交按钮传递两个值的示例。这里使用hello.html来处理这个输入。

文件:hello.html -

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>用户表单处理</title>
</head>
<body>
    <div style="margin: auto; width: 80%;">
        <form action="main.jsp" method="get">
            用户名: <input type="text" name="username">  email: <input
                type="text" name="email" /> <input type="submit" value="提交" />
        </form>
    </div>
</body>
</html>

现在打开浏览器,在地址栏中输入:http://localhost:8080/formprocessing/hello.html 。 这将产生以下结果 -

填入信息,提交表单,看到以下结果 -

post方法处理表单示例

在上面的jsp中进行一些修改来处理get和post方法。以下是使用get或post方法处理由web浏览器给出的输入jsp程序:post.jsp。

因为上述jsp代码实现没有变化,但是传递参数的方法需要改变为post,也不是将二进制数据被传递给jsp程序。文件处理相关概念将在单独的章节中进行说明,我们需要读取二进制数据流。

文件:post.jsp -

<%@ page language="java" contenttype="text/html; charset=utf-8"
    pageencoding="utf-8"%>
<!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title>使用post方读取请求数据</title>
</head>
<body>
    <h1>使用post方读取表单数据</h1>
    <ul>
        <li><p>
                <b>username:</b>
                <%=request.getparameter("username")%>
            </p></li>
        <li><p>
                <b>email:</b>
                <%=request.getparameter("email")%>
            </p></li>
    </ul>
</body>
</html>

以下是post.html文件的内容 -

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>用户表单处理</title>
</head>
<body>
    <div style="margin: auto; width: 80%;">
        <form action="post.jsp" method="post">
            用户名: <input type="text" name="username">  email: <input
                type="text" name="email" /> <input type="submit" value="提交" />
        </form>
    </div>
</body>
</html>

部署运行以上项目,然后打开浏览器访问url: http://localhost:8080/formprocessing/post.html ,看到结果如下 -

分别填写用户名和email,然后提交表单,结果如下所示 -

jsp程序处理复选框数据

当表单数据需要多个选项时,可使用复选框。以下是具有两个复选框的表单的示例html代码:checkbox.html 。

文件:checkbox.html -

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>复选框数据处理示例</title>
</head>
<body>
    <div style="margin: auto; width: 80%;">
        <h2>选择课程(多选)</h2>
        <form action="checkbox.jsp" method="post">
            <input type="checkbox" name="maths" checked="checked" /> 数学 <input
                type="checkbox" name="physics" /> 物理 <input type="checkbox"
                name="chemistry" checked="checked" /> 化学 <input
                type="submit" value="选择提交" />
        </form>
    </div>
</body>
</html>

文件:checkbox.jsp -

<%@ page language="java" contenttype="text/html; charset=utf-8"
    pageencoding="utf-8"%>
<!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title>复选框数据处理示例</title>
</head>
<body>
    <div style="margin: auto; width: 80%;">
        <h2>复选框数据处理示例</h2>
        <ul>
            <li><p>
                    <b>数学:</b>
                    <%=request.getparameter("maths")%>
                </p></li>
            <li><p>
                    <b>物理:</b>
                    <%=request.getparameter("physics")%>
                </p></li>
            <li><p>
                    <b>化学:</b>
                    <%=request.getparameter("chemistry")%>
                </p></li>
        </ul>
    </div>
</body>
</html>

部署运行以上项目,然后打开浏览器访问url: http://localhost:8080/formprocessing/checkbox.html ,看到结果如下 -

选择对应选项然后提交,上述程序将产生以下结果 -

读取所有表单参数

以下是使用httpservletrequest的getparameternames()方法读取所有可用的表单参数的通用示例。此方法返回一个枚举,其中包含未指定顺序的参数名称。

当有了这个枚举后,就可以使用标准方式循环枚举,使用hasmoreelements()方法来确定何时停止并使用nextelement()方法来获取每个参数名称。

文件:allformparameters.html -

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>获取所有表单数据</title>
<!-- file: allformparameters.jsp -->
</head>
<body>
<body>
    <div style="margin: auto; width: 80%;">
        <h2>选择课程(多选)</h2>
        <form action="allformparameters.jsp" method="post">
            <input type="checkbox" name="maths" checked="checked" value="math"/> 数学 <input
                type="checkbox" name="physics" value="phys"/> 物理 <input type="checkbox"
                name="chemistry" checked="checked" value="chem"/> 化学 <input type="submit"
                value="选择提交" />
        </form>
    </div>
</body>
</html>

文件:allformparameters.jsp -

<%@ page language="java" contenttype="text/html; charset=utf-8"
    pageencoding="utf-8"%>
<%@ page import="java.io.*,java.util.*"%>
<!doctype html public "-//w3c//dtd html 4.01 transitional//en" "http://www.w3.org/tr/html4/loose.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=utf-8">
<title>获取所有表单数据</title>
</head>
<body>
    <div style="margin: auto; width: 80%;">
        <h2>获取所有表单数据</h2>
        <table width="100%" border="1" align="center">
            <tr bgcolor="#949494">
                <th>param name</th>
                <th>param value(s)</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>
    </div>
</body>
</html>

部署运行以上项目,然后打开浏览器访问url: http://localhost:8080/formprocessing/allformparameters.html ,看到结果如下 -

选择对应选项然后提交,上述程序将产生以下结果 -



【说明】本文章由站长整理发布,文章内容不代表本站观点,如文中有侵权行为,请与本站客服联系(QQ:254677821)!