JSP自定义标签案例分析

本文为大家介绍了JSP自定义标签的案例,供大家参考,具体内容如下

案例一:实现一个基本防盗链标签

1. 标签处理类

public class MyReferer extends BodyTagSupport {
  private String site;
  private String back;
  public String getSite() {
    return site;
  }
  public void setSite(String site) {
    this.site = site;
  }
  public String getBack() {
    return back;
  }
  public void setBack(String back) {
    this.back = back;
  }
  public int doEndTag() throws JspException {
    // 获取JSP上下文环境对象
    PageContext pageContext = this.pageContext;
    // 获取到request对象
    HttpServletRequest request = (HttpServletRequest)pageContext.getRequest();
    // 判断
    String header = request.getHeader("referer");
    if(header != null && header.startsWith(getSite())){
      // 执行后续的页面
      return Tag.EVAL_PAGE;
    }else{
      // 页面的重定向
      HttpServletResponse response = (HttpServletResponse)pageContext.getResponse();
      try {
        response.sendRedirect(getBack());
      } catch (IOException e) {
        e.printStackTrace();
      }
      // 不执行
      return Tag.SKIP_PAGE;
    }
  }
}

2. 描述文件

<?xml version="1.0" encoding="UTF-8"?>
<taglib
  xmlns="http://java.sun.com/xml/ns/javaee"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd"
  version="2.1">
 <!-- 2. 编写标签库描述文件 -->
 <tlib-version>1.0</tlib-version>
 <short-name>jnb</short-name>
  <tag>
  <name>referer</name>
  <tag-class>cn.itcast.custom.MyReferer</tag-class>
  <body-content>empty</body-content>
   <attribute>
    <name>site</name>
    <required>true</required>
    <rtexprvalue>true</rtexprvalue>
  </attribute>
   <attribute>
    <name>back</name>
    <required>true</required>
    <rtexprvalue>true</rtexprvalue>
  </attribute>
 </tag>
</taglib>

3. 引入和使用

<%@taglib uri="/WEB-INF/referer.tld" prefix="my"%>
  <my:referer site=http://localhost:8080/day11/list.jsp
 back="/day11/list.jsp"/>

JSP2.0自定义标签

---| SimpleTag 接口

定义了标签处理类的生命周期方法。doTag()

-----| SimpleTagSupport 类

全部实现了SimpleTag接口的方法,因此后面我们只需要继承并重写该类即可。

案例二:实现自己的if….else标签

目标:

 <%@taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c" %>
  <c:choose>
   <c:when test="<%= 12>1 %>">
      大于
   </c:when>
   <c:otherwise>
      小于
   </c:otherwise>
  </c:choose>

分析:

1. ChooseTag.java,必须定义一个标记字段属性

public class ChooseTag extends SimpleTagSupport {
  private boolean tag = true;
  public boolean isTag() {
    return tag;
  }
  public void setTag(boolean tag) {
    this.tag = tag;
  }
  // 遇到标签自动执行
  public void doTag() throws JspException, IOException {
    // 获取标签体对象
    JspFragment body = this.getJspBody();
    // 执行标签体
    body.invoke(null);
    super.doTag();
  }
}

2. WhenTag.java

public class WhenTag extends SimpleTagSupport {
  private boolean test;
  public boolean isTest() {
    return test;
  }
  public void setTest(boolean test) {
    this.test = test;
  }
  // 遇到标签自动执行
  public void doTag() throws JspException, IOException {
    // 获取父元素
    ChooseTag choose = (ChooseTag)this.getParent();
    // 获取父元素的标记变量值
    boolean parent = choose.isTag();
    // 判断
    if( parent && this.isTest() ){
      // 执行标签体
      JspFragment body = this.getJspBody();
      body.invoke(null);
    }
    super.doTag();
  }
}

3. Otherwise.java

public class OtherwiseTag extends SimpleTagSupport {

  // 遇到标签自动执行
  public void doTag() throws JspException, IOException {
    // 获取父元素
    ChooseTag choose = (ChooseTag)this.getParent();
    // 获取父元素的标记变量值
    boolean parent = choose.isTag();
    // 判断
    if(parent){
      // 执行标签体
      JspFragment body = this.getJspBody();
      body.invoke(null);
    }
    super.doTag();
  }
}

4. 描述文件

<?xml version="1.0" encoding="UTF-8"?>
<taglib
  xmlns="http://java.sun.com/xml/ns/javaee"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-jsptaglibrary_2_1.xsd"
  version="2.1">
 <!-- 2. 编写标签库描述文件 -->
 <tlib-version>1.0</tlib-version>
 <short-name>jnb</short-name>
  <tag>
  <name>choose</name>
  <tag-class>cn.itcast.tags.ChooseTag</tag-class>
  <body-content>scriptless</body-content>   JSP2.0方式
 </tag>
 <tag>
  <name>when</name>
  <tag-class>cn.itcast.tags.WhenTag</tag-class>
  <body-content>scriptless</body-content>
  <attribute>
    <name>test</name>
    <required>true</required>
    <rtexprvalue>true</rtexprvalue>
  </attribute>
 </tag>

  <tag>
  <name>otherwise</name>
  <tag-class>cn.itcast.tags.OtherwiseTag</tag-class>
  <body-content>scriptless</body-content>
 </tag>
</taglib>

5. 引入和使用

<%@taglib uri="/WEB-INF/ifelse.tld" prefix="jnb"%>
   <jnb:choose>
    <jnb:when test="<%= 1>2 %>">
        小于
    </jnb:when>
    <jnb:otherwise>
         大于
    </jnb:otherwise>
   </jnb:choose> 

打包自定义标签库

1.   建立一个taglibs文件夹

2.   将所有的标签处理类对应的class文件连同包拷贝到1中的目录中

3.   在1中的文件夹中建立一个META-INF文件夹

4.   将tld文件拷贝到META-INF目录

5.   编辑tld文件引入uri元素:<uri>http://www.jnb.com</uri>     à提供引入的url路径

6.   使用jar命令进行打包:D:\mytaglibs>jar cvf jnb.jar *

总结

主要掌握如何使用JSP2.0进行自定义标签的开发和打包。

1.   建立一个taglibs文件夹

2.   将所有的标签处理类对应的class文件连同包拷贝到1中的目录中

3.   在1中的文件夹中建立一个META-INF文件夹

4.   将tld文件拷贝到META-INF目录

5.   编辑tld文件引入uri元素:<uri>http://www.jnb.com</uri>     à提供引入的url路径

6.   使用jar命令进行打包:D:\mytaglibs>jar cvf jnb.jar *

总结

主要掌握如何使用JSP2.0进行自定义标签的开发和打包。

(0)

相关推荐

  • JS案例分享之金额小写转大写

    之前做项目的时候遇到需要在输入小写金额之后自动转成大写,经过一番研究,整出了如下代码,分享给大家,希望有所帮助 复制代码 代码如下: function Arabia_to_Chinese(Num){ for(i=Num.length-1;i>=0;i--) { Num = Num.replace(",","") Num = Num.replace(" ","") } Num = Num.replace("¥&q

  • JavaScript多图片上传案例

    JS多图片上传小小实例: <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>上传多图片</title> <script type="text/javascript"> function JM_wu(ob) { ob.style.display = "none"; } function JM_you(ob) { ob.sty

  • AngularJS实现元素显示和隐藏的几个案例

    案例一:控制html元素显示和隐藏有n种方法:html的hidden.css的display.jquery的hide()和show().bootstrap的.hide.今天的重点不是显示和隐藏,而是监听某个布尔变量值,自动改变元素显示和隐藏状态.监听函数.if判断.选择dom.设置dom,5行代码搞不定吧,而且毫无技术含量. 看代码: <!DOCTYPE html> <html ng-app> <head> <meta charset="utf-8&qu

  • BootStrap的JS插件之轮播效果案例详解

    Bootstrap 是一个用于快速开发 Web 应用程序和网站的前端框架.Bootstrap 是基于 HTML.CSS.JAVASCRIPT 的. 案例 下面展示的就是此插件和相关组件制作的轮播案例. <div id="carousel-example-generic" class="carousel slide" data-ride="carousel"> <!-- Indicators --> <ol class

  • js对象转json数组的简单实现案例

    复制代码 代码如下: function obj2Str(obj){ switch(typeof(obj)){ case 'object': var ret = []; if (obj instanceof Array){ for (var i = 0, len = obj.length; i < len; i++){ ret.push(obj2Str(obj[i])); } return '[' + ret.join(',') + ']'; } else if (obj instanceof R

  • Ajax $.getJSON案例详解

    复制代码 代码如下: <script type="text/javascript"> function pageIndexChanged() { var url = "/OrderList/Lists"; var where = ""; @*location.href = "@this.Url.Action("List")?pageindex=" + $("#pager").

  • php处理json格式数据经典案例总结

    本文实例总结了php处理json格式数据的方法.分享给大家供大家参考,具体如下: 1.json简介: 何为json? 简 单地说,JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端程序. 通俗点讲,它是一种数据的存储格式,就像php序列化后的字符串一样. 它也是一种数据描述,比如:我们将一个数组序列化后存放,就可以很容易的反序列化后应用:json也是如此,只不过它搭建的是

  • javascript的理解及经典案例分析

    js的简介: JavaScript是一种能让你的网页更加生动活泼的程式语言,也是目前网页中设计中最容易学又最方便的语言. 你可以利用JavaScript轻易的做出亲切的欢迎讯息.漂亮的数字钟.有广告效果的跑马灯及简易的选举,还可以显示浏览器停留的时间.让这些特殊效果提高网页的可观性. javascript现在可以再网页上做很多很多事情,网页特效,操作dom,html5游戏(基于html5和JavaScript的结合),动画等等特效,还可以实现拉去后台数据(通过ajax),不仅可以做前台还可以做后

  • ajax请求json数据案例详解

    今天有这样一个需求,点击六个大洲,出现对应的一些请求信息,展示在下面,请求请求过后,第二次点击就无需请求. 如图所示:点击北美洲下面出现请求的一些数据 html代码结构: <div class="conSixmap"> <div class="name conmap01" data-name="beimeizhou"> <a href="javascript:void(0)">北美洲<

  • AngularJs解决跨域问题案例详解(简单方法)

    首先我们做点准备说明,不然你明白我说的是啥意思别人不明白,就算别人明白了那总有人不明白,那你要说了,我的意思是这个说明必须要做了,答案是必须的,为了更好的方便大家理解嘛. 我们以两个主域名或者一个主域名+一个二级域名为例,均可演示跨域问题. 客户端 a.com 服务端 b.com或者s.a.com angularJs版本 V1.2.25 准备工作做得很充分嘛,就差把我们的编辑器是subline暴露出来了,这个一般人我是不告诉他滴. 有人嚷嚷了,这问题老早就有了,你现在提出来有啥意义呢?难不成你还

随机推荐