使用自訂標籤,將結果集返回到jsp頁面!(推薦方法)
來源:互聯網
上載者:User
js|頁面
在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 代碼重用的思想,而且也使結果集的相關操作不直接暴露與使用者,也實現了安全!供參考!