是否可以定义自定义格式<xsl:number>
?
我有这样的情况:需要标准的基于字母的格式,但字母表中的某些字符是被禁止的(奇怪的要求,但这是客户所要求的)。例如,字母i
不能使用,所以使用时<xsl:number>
我应该得到序列:a, b, c, d, e, f, g, h, j, k, ..., aa, ab, ...,啊,阿杰,...
该项目使用 XSLT 2.0 和 Saxon,因此如果存在特定于 Saxon 的解决方案,那就没问题。
XSLT 2.0 是否提供定义自定义格式序列的功能?Saxon 是否提供注册自定义序列以供使用的功能<xsl:number>
?
我正在使用Log4j(1.2.16)登录的Web应用程序.为了避免编辑大量文件,我试图挂钩一个自定义的LoggerFactory实现,以防止日志伪造.
看来可以设置log4j.loggerFactory
配置设置(项目使用属性文件方法)来指定要使用的记录器工厂.但是,这似乎不起作用.在检查了Log4j的源代码之后,看起来该属性从未真正使用过,即使它是由PropertyConfigurator类读取的.
检查更多的Log4j源代码,它似乎是实现我想要的唯一方法,我必须创建Log4j类的自定义子类.这是唯一的方法吗?
以下代表我在Web应用程序上下文监听器中必须要做的事情,以初始化Log4j,以便使用我的自定义记录器工厂:
package com.example.myapp.log4j;
import javax.servlet.ServletContextListener;
import javax.servlet.ServletContextEvent;
import javax.servlet.*;
public class MyLog4jInitContextListener implements ServletContextListener
{
public void contextInitialized(
ServletContextEvent event
) {
this.context = event.getServletContext();
String file = context.getInitParameter("log4jConfiguration");
if (file != null) {
String prefix = context.getRealPath("/");
String pathname = prefix+file;
event.getServletContext().log("Initializing log4j with "+pathname);
org.apache.log4j.LogManager.setRepositorySelector(
new org.apache.log4j.spi.DefaultRepositorySelector(
new MyHierarchy(
new org.apache.log4j.spi.RootLogger(
(org.apache.log4j.Level)org.apache.log4j.Level.INFO))), this);
new MyPropertyConfigurator().doConfigure(
pathname, org.apache.log4j.LogManager.getLoggerRepository());
} else {
event.getServletContext().log(
"No log4jConfiguration parameter specified");
}
}
public void contextDestroyed(
ServletContextEvent event
) …
Run Code Online (Sandbox Code Playgroud)