使用自定义标签,将结果集返回到jsp页面!(推荐方法)

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

在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 代码重用的思想,而且也使结果集的相关操作不直接暴露与用户,也实现了安全!

供参考!

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航