当前页面: 开发资料首页 → JSP 专题 → 使用自定义标签,将结果集返回到jsp页面!(推荐方法)
摘要: 使用自定义标签,将结果集返回到jsp页面!(推荐方法)
在web应用中,如果直接将结果集 ResultSet rs,保存在session ,或者 reueest范围内,
可以将其传递到jsp,并显示,
但是要考虑到,如果同时查询的用户非常多,服务器的压力就非常大!
所以我本人建议用以下方法!
我觉得应该自己写一个标签。比如为 display.java
然后将起定义为标签,
对于你每次要显示的内容,其实你只要传递关键字,比如:sql 语句。就可以了!
然后在你的页面中利用自定义的标签:比如为:
以下是本人写的一个很简单的标签,在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" ?>
taglib
PUBLIC "-//Sun Microsystems, Inc.//DTD JSP Tag Library 1.2//EN"
"http://java.sun.com/dtd/web-jsptaglibrary_1_2.dtd">
<body-content>empty</body>
web.xml
---------------------------------------------------------------
添加以下内容:
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" %>
<head>
这样,在你的每一个jsp中,只要想输出查询结果,就只需要调用
就可以了!
以上代码不一定完全正确,但是思想就是这样!
而且在大的项目中,非常推崇!
它体现了java 代码重用的思想,而且也使结果集的相关操作不直接暴露与用户,也实现了安全!
供参考!