在web应用中,如果直接将结果集 resultset rs,保存在session ,或者 reueest范围内,
可以将其传递到jsp,并显示,
但是要考虑到,如果同时查询的用户非常多,服务器的压力就非常大!
所以我本人建议用以下方法!
我觉得应该自己写一个标签。比如为 display.java然后将起定义为标签,对于你每次要显示的内容,其实你只要传递关键字,比如:sql 语句。就可以了!然后在你的页面中利用自定义的标签:比如为: <app:display> 就可以实现了!
以下是本人写的一个很简单的标签,在struts中!
displaytag.java—————————————————————–import javax.servlet.jsp.tagext.tagsupport;import java.io.ioexception;import javax.servlet.jsp.pagecontext;import javax.servlet.jsp.jspwriter;import javax.servlet.jsp.jspexception;import javax.servlet.http.httpsession;import java.sql.*;
public final class displaytag extends tagsupport { public int doendtag()throws jspexception{ userdao userdao=new userdao(); jspwriter out=pagecontext.getout(); httpsession session=pagecontext.getsession(); try{ string name="name"; string password="password"; string strsql=(string)session.getattribute("strsql"); resultset rs=userdao.display(strsql);
out.println("<table border=1>"); out.println("<tr>"); out.println("<th width=100>"+name+"</th>"); out.println("<th width=100>"+password+"</th>"); out.println("</tr>"); while(rs.next()){ out.println("<tr>"); out.println("<td>"+rs.getstring(name)+"</td>" ); out.println("<td>"+rs.getstring(password)+"</td>" ); out.println("</tr>"); } out.println("</table>"); } catch(exception e){} return super.doendtag(); }
}
app.tld——————————————————————–<?xml version="1.0" encoding="iso-8859-1" ?><!doctype taglib public "-//sun microsystems, inc.//dtd jsp tag library 1.2//en" "http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd"><taglib> <tlib-version>1.0</tlib-version> <jsp-version>1.2</jsp-version> <short-name>application tag library</short-name> <tag> <name>display</name> <tag-class>netregister.displaytag</tag-class> <body-content>empty</body-content> </tag></taglib>
web.xml—————————————————————添加以下内容: <taglib> <taglib-uri>/web-inf/app.tld</taglib-uri> <taglib-location>/web-inf/app.tld</taglib-location> </taglib>
displayaction.do—————————————————————— string strsql=new string("select * from yonghu"); httpsession session=httpservletrequest.getsession(); session.setattribute("strsql",strsql) ; return actionmapping.findforward("success") ;
如果不是用的struts,可以通过其他方法,实现这步!
display.jsp—————————————————————–<%@ page contenttype="text/html; charset=gbk" %><%@ taglib uri="/web-inf/app.tld" prefix="app" %><html><head><title>display</title></head><body bgcolor="#ffffff"><app:display /></body></html>
这样,在你的每一个jsp中,只要想输出查询结果,就只需要调用 <app:display/>就可以了!以上代码不一定完全正确,但是思想就是这样!而且在大的项目中,非常推崇!它体现了java 代码重用的思想,而且也使结果集的相关操作不直接暴露与用户,也实现了安全!供参考!
