热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

tomcatcontext.xmlmysql_如何将值动态加载到Tomcat的ContextXML文件中

假设您有一个tomcatconfcontext.xml文件,如下所示:WEB-INFweb.xmlnamejdbcMyDBauthContainertype

假设您有一个tomcat / conf / context.xml文件,如下所示:

WEB-INF/web.xml

name="jdbc/MyDB"

auth="Container"

type="javax.sql.DataSource"

removeAbandoned="true"

removeAbandonedTimeout="15"

maxActive="5"

maxIdle="5"

maxWait="7000"

username="${db.mydb.uid}"

password="${db.mydb.pwd}"

driverClassName="${db.mydb.driver}"

url="${db.mydb.url}${db.mydb.dbName}?autoReconnectForPools=true&characterEncoding=UTF-8"

factory="com.mycompany.util.configuration.CustomDataSourceFactory"

validationQuery="SELECT '1';"

testOnBorrow="true"/>

在这种情况下我们想要替换的是此资源定义中${.*}内容中的任何内容.但是,稍微修改下面的代码,您可以在几乎任何您想要的标准上执行这些替换.

注意line factory =“com.mycompany.util.configuration.CustomDataSourceFactory”

这意味着Tomcat将尝试使用此工厂来处理此资源.应该提到的是,这意味着这个工厂必须在启动时在Tomcat的类路径上(就我个人而言,我将它放在Tomcat lib目录中的JAR中).

这是我工厂的样子:

package com.mycompany.util.configuration;

import java.util.Hashtable;

import java.util.regex.Matcher;

import java.util.regex.Pattern;

import javax.naming.Context;

import javax.naming.Name;

import javax.naming.RefAddr;

import javax.naming.Reference;

import javax.naming.StringRefAddr;

import javax.naming.spi.ObjectFactory;

import org.apache.commons.dbcp.BasicDataSourceFactory;

public class CustomDataSourceFactory extends BasicDataSourceFactory implements ObjectFactory {

private static final Pattern _propRefPattern = Pattern.compile("\\$\\{.*?\\}");

//http://tomcat.apache.org/tomcat-6.0-doc/jndi-resources-howto.html#Adding_Custom_Resource_Factories

@Override

public Object getObjectInstance(Object obj, Name name, Context nameCtx, Hashtable environment) throws Exception {

if (obj instanceof Reference) {

Reference ref = (Reference) obj;

System.out.println("Resolving context reference values dynamically");

for(int i = 0; i

RefAddr addr = ref.get(i);

String tag = addr.getType();

String value = (String) addr.getContent();

Matcher matcher = _propRefPattern.matcher(value);

if (matcher.find()) {

String resolvedValue = resolve(value);

System.out.println("Resolved " + value + " to " + resolvedValue);

ref.remove(i);

ref.add(i, new StringRefAddr(tag, resolvedValue));

}

}

}

// Return the customized instance

return super.getObjectInstance(obj, name, nameCtx, environment);

}

private String resolve(String value) {

//Given the placeholder, do stuff to figure out what it's true value should be, and return that String.

//This could be decryption, or maybe using a properties file.

}

}

然后,一旦此代码在类路径上,重新启动Tomcat并观察catalina.out以获取日志消息.注意:System.out.println语句可能最终会将敏感信息打印到您的日志中,因此您可能希望在完成调试后删除它们.

在旁注中,我写了这个,因为我发现许多例子对于一个特定主题(例如利用密码学)来说太具体了,我想说明如何一般地完成这个.此外,这个问题的其他一些答案并没有很好地解释自己,我不得不做一些挖掘来弄清楚需要做些什么来使这项工作.我想和你们分享我的发现.如果您发现问题,请随时对此发表评论,提出任何问题或进行更正,我将确保将修复内容添加到我的答案中.



推荐阅读
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • VScode格式化文档换行或不换行的设置方法
    本文介绍了在VScode中设置格式化文档换行或不换行的方法,包括使用插件和修改settings.json文件的内容。详细步骤为:找到settings.json文件,将其中的代码替换为指定的代码。 ... [详细]
  • 本文介绍了Java工具类库Hutool,该工具包封装了对文件、流、加密解密、转码、正则、线程、XML等JDK方法的封装,并提供了各种Util工具类。同时,还介绍了Hutool的组件,包括动态代理、布隆过滤、缓存、定时任务等功能。该工具包可以简化Java代码,提高开发效率。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • Oracle seg,V$TEMPSEG_USAGE与Oracle排序的关系及使用方法
    本文介绍了Oracle seg,V$TEMPSEG_USAGE与Oracle排序之间的关系,V$TEMPSEG_USAGE是V_$SORT_USAGE的同义词,通过查询dba_objects和dba_synonyms视图可以了解到它们的详细信息。同时,还探讨了V$TEMPSEG_USAGE的使用方法。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • 本文详细介绍了SQL日志收缩的方法,包括截断日志和删除不需要的旧日志记录。通过备份日志和使用DBCC SHRINKFILE命令可以实现日志的收缩。同时,还介绍了截断日志的原理和注意事项,包括不能截断事务日志的活动部分和MinLSN的确定方法。通过本文的方法,可以有效减小逻辑日志的大小,提高数据库的性能。 ... [详细]
  • Spring源码解密之默认标签的解析方式分析
    本文分析了Spring源码解密中默认标签的解析方式。通过对命名空间的判断,区分默认命名空间和自定义命名空间,并采用不同的解析方式。其中,bean标签的解析最为复杂和重要。 ... [详细]
  • 本文介绍了数据库的存储结构及其重要性,强调了关系数据库范例中将逻辑存储与物理存储分开的必要性。通过逻辑结构和物理结构的分离,可以实现对物理存储的重新组织和数据库的迁移,而应用程序不会察觉到任何更改。文章还展示了Oracle数据库的逻辑结构和物理结构,并介绍了表空间的概念和作用。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 本文讨论了在数据库打开和关闭状态下,重新命名或移动数据文件和日志文件的情况。针对性能和维护原因,需要将数据库文件移动到不同的磁盘上或重新分配到新的磁盘上的情况,以及在操作系统级别移动或重命名数据文件但未在数据库层进行重命名导致报错的情况。通过三个方面进行讨论。 ... [详细]
  • ubuntu用sqoop将数据从hive导入mysql时,命令: ... [详细]
author-avatar
阵风阿斯顿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有