设为首页 收藏本站
查看: 934|回复: 0

[经验分享] Tomcat StringManager阅读学习

[复制链接]
累计签到:6 天
连续签到:1 天
发表于 2015-8-7 07:05:52 | 显示全部楼层 |阅读模式
我们到底能走多远系列(10)
  扯淡:空闲时间不多,扯淡时间久更少了。
  主题:
  先了解下两个所谓的知识点:ResourceBundleMessageFormat
  在项目里用的得心应手的properites文件,大多要用到这两个类吧。



java.util.ResourceBundle
java.text.MessageFormat
  1,ResourceBundle解析资源文件分两步:1加载资源文件,2获取资源文件中的信息



// 加载资源文件
ResourceBundle resource = ResourceBundle.getBundle("messages");
// 获取资源文件中的信息
String driverName = resource.getString("database.driver");
  ResourceBundle支持多国语言:先把文件名取成类似这样myres_zh_CN.properties
  然后:



Locale locale1 = new Locale("zh", "CN");
ResourceBundle resb1 = ResourceBundle.getBundle("myres", locale1);
resb1.getString("aaa");
  2,MessageFormat用来格式化一个消息(字符串嘛)
  直接网上类似代码:



String pig = "{0}{1}{2}{3}{4}{5}{6}{7}{8}{9}{10}{11}{12}{13}{14}{15}{16}";  
Object[] array = new Object[]{"A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q"};  
String value = MessageFormat.format(pig, array);  
System.out.println(value);  //最终结果是:ABCDEFGHIJKLMNOPQ
  3,结合在一起就可以实现,将properites文件解析出想要的消息体,然后格式化后给上一层方法用。
  
  myResources.properties:



database.driver=com.mysql.jdbc.Drvier
database.url=jdbc:mysql://localhost:3306:test
database.user={0}
database.pass={0}

  例:



public class ResourceBundleTest {
public static void main(String[] args) {
// 指明包路径和文件名即可
ResourceBundle resource = ResourceBundle.getBundle("code.stu.ResourceBundle.myResources");
String driverName = resource.getString("database.driver");
String url = resource.getString("database.url");
Object[] array1 = new Object[]{"root"};
Object[] array2 = new Object[]{"test"};
// 取得字符串,直接格式化
String user = MessageFormat.format(resource.getString("database.user"), new Object[]{"root"});
String pass = MessageFormat.format(resource.getString("database.pass"), new Object[]{"test"});
System.out.println(driverName + url + user + pass);//结果:com.mysql.jdbc.Drvierjdbc:mysql://localhost:3306:testroottest
    }
}

StringManager

  在tomcat里,把错误日志信息的字符串写在properites文件里,如此一来,打印日志的事情就可以通过上面的两个类来解决了。
  StringManager是管理打印日志的类,Tomcat的设计是,对每一个包提供自己的properites文件,也就是说,每一个包的日志信息只需要去各自包的properites文件里去找就可以了,然后Tomcat为每一个包提供一个StringManager实例,相当于一个包一个单例的效果(值得学习下)。各自的StringManager实例来管理各自包下的日志打印。
  源码如下:



package org.apache.catalina.util;
import java.text.MessageFormat;
import java.util.Hashtable;
import java.util.Locale;
import java.util.MissingResourceException;
import java.util.ResourceBundle;
import java.net.URLClassLoader;
public class StringManager {
// ResourceBundle用于读取properties文件
private ResourceBundle bundle;
private static org.apache.juli.logging.Log log=
org.apache.juli.logging.LogFactory.getLog( StringManager.class );
// 私有的构造方法能够保证外界无法实例化自己,这也是单例实现的关键步骤
private StringManager(String packageName) {
// properties文件所在的package+“.LocalStrings”
// 所有tomcat的日志使用的properties文件都依照这个形式来命名的
String bundleName = packageName + ".LocalStrings";
try {
// 根据bundleName取得解析资源文件的实例
bundle = ResourceBundle.getBundle(bundleName);
return;
} catch( MissingResourceException ex ) {// 好吧,异常就先不管了。
// Try from the current loader ( that's the case for trusted apps )
ClassLoader cl=Thread.currentThread().getContextClassLoader();
if( cl != null ) {
try {
bundle=ResourceBundle.getBundle(bundleName, Locale.getDefault(), cl);
return;
} catch(MissingResourceException ex2) {
}
}
if( cl==null )
cl=this.getClass().getClassLoader();
if (log.isDebugEnabled())
log.debug("Can't find resource " + bundleName +
" " + cl);
if( cl instanceof URLClassLoader ) {
if (log.isDebugEnabled())
log.debug( ((URLClassLoader)cl).getURLs());
}
}
}
/**
* Get a string from the underlying resource bundle.
*
* @param key The resource name
*/
public String getString(String key) {
return MessageFormat.format(getStringInternal(key), (Object [])null);
}

protected String getStringInternal(String key) {
// key 还是要保证不是null
if (key == null) {
String msg = "key is null";
throw new NullPointerException(msg);
}
// 返回string
String str = null;
if( bundle==null )
return key;
try {
// 资源文件里去查有没有对应的内容
str = bundle.getString(key);
} catch (MissingResourceException mre) {
str = "Cannot find message associated with key '" + key + "'";
}
return str;
}
public String getString(String key, Object[] args) {
String iString = null;
String value = getStringInternal(key);
// this check for the runtime exception is some pre 1.1.6
// VM's don't do an automatic toString() on the passed in
// objects and barf out
try {
// ensure the arguments are not null so pre 1.2 VM's don't barf
Object nonNullArgs[] = args;
for (int i=0; i

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-94888-1-1.html 上篇帖子: Tomcat6+IIS6集成及Tomcat负载均衡与Tomcat集群配置 下篇帖子: Tomcat加载servlet类文件
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表