小编给大家分享一下JSP如何实现HTML表单,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
大多数情况下,商业的网站都要有一些表单,比如说输入一下消费者的姓名啦,地址啦,或者敲一个词来用搜索引擎来查一下啦,或者市场人员从来访者处收集一些数据供参考什么的。
那些表单传回的数据怎么处理的?
来访者通过表单向JSP引擎输入了数据,并保存在了request对象中,那么接下来怎么办?
首先,JSP引擎把存放在request对象中的数据发到JSP页面指定的服务器端的组件(JavaBeans组件, servlet,或者enterprise bean),组件收到这些个数据以后,有可能再存这些数据到数据库或者其他的地方存放起来,同时,返回一个response对象给JSP引擎。JSP引擎再把response对象传给JSP页面,这时的页面包含了定义好的格式和从服务器端得到的数据。这时JSP引擎和Web服务器再发送一个整理好的完整的页面给客户,也就是这们在浏览器上看到的结果。客户和服务器间的通信协议可以用HTTP,当然也可以用其他的。
Request和Response对象在你制作的JSP原代码中起作用。到于request对象到底怎么用,我要在接下来详细的讲给你听。
如何创建表单,那么本JSP教程将给你展现一个步骤:
用HTML定义一些有代表性的表单做成一个JSP文件,然后用JSP标签在表单和服务器端对象(通常都用Bean)传递数据。一般情况下是这么干的:
1、 写JSP原文件,创建一些HTML的表单并命名。
2、 在Java文件里写Bean,定义属性,GET或者SET方法来配合已经被你指定好名字的表单。
3、 回到JSP原文件中,增加
4、 增加
5、 增加
6、 如果需要处理更多的用户数据,用request对象。
说了半天你可能看不懂,其实看一个例子你就懂了。
先看一个简单的hello的例子吧:
这段程序其实还是计算机程序里那个最经典的“hello,world”的程序,只不过呢,我使他挠了一点弯儿,使他看起来比较智能和复杂。首先你输入你的名字,然后Duke跟你说:“hello!”
JSP源码:
dukebanner.html ﹤table border="0" width="400" cellspacing="0" cellpadding="0"﹥ ﹤tr﹥ ﹤td height="150" width="150"﹥ ﹤/td﹥ ﹤td width="250"﹥ ﹤/td﹥ ﹤/tr﹥ ﹤tr﹥ ﹤td width="150"﹥ ﹤/td﹥ ﹤td align="right" width="250"﹥ ﹤img src="duke.waving.gif"﹥ ﹤/td﹥ ﹤/tr﹥﹤/table﹥﹤br﹥ 主JSP文件:hellouser.jsp ﹤%@ page import="hello.NameHandler" %﹥ ﹤jsp:useBean id="mybean" scope="page" class="hello.NameHandler" /﹥ ﹤jsp:setProperty name="mybean" property="*" /﹥ ﹤html﹥ ﹤head﹥﹤title﹥Hello, User﹤/title﹥﹤/head﹥ ﹤body bgcolor="#ffffff" background="background.gif"﹥ ﹤%@ include file="dukebanner.html" %﹥ ﹤table border="0" width="700"﹥ ﹤tr﹥﹤td width="150"﹥ ﹤/td﹥ ﹤td width="550"﹥ ﹤h2﹥My name is Duke. What's yours?﹤/h2﹥﹤/td﹥﹤/tr﹥ ﹤tr﹥﹤td width="150" ﹤/td﹥﹤td width="550"﹥ ﹤form method="get"﹥ ﹤input type="text" name="username" size="25"﹥ ﹤br﹥ ﹤input type="submit" value="Submit"﹥ ﹤input type="reset" value="Reset"﹥ ﹤/td﹥﹤/tr﹥ ﹤/form﹥ ﹤/table﹥ ﹤% If ( request.getParameter("username") != null ) { %﹥ ﹤% @ include file="response.jsp" %﹥ ﹤% } %﹥ ﹤/body﹥﹤/html﹥ 回应文件:response.jsp ﹤table border="0" width="700"﹥ ﹤tr﹥ ﹤td width="150"﹥ ﹤/td﹥ ﹤td width="550"﹥ ﹤h2﹥Hello, ﹤jsp:getProperty name="mybean" property="username" /﹥! ﹤/h2﹥ ﹤/td﹥ ﹤/tr﹥ ﹤/table﹥ 处理数据的Bean:(namehandler.java) package hello; public class NameHandler { private String username; public NameHandler() { username = null; } public void setUsername( String name ) { username = name; } public String getUsername() { return username; } }
建立HTML表单
一个HTML的窗分为三个部分:
使用GET和POST方法
用GET和POST方法可以发数据到服务器,在JSP程序中GET和POST方法可以发数据到Bean、servlet、或者其他服务器端的组件。
理论上说,GET是从服务器上请求数据,POST是发送数据到服务器。事实上,GET方法是把数据参数队列(query string)加到一个URL上,值和表单是一一对应的。比如说,name=John。在队列里,值和表单用一个&符号分开,空格用+号替换,特殊的符号转换成十六进制的代码。因为这一队列在URL里边,这样队列的参数就能看得到,可以被记录下来,或更改。通常GET方法还限制字符的大小。事实上POST方法可以没有时间限制的传递数据到服务器,用户在浏览器端是看不到这一过程的,所以POST方法比较适合用于发送一个保密的(比如信用卡号)或者比较大量的数据到服务器。
写Bean
如果JSP程序用到了Bean,你就得按照JavaBeans API的说明设计你的Bean。
记住下面两个关键部分。
如果JSP程序里用
如果JSP程序进而用
设置参数到Bean或者从里边取参数将在以后的部分详细介绍。
传数据到Bean
把HTML表单的数据传到Bean里需要两个工作:
◆ 用
◆在Bean里面用
***步用
第二步在Bean里面用
当然也可以定义成不同的名字,只要你不认为麻烦。谁让你记忆力好呢!
Request对象
用户输入的数据用来存放在Request对象里,用javax.servlet.HttpServletRequest来执行(你也可以用其他不同的工具来执行,但他们其实都是javax.servlet.HttpServletRequest的子集)
你也可以直接用scriptlet来直接访问Request对象。Scriptlet将在下一讲里边详细的讨论,现在你只需要知道他是用脚本语言写的一段放在<%> 之间的代码就足够了。在JSP 1.0中,你必须用JavaTM程序语言作为你的脚本语言。
你经常会用到如下方法处理Request对象:
◆方法
◆说明
◆执行结果
getRequest
Javax.servlet.jsp.PageContext
返回当前Request对象
getParameterNames
javax.servlet.ServletRequest
返回当前Request对象参数名
getParameterValues
javax.servlet.ServletRequest
返回当前Request对象参数值
你将会发现其他方法包括ServletRequest,HttpServletRequest或者其他任何ServletRequest的子集。
JSP引擎经常在scenes之后使用Request对象,即使你没有明确地在JSP文件中调用。
从Bean中调数据到JSP页面
一旦用户的数据被传到Bean,你就想重新得到数据,然后在JSP面页中显示出来。想达到这一步,你就得用到
﹤h2﹥Hello, ﹤jsp:getProperty name="mybean" property="username"/﹥! ﹤jsp:useBean﹥, ﹤jsp:setProperty﹥, 和 ﹤jsp:getProperty﹥标签必须相配,举个例子: hellouser.jsp: ﹤jsp:useBean id="mybean" scope="session" class="hello.NameHandler" /﹥ ﹤jsp:setProperty name="mybean" property="*" /﹥ response.jsp: ﹤h2﹥Hello, ﹤jsp:getProperty name="mybean" property="username"/﹥!
在这个例子里,标签被放在两个文件中,但是指定的名字都是相同的,如果不同的话,那么系统会返回一个错误信息。
如何运行例子
我用的是UNIX主机,如果你用windows,那么改相应的路径即可。
创建路径../jswdk-1.0/examples/jsp/tutorial/hellouser.
把文件background.gif, duke.waving.gif, dukebanner.html, hellousr.jsp和response.jsp文件放进去。
创建一个目录,../jswdk-1.0/examples/WEB-INF/jsp/beans/hello
把文件NameHandler.java和NameHandler.class放进去。
cd../jswdk-1.0然后startserver
打开浏览器http://计算机名:8080/examples/jsp/tutorial/hellouser/hellouser.jsp
以上是“JSP如何实现HTML表单”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。