Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 627|回复: 0

Asp.Net 网站多语言解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2024-4-6 11:05
  • 签到天数: 748 天

    [LV.9]以坛为家II

    2034

    主题

    2092

    帖子

    70万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    705612
    发表于 2021-4-18 16:37:49 | 显示全部楼层 |阅读模式

    最近领导要求实现PMSWeb应用程序的多区域语言的支持,所以在网搜集相关的信息,写出了解决方案文档,欢迎各位批评指正,谢谢!废话少说,进入正题:

       

    多语言解决方案(2013年1月 济南)

    目  录

     

    1.      开发目的... 1

    2.      实现的效果... 1

    3.      方案1说明(Asp.Net内置公共资源文件+ExtJS)... 1

    3.1.       概述... 1

    3.2.       实现步骤... 1

    3.3.       本方案总结... 4

    4.      方案2(XML+JS)... 5

    4.1.       概述:... 5

    4.2.       实现步骤:... 5

    4.3.       本方案总结... 7

     

    1.    开发目的

    为了使PMS系统适应国际化项目管理的正常运行,根据当前用户本地的语言、数据的习惯格式进行对系统进行本地化显示,满足用户的需求。

     

    2.    实现的效果

    PMS系统平台根据用户在登录时所选择的语言种类,对界面进行本地化显示。用户选择中文时,系统界面展示的语言为中文,如果用户选择英文时,则展示为英文。本地化内容具体包括:界面显示、提示信息、数据格式(日期、货币)。

     

    3.    方案1说明(Asp.Net内置公共资源文件+ExtJS)

    3.1.  概述

       方案1采用.Net Framework2.0 公共资源文件(.resx)+ExtJS实现。为每个区域用户分别添加该区域的语言描述文件(默认语言.resx,中文.resx,英文.resx)。语言描述文件内容主要包括:关键字名称(key_name), 关键字值(key_value),其中关键字名称是唯一的。系统根据当前用户选择的区域语言,在相应的区域语言描述文件中获取界面显示信息。

    3.2.  实现步骤

    1)       获取当前用户的区域信息

    用户在登录时选择语言种类。

    PMS读取当前操作系统安装语言作为默认语言。

    2)   建立区域语言资源文件

    根据用户群体的需求,创建区域语言资源文件。

    具体实现步骤:

    • 在解决方案管理器中添加Asp.Net 文件夹“App_GlobalResources

    在文件夹中添加资源文件,例如 lang.resx。

    添加所要描述的键名称、键值。此文件为默认文件。

    添加其他种类语言的描述文件,例如 英文(lang.en-US.resx)、中文(lang.zh-CN.resx),它们与默认文件的键名称相同,键值不同。如下图所示:

       
      
      
      
      
      

     

     

     

     

    3)             设置Asp.Net 控件的文本显示方式,

    设置举例如下:

    标签控件(引用公共资源文件):

    <asp:Label ID="lbl_global" runat ="server" Width ="600px" Text ="<%$Resources:lang,Message %>"></asp:Label>

     

    按钮控件(引用本地资源文件):

     

    <asp:Button ID="btnMessage" runat="server" OnClick="btnMessage_Click" Text="Message" meta:resourcekey="btnMessageResource1" />
    

      

    隐藏按钮(引用公共资源文件)

    <asp:HiddenField ID="hidLang" runat ="server"   value="<%=Resources.lang.Message %>"/>
    

      

    JavaScript变量引用

        

    var strLang="<%=Resources.lang.Message%>";

     

     

    实现效果界面展示:

     

     

      

     

     

    3.3.  本方案总结

    优点:本方案实现简单,操作方便,安全性高。

    对各种浏览器适应性高。

    缺点: 部署后不易维护,需要重新编译。

    数据信息无法分类,难护分类。

      

     

    4.    方案2(XML+JS)

    实现方案说明:

    4.1.  概述:

    本方案主要将区域语言描述数据存放在XML文件中,根据在XML文件中自定义的节点标志变量及标志变量的值,通过Javascript对XML文件进行读取操作。

    4.2.  实现步骤:

    Ø  设置区域语言初始标志

    在Web.Config中,添加如下信息:

    <appSettings>
    
        <add key="Flag" value="1" /> <!-- 0:中文; 1:英文--> 
    
      </appSettings>
    

      

    Ø  系统获取区域语言标志

    由于Javascript无法访问web.config文件,所以需要在Global.asax文件中Application_Start事件添加如下处理:

    从Web.config 读取区域语言标志变量

    将标志变量写入在指定的XML文件中,例如web.xml文件。

     

    Ø  提取界面显示、提示信息区域语言描述信息,分别存入相对应的XML文件中,如中文.XML,英文.XML。格式如下所示:

    英文:

     

    <?xml version="1.0" encoding="utf-8" ?>
    
    <langShow>
    
      <formShow>    
    
        <add key="Add" value="Add"></add>
    
        <add key="Delete" value="Delete"></add>
    
        <add key="ShowInfo" value="This is a test!"></add>
    
      </formShow>
    
      <alertmsg>
    
        <add key="FileNotExist" value="File isn't exist!"></add>
    
        <add key="DelInfo" value="Are you sure to delete this file?"></add>
    
      </alertmsg>  
    
    </langShow>

     

    中文:

    <?xml version="1.0" encoding="utf-8" ?>
    
    <langShow>
    
      <formShow>     
    
        <add key="Add" value="添加"></add>    
    
        <add key="Delete" value="删除"></add>
    
        <add key="ShowInfo" value="这是一个测试用例"></add>
    
      </formShow>
    
      <alertmsg>
    
        <add key="FileNotExist" value="文件不存!"></add>
    
        <add key="DelInfo" value="请确认是否删除该文件?"></add>    
    
      </alertmsg>
    
    </langShow>

     

     

    Ø  根据区域标志,通过Javascript在对应的上述文件中读取显示信息。

    界面效果显示如下图所示:

     

     

     

     

     

    4.3.  本方案总结

    优点:

    资源文件维护方便,不用重新编译。

    数据信息可以分类,便于维护。

    缺点:

    安全性差,用户可以直接打开资源文件。

    适应性差。系统需要辨别不同的浏览器(IE,Firefox..)。

     代码下载:

     .Net 内置公共资源.zip  js_xml_multiLang.zip

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-5-18 18:12 , Processed in 0.063779 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

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