基于语言文件的asp.net全球化解决方案
方案描述
本方案采用一种语言一个资源文件的方法,能够有效提高资源文件的可维护性。而VS.NET提供的一个WebForm一个资源文件的方案,无法满足统一维护的需要。
实现步骤
1. 准备资源文件
资源文件通常有.resx和.resources两种,前者是xml文件,后者是二进制文件。本方案中采用.resources作为资源文件,因此需要一个第三方提供的资源编辑器对资源文件进行编辑,我使用的是Resourcer,反正只要能编辑资源文件并且保存为.resources文件的软件都可以。在资源文件中添加一些string资源,通常情况下,只会用到string资源,有些项目可能需要全球化的图片资源,原理里一样的,本文就不涉及了。
资源文件的命名是有规定,该方案中,我把所有的资源文件名设为business.[culture].resources,其中business这个名字可以改,可以改成任何一个你喜欢的名字,[culture]部分必须使用.net允许的文化缩写,如zh-cn、ja-jp、en-us等。
2. 把资源文件放入项目
为了方便管理,我把所有的资源文件放在网站的一级目录Resources中。由于读取资源文件时要用到资源文件的物理位置,建议把Resources目录直接放在wwwroot下,否则会因为路径问题而变得很麻烦。
3. 增加默认语言设置
在web.config中加入<add key="cultureName" value="zh-cn" />,表明默认情况下使用zh-cn作为默认语言文化。
4. 通过Session设置当前语言
我们用一个Session变量——Session["cultureName"]来告诉每一个页面应该使用哪种语言进行初始化。当Session["cultureName"]==null时,表明该变量未设置过,就直接用默认语言文化,即web.config中的设置值。
如果用户想改变当前的界面语言,只需要设置Session["cultureName"]为指定的文化缩写即可。
全球化资源辅助管理类
通过这个类你不需要了解ResourceManager的使用方法,就可以完成全球化的初始化和资源读取工作。该类初始化时需要传入一个Page对象,该对象将用于获得Session变量值。一般情况下,大家只需要用该类的GetString()方法就可以了。
/// 全球化资源辅助管理类
/// </summary>
public class ResourceHelper
{
private ResourceManager _rm=null;
private Page _page=null;
public ResourceHelper(Page page)
{
_page=page;
PrepareResource();
}
/// <summary>
/// 获得当前文化,从Session["cultureName"]取
/// </summary>
protected CultureInfo GetCurrentCulture
{
get
{
if(_page.Session["cultureName"]!=null)
return CultureInfo.CreateSpecificCulture(_page.Session["cultureName"].ToString());
else //如果Session未设置,则直接从web.config中读取默认设置
return CultureInfo.CreateSpecificCulture(System.Configuration.ConfigurationSettings.AppSettings["cultureName"]);
}
}
/// <summary>
/// 初始化资源管理
/// </summary>
public void PrepareResource()
{
_rm = ResourceManager.CreateFileBasedResourceManager("business",_page.Server.MapPath("resources")+System.IO.Path.DirectorySeparatorChar,null);
}
/// <summary>
/// 获得资源指针
/// </summary>
protected ResourceManager resource
{
get
{
if(_rm==null)
PrepareResource();
return _rm;
}
}
/// <summary>
/// 获得资源字符串
/// </summary>
/// <param name="ResourceID">资源ID</param>
/// <returns></returns>
public string GetString(string ResourceID)
{
return this.resource.GetString(ResourceID,this.GetCurrentCulture);
}
}
为了方便大家学习,做了个Demo给大家参考
关于Demo的一些说明:
1. 本演示在WindowsXP Professional+VS.NET2003环境下调试通过
2. 演示中提供了三种语言的资源文件:business.zh-cn.resources, business.en-us.resources,business.ja-jp.resources
它们都放在Resources目录下,每个资源文件中有001_01、001_02、001_03三个string资源,分别表示用户名、密码、生日。
3. 通过选择下拉式列表中的语言,然后按“确定”按钮,可以完成语言切换
版权声明:本文由作者Tony Qu原创, 未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则视为侵权。