Java

本类阅读TOP10

·使用MyEclipse开发Struts框架的Hello World!(录像1)
·hibernate配置笔记
·AOP编程入门--Java篇
·linux下Tomcat 5.0.20 与 Apache 2 安装/集成/配置
·在win2003下整合了整合Tomcat5.5+ apache_2.0.53+ mod_jk_2.0.47.dll
·构建Linux下IDE环境--Eclipse篇
·Jsp 连接 mySQL、Oracle 数据库备忘(Windows平台)
·ASP、JSP、PHP 三种技术比较
·Tomcat5.5.9的安装配置
·AWT GUI 设计笔记(二)

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
使用自定义标签,将结果集返回到jsp页面!(推荐方法)

作者:未知 来源:月光软件站 加入时间:2005-5-13 月光软件站

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




相关文章

相关软件