自定义<%@ taglib prefix="cf" uri="http://training.bmcc.com.cn/tld/functions"%> 

就可以根据${cf:proxyConfig('elearning_play')}

实现自定义标签 读取  proxyConfig中的内容,

如果我们使用jsp2,则web.xml使用的是servlet2.4以上的版本。那我们看一下web.xml对应的头文件:

新增的特性是:

<web-app version= "4"
xmlns="http://javasuncom/xml/ns/j2ee"
xmlns:xsi="http://wwwworg/2001/XMLSchema-instance"
xsi:schemaLocation="http://javasuncom/xml/ns/j2ee
http://javasuncom/xml/ns/j2ee/web-app_2_xsd" >
</web-app>

首先在web.xml中添加如下代码:

 <jsp-config>
<taglib>
<taglib-uri>http://training.bmcc.com.cn/tld/functions</taglib-uri>
<taglib-location>/WEB-INF/customfunction.tld</taglib-location>
</taglib>
</jsp-config>

根据上面的

<%@ taglib prefix="cf" uri="http://training.bmcc.com.cn/tld/functions"%> 

得到taglib-location   这里得到的是customfunction.tld 找到如下文件:直接上代码

<?xml version="1.0" encoding="UTF-8" ?>
<taglib 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 http://java.sun.com/xml/ns/j2ee/web-jsptaglibrary_2_0.xsd"
version="2.0">
<display-name>Custom Functions</display-name>
<tlib-version>1.1</tlib-version>
<short-name>cf</short-name>
<uri>http://training.bmcc.com.cn/tld/functions</uri>
<function>
<name>proxyConfig</name>
<function-class>com.cmbj.training.common.util.ProxyConfigUtil</function-class>
<function-signature>java.lang.String getProxyURL(java.lang.String)</function-signature>
</function>
<function>
<name>popedomCheck</name>
<function-class>com.cmbj.training.common.util.PopedomCheckUtil</function-class>
<function-signature>boolean check(java.util.Map, java.lang.Integer)</function-signature>
</function>
<function>
<name>checkEmployeeJob</name>
<function-class>com.cmbj.training.common.util.UserJobUtil</function-class>
<function-signature>boolean checkEmloyeeJob(java.lang.String)</function-signature>
</function>
<function>
<name>checkManager</name>
<function-class>com.cmbj.training.common.util.UserJobUtil</function-class>
<function-signature>boolean checkManager(java.lang.String)</function-signature>
</function>
<function>
<name>getValByKey</name>
<function-class>com.cmbj.training.common.util.ConstantsMapUtil</function-class>
<function-signature>java.lang.String getValByKey(java.util.Map, java.lang.String)</function-signature>
</function>
<function>
<name>titleFormat</name>
<function-class>common.base.util.StringUtil</function-class>
<function-signature>java.lang.String titleFormat(java.lang.String, java.lang.Integer)</function-signature>
</function>
<function>
<name>titleFormat2</name>
<function-class>common.base.util.StringUtil</function-class>
<function-signature>java.lang.String titleFormat(java.lang.String, java.lang.Integer, java.lang.String)</function-signature>
</function> <function>
<name>checkRoleByName</name>
<function-class>com.bestnet.common.util.RoleUtil</function-class>
<function-signature>boolean checkRoleByName(java.util.Map, java.lang.String)</function-signature>
</function> <function>
<name>checkRoleByCode</name>
<function-class>com.bestnet.common.util.RoleUtil</function-class>
<function-signature>boolean checkRoleByCode(java.util.Map, java.lang.String)</function-signature>
</function>
</taglib>

根据name得到 类路径:

<function-class>com.cmbj.training.common.util.ProxyConfigUtil</function-class>

类内容如下:

public class ProxyConfigUtil {

    private static ResourceLoadUtil RESOURCE_LOADUTIL = new ResourceLoadUtil("/proxyConfig.properties");

    private ProxyConfigUtil() {

    }

    public static String getProxyURL(String proxyURLKey, String defaultVal) {
return RESOURCE_LOADUTIL.getVal(proxyURLKey, defaultVal);
} public static String getProxyURL(String proxyURLKey) {
return getProxyURL(proxyURLKey, "");
} public static String getProxyParam(String key){
return RESOURCE_LOADUTIL.getVal(key);
}

最后得到配置文件,读取内容,得到相应的url内容${cf:proxyConfig('elearning_play')}
elearning_play=http\://***.***.***\:8011

最终完成自定义标签的配置。

taglib 自定义标签的更多相关文章

  1. thinkphp5 taglib自定义标签教程

    学着写了一下,终于搞定了,顺便分享一下!taglib是tp框架自定义标签功能,如果你用过cms,肯定见过类似: {dede:arclist typeid='' row='' col='' titlel ...

  2. ThinkPHP3.2.3 自定义标签库的使用

    ThinkPHP 3.2.3 手册中标签库驱动的地址是: http://www.kancloud.cn/manual/thinkphp/1859 标签库的地址是:http://www.kancloud ...

  3. JSP2.2自定义标签、EL函数

    简介 JSTL是一个JSP标准标签库,可以解决大部分问题,但是如果我们需要一些更特殊的功能,就需要自定义类似JSTL中标签的标签.如果EL表达式无法满足我们的需求,我们也可以自定义EL函数. tld后 ...

  4. [JSP]自定义标签库taglib

    自定义标签的步骤 自定义标签的步骤大概有三步: 1.继承javax.servlet.jsp.tagext.*下提供的几个标签类,如Tag.TagSupport.BodyTagSupport.Simpl ...

  5. [Java] JSP笔记 - 自定义标签

    自定义标签的创建步骤: 自定义标签的四大功能: 自定义标签的类结构: 在 1.0 中呢, 可以将 <body-content> 的值设置为 JSP, 2.0中则不允许在自定义标签体中出现j ...

  6. thinkphp自定义标签库

    thinkphp ~ php中 的类, 的成员变量, 本身是没有类型说明的, 那么我怎么知道它的类型呢? 或初始值呢? 通常在类定义中, 如果能给一个初始值的(对于已知简单类型的),最好给一个初始值, ...

  7. 12 自定义标签/JSTL标签库/web国际化/java web之设计模式和案例

    EL应用      自定义一个标签,实现两个字符串的相加 1回顾      1.1servlet生命周期           init(ServletConfig)           service ...

  8. EL函数以及自定义标签的应用

    一.EL函数(调用普通类的静态方法) 编写步骤(自定义EL函数的编写步骤即自定义标签的编写步骤): ①编写一个普通的java类,提供一个静态方法,功能自定,例如下: package cn.wzbril ...

  9. JSTL 自定义标签

    编写描述标签的tld文件,把这个文件放到web-inf/目录下,才能在jsp页面上调用自定义的标签 package test.yz; import java.io.IOException; impor ...

随机推荐

  1. js基础之动画(二)

    一.多物体同时运动 栗子一:多个Div,鼠标移入变高,动态下拉菜单 function startMove(obj,iTarget){  clearInterval(obj.timer); obj.ti ...

  2. Android SDK生成时,自定义文件名称,而非系统第一分配的app-release.apk

    buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.tx ...

  3. virtualbox安装提示出现严重错误解决办法

    解决办法: 在服务里面启动1. Device Install Service2. Device Setup Manager 这两个服务就好了.也有可能只需要启动第一个.

  4. vi编辑器选项

    Vi编辑器有一些选项设置可以帮助人们更好的使用. 在vi中选项分为两种: 1.  开关选项,如果要打开这类选项就使用ex命令——:set 选项:如果要关闭这类选项就是用ex命令——:set  no选项 ...

  5. APP store 上架过程中碰到的那些坑&被拒的各种奇葩原因整理&审核指南中文版

    苹果官方发布的十大常见被拒原因 1.崩溃次数和Bug数量.苹果要求开发者在将应用提交给App Store之前彻查自己的应用,以尽量避免Bug的存在. 2.链或错误的链接.应用中所有的链接必须是真实且有 ...

  6. struts2内Action方法调用

    1.struts2流程: jsp页面-->web.xml-->struts.xml-->user.acrion-->UserAction.java 中的execute()--r ...

  7. sql学习资料

    http://blog.sina.com.cn/s/articlelist_1594135432_9_1.html

  8. NTP服务器的配置

    安装cloudera Manager的时候,必须要求集群的主机之间时间同步,搭建一个NTP服务器的思路是,首先通过一台主机master与外网进行时间同步,然后其他的slaver主机与主机master进 ...

  9. <矩阵的基本操作:矩阵相加,矩阵相乘,矩阵转置>

    //矩阵的基本操作:矩阵相加,矩阵相乘,矩阵转置 #include<stdio.h> #include<stdlib.h> #define M 2 #define N 3 #d ...

  10. 2016 - 1 -19 初学HTML5 第一天

    1.HTML COMMANDS MHTL commands called elements.Usually, an element has a start tag and an end tag e.g ...