当前位置: 首页 > 图文教程 > 网络编程 > JSP > JSP由浅入深(10-2)

JSP
我认为JSP有问题(上)
我认为JSP有问题(下)
jsp“抓”网页代码的程序
关于在bean里面打印html的利弊看法
bean里面如何打印到html页面
jdbc3中的RowSet 接口规范
Apusic Application Server1.0中jsp源代码泄漏漏洞
Unify的eWave ServletExec拒绝服务漏洞
通过提交超长的GET请求导致IBM HTTP Server远程溢出
在HTTP请求中添加特殊字符导致暴露JSP源代码文件
Resin 1.2 重要源代码暴露漏洞
多中WEB服务器的通用JSp源代码暴露漏洞
Tomcat 暴露JSP文件内容
IBM WebSphere Application Server 暴露JSP文件内容
JRun 2.3.x 范例文件暴露站点安全信息
BEA WebLogic 暴露源代码漏洞
IBM WebSphere Application Server 3.0.2 存在暴露源代码漏洞
Tomcat 3.1 存在暴露网站路径问题
Sun Java Web Server 能让攻击者远程执行任意命令
Netscape 修复 JAVA 安全漏洞

JSP由浅入深(10-2)


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-09-04   浏览: 65 ::
收藏到网摘: n/a

一旦你定义了这个类,再编译它,并且将它放置于网络服务器的类路径中。这个服务器同样要定义一个特殊的目录来放置bean类。如果你是使用Blazix你可以将它们放置到“classes”目录中。如果你必须改变类路径并且服务器正在运行,那么网络服务器就必须停止并重新启动。

下面我们来修改一下“SaveName.jsp”以使用bean来收集数据:

<jsp:useBean id="user" class="UserData" scope="session"/>

<jsp:setProperty name="user" property="*"/>


<HTML>


<BODY>


<A HREF="NextPage.jsp">Continue</A>


</BODY>


</HTML>



这里所有我们需要作的事情是增加一个jsp:useBean标志以及jsp:setProperty标志。这个useBean标志是在session中查找“UserData”的实例。如果实例被找到了,它就将更新旧的实例;如果实例没有被找到,它就将创建一个UserData新的实例(UserData的实例被称为bean),然后将它放置于session中。而setProperty标志会自动收集输入的数据,并匹配bean方法的名字,在将数据放置于bean中。

下面修改NextPage.jsp以从bean取出数据:

<jsp:useBean id="user" class="UserData" scope="session"/>

<HTML>


<BODY>


You entered<BR>


Name: <%= user.getUsername() %><BR>


Email: <%= user.getEmail() %><BR>


Age: <%= user.getAge() %><BR>


</BODY>


</HTML>



这里要注意useBean标签被重复使用了。这个bean是作为类“UserData”的变量的。由用户键入的数据都被收集在bean中。我们可以不需要“SaveName.jsp”,“GetName.html”的目标就是“NextPage.jsp”,并且只要我们增加一个jsp:setProperty 标志数据同样有效。在下一个教程中,我们要使用SaveName.jsp作为一个错误处理并自动连接到NextPage.jsp上,换句话说,它叫用户校正错误的数据。

本节教程的辅助练习为:A)编写一个JSP/HTML使得用户可以键入系统属性的名字并将显示有System.getProperty返回数值。B)回到我们刚才手动修改的boolean变量,这时我们不用boolean变量,而是将来自HIDDEN表单区域的变量设置为true或者false。