taglib 自定义标签
自定义<%@ 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 自定义标签的更多相关文章
- thinkphp5 taglib自定义标签教程
学着写了一下,终于搞定了,顺便分享一下!taglib是tp框架自定义标签功能,如果你用过cms,肯定见过类似: {dede:arclist typeid='' row='' col='' titlel ...
- ThinkPHP3.2.3 自定义标签库的使用
ThinkPHP 3.2.3 手册中标签库驱动的地址是: http://www.kancloud.cn/manual/thinkphp/1859 标签库的地址是:http://www.kancloud ...
- JSP2.2自定义标签、EL函数
简介 JSTL是一个JSP标准标签库,可以解决大部分问题,但是如果我们需要一些更特殊的功能,就需要自定义类似JSTL中标签的标签.如果EL表达式无法满足我们的需求,我们也可以自定义EL函数. tld后 ...
- [JSP]自定义标签库taglib
自定义标签的步骤 自定义标签的步骤大概有三步: 1.继承javax.servlet.jsp.tagext.*下提供的几个标签类,如Tag.TagSupport.BodyTagSupport.Simpl ...
- [Java] JSP笔记 - 自定义标签
自定义标签的创建步骤: 自定义标签的四大功能: 自定义标签的类结构: 在 1.0 中呢, 可以将 <body-content> 的值设置为 JSP, 2.0中则不允许在自定义标签体中出现j ...
- thinkphp自定义标签库
thinkphp ~ php中 的类, 的成员变量, 本身是没有类型说明的, 那么我怎么知道它的类型呢? 或初始值呢? 通常在类定义中, 如果能给一个初始值的(对于已知简单类型的),最好给一个初始值, ...
- 12 自定义标签/JSTL标签库/web国际化/java web之设计模式和案例
EL应用 自定义一个标签,实现两个字符串的相加 1回顾 1.1servlet生命周期 init(ServletConfig) service ...
- EL函数以及自定义标签的应用
一.EL函数(调用普通类的静态方法) 编写步骤(自定义EL函数的编写步骤即自定义标签的编写步骤): ①编写一个普通的java类,提供一个静态方法,功能自定,例如下: package cn.wzbril ...
- JSTL 自定义标签
编写描述标签的tld文件,把这个文件放到web-inf/目录下,才能在jsp页面上调用自定义的标签 package test.yz; import java.io.IOException; impor ...
随机推荐
- js基础之动画(二)
一.多物体同时运动 栗子一:多个Div,鼠标移入变高,动态下拉菜单 function startMove(obj,iTarget){ clearInterval(obj.timer); obj.ti ...
- Android SDK生成时,自定义文件名称,而非系统第一分配的app-release.apk
buildTypes { release { minifyEnabled false proguardFiles getDefaultProguardFile('proguard-android.tx ...
- virtualbox安装提示出现严重错误解决办法
解决办法: 在服务里面启动1. Device Install Service2. Device Setup Manager 这两个服务就好了.也有可能只需要启动第一个.
- vi编辑器选项
Vi编辑器有一些选项设置可以帮助人们更好的使用. 在vi中选项分为两种: 1. 开关选项,如果要打开这类选项就使用ex命令——:set 选项:如果要关闭这类选项就是用ex命令——:set no选项 ...
- APP store 上架过程中碰到的那些坑&被拒的各种奇葩原因整理&审核指南中文版
苹果官方发布的十大常见被拒原因 1.崩溃次数和Bug数量.苹果要求开发者在将应用提交给App Store之前彻查自己的应用,以尽量避免Bug的存在. 2.链或错误的链接.应用中所有的链接必须是真实且有 ...
- struts2内Action方法调用
1.struts2流程: jsp页面-->web.xml-->struts.xml-->user.acrion-->UserAction.java 中的execute()--r ...
- sql学习资料
http://blog.sina.com.cn/s/articlelist_1594135432_9_1.html
- NTP服务器的配置
安装cloudera Manager的时候,必须要求集群的主机之间时间同步,搭建一个NTP服务器的思路是,首先通过一台主机master与外网进行时间同步,然后其他的slaver主机与主机master进 ...
- <矩阵的基本操作:矩阵相加,矩阵相乘,矩阵转置>
//矩阵的基本操作:矩阵相加,矩阵相乘,矩阵转置 #include<stdio.h> #include<stdlib.h> #define M 2 #define N 3 #d ...
- 2016 - 1 -19 初学HTML5 第一天
1.HTML COMMANDS MHTL commands called elements.Usually, an element has a start tag and an end tag e.g ...