簡單標籤的開發咱們只要實現Tag接口便可,爲了簡單起見能夠直接繼承實現了此接口的TagSupport類java
1 建立自定義標籤類web
public class UserInfoTag extends TagSupport {緩存
private UserInfo user;tomcat
@Overridejsp
public int doStartTag() throws JspException {ide
try {ui
JspWriter out = this.pageContext.getOut();this
if(user == null) {spa
out.println("No UserInfo Found...");xml
return SKIP_BODY;
}
out.println("<table width='500px' border='1' align='center'>");
out.println("<tr>");
out.println("<td width='20%'>Username:</td>");
out.println("<td>" + user.getUserName() + "</td>");
out.println("</tr>");
out.println("<tr>");
out.println("<td>Age:</td>");
out.println("<td>" + user.getAge() + "</td>");
out.println("</tr>");
out.println("<tr>");
out.println("<td>Email:</td>");
out.println("<td>" + user.getEmail() + "</td>");
out.println("</tr>");
out.println("</table>");
} catch(Exception e) {
throw new JspException(e.getMessage());
}
return SKIP_BODY;
}
@Override
public int doEndTag() throws JspException {
return EVAL_PAGE;
}
@Override
public void release() {
super.release();
this.user = null;
}
//getter and setters
public UserInfo getUser() {
return user;
}
public void setUser(UserInfo user) {
this.user = user;
}
}
2 在Web-Inf建立標籤庫描述文件.tdl(Tag Library Description)
<?xml version="1.0" encoding="UTF-8"?>
<taglib version="2.0" xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee web-jsptaglibrary_2_0.xsd">
<tlib-version>1.0</tlib-version>
<jsp-version>2.0</jsp-version>
<short-name>cc</short-name>
<uri>/mytaglib</uri>
<tag>
<name>showUserInfo</name>
<tag-class>com.mytags.UserInfoTag</tag-class>
<body-content>empty</body-content>
<attribute>
<name>user</name>
<required>false</required>
<rtexprvalue>true</rtexprvalue>
</attribute>
</tag>
</taglib>
3 配置web.xml
<jsp-config>
<taglib>
<taglib-uri>/mytaglib</taglib-uri>
<taglib-location>/WEB-INF/mytaglib.tld</taglib-location>
</taglib>
</jsp-config>
4 在須要使用此標籤的jsp頁面頭部引入
<%@ taglib uri="/mytaglib" prefix="cc"%>
5 使用(參照上面的使用步驟)
此致,一個簡單的JSP標籤開發完成
標籤類說明:
咱們建立的UserInfoTag類繼承了TagSupport類,而它又實現了Tag接口,Tag接口的生命週期由其所在的容器控制,以下圖:
setPageContext() 將所在jsp頁面的pageContext注入進來,目的是爲了在後面的方法中能夠訪問到jsp頁面對象的pageContext屬性
setParent() 設置此標籤的父標籤
setAttribute() 將標籤中的屬性注入到此class的屬性,不須要本身實現但要提供屬性的get與set方法
doStartTag() 在開始標籤屬性設置後調用,若是返回SKIP_BODY則忽略標籤之中的內容,若是返回EVAL_BODY_INCLUDE則將標籤體的內容進行輸出
doEndTag() 在結束標籤以前調用,返回SKIP_PAGE跳過整個jsp頁面後面的輸出,返回EVAL_PAGE執行頁面餘下部分
release() 生命週期結束時調用
特別說明:在tomcat4.1以後的版本中默認開啓了標籤緩衝池(websphere和weblogic並不會這麼作),因此執行完標籤後並不會執行release()方法(_jspDestroy()時才釋放),也就是說同一個jsp頁面自定義標籤無論使用多少次只會存在一個實例,但也並非每個標籤都會爲其建立一個緩衝池,要根據參數來判斷,例如:
<cc:UserInfoTag user=」…」 />
<cc:UserInfoTag />
上面例子中因爲參數不一樣就會建立兩個標籤緩衝池。
這個問題能夠經過設定tomcat的配置文件加以解決:
在%tomcat%\conf\web.xml加入enablePooling參數,並設置爲false(不緩存自定義標籤)。
<init-param>
<param-name>enablePooling</param-name>
<param-value>false</param-value>
</init-param>
清空%tomcat%\conf\目錄
-------------------------------------------------------------------------------------------------------------------------------
TagSupport類已經爲咱們實現並擴展了一些方法(好比在上述方法中咱們能夠直接使用pageContext對象,調用父標籤getParent()等),因此通常狀況下咱們只需重寫doStartTag(),doEndTag() 便可
TLD文件說明:
<!--版本號-->
<tlib-version>1.0</tlib-version>
<jsp-version>2.0</jsp-version>
<short-name>cc</short-name>
<tag>
<!—指定標籤名 -->
<name>showUserInfo</name>
<!—指定標籤類文件的全路徑 -->
<tag-class>com.mytags.UserInfoTag</tag-class>
<!--若是不須要標籤體則設置empty,反之設定jsp -->
<body-content>empty</body-content>
<!—設定屬性(若是有的話) -->
<attribute>
<!—指定標籤名 -->
<name>user</name>
<!—是不是必須,若是非必須沒設置則爲空 -->
<required>false</required>
<rtexprvalue>true</rtexprvalue><!—是否可在屬性中使用表達式 -->
</attribute>
</tag>
Web.xml文件說明:
<jsp-config>
<taglib>
<!--
標籤庫的uri路徑
即jsp頭文件中聲明<%@ taglib uri="/mytaglib" prefix="cc"%>
的uri
-->
<taglib-uri>/mytaglib</taglib-uri>
<!—tld文件所在的位置-->
<taglib-location>/WEB-INF/mytaglib.tld</taglib-location>
</taglib>
</jsp-config>