首页
学习
活动
专区
圈层
工具
发布
30 篇文章
1
ASP.NET MVC5+EF6+EasyUI 后台管理系统(2)-easyui构建前端页面框架[附源码]
2
ASP.NET MVC5+EF6+EasyUI 后台管理系统(55)-Web打印
3
ASP.NET MVC5+EF6+EasyUI 后台管理系统(29)-T4模版
4
ASP.NET MVC5+EF6+EasyUI 后台管理系统(67)-MVC与ECharts
5
ASP.NET MVC5+EF6+EasyUI 后台管理系统(7)-MVC与EasyUI DataGrid
6
ASP.NET MVC5+EF6+EasyUI 后台管理系统(28)-系统小结
7
ASP.NET MVC5+EF6+EasyUI 后台管理系统(60)-系统总结
8
ASP.NET MVC5+EF6+EasyUI 后台管理系统(80)-自由桌面
9
ASP.NET MVC5+EF6+EasyUI 后台管理系统(91)-EF 连接 MySql
10
ASP.NET MVC5+EF6+EasyUI 后台管理系统(41)-组织架构
11
ASP.NET MVC5+EF6+EasyUI 后台管理系统(58)-DAL层重构
12
ASP.NET MVC5+EF6+EasyUI 后台管理系统(59)-BLL层重构
13
ASP.NET MVC5+EF6+EasyUI 后台管理系统-关于WebApi的用法
14
ASP.NET MVC5+EF6+EasyUI 后台管理系统(90)-EF 扩展操作
15
ASP.NET MVC5+EF6+EasyUI 后台管理系统(5)-EF增删改查
16
ASP.NET MVC5+EF6+EasyUI 后台管理系统(6)-Unity 依赖注入
17
ASP.NET MVC5+EF6+EasyUI 后台管理系统(33)-MVC 表单验证
18
ASP.NET MVC5+EF6+EasyUI 后台管理系统(17)-LinQ动态排序
19
ASP.NET MVC5+EF6+EasyUI 后台管理系统(63)-WebApi与Unity注入
20
ASP.NET MVC5+EF6+EasyUI 后台管理系统(57)-插件---ueditor使用
21
ASP.NET MVC5+EF6+EasyUI 后台管理系统(50)-Easyui 扁平化皮肤
22
ASP.NET MVC5+EF6+EasyUI 后台管理系统(32)-swfupload多文件上传[附源码]
23
ASP.NET MVC5+EF6+EasyUI 后台管理系统(31)-MVC使用RDL报表
24
ASP.NET MVC5+EF6+EasyUI 后台管理系统(30)-本地化(多语言)
25
ASP.NET MVC5+EF6+EasyUI 后台管理系统-分配角色给用户
26
ASP.NET MVC5+EF6+EasyUI 后台管理系统--工作流演示截图
27
ASP.NET MVC5+EF6+EasyUI 后台管理系统(63)-Excel导入和导出
28
ASP.NET MVC5+EF6+EasyUI 后台管理系统(62)-EF链接串加密
29
ASP.NET MVC5+EF6+EasyUI 后台管理系统(92)-打印EasyUI 的datagrid表格
30
ASP.NET MVC5+EF6+EasyUI 后台管理系统(87)-MVC Excel导入和导出

ASP.NET MVC5+EF6+EasyUI 后台管理系统(30)-本地化(多语言)

我们的系统有时要扩展到其他国家,或者地区,需要更多的语言环境,微软提供了一些解决方案,原始我们是用js来控制的,现在不需要了。

我们只要创建简单的资源文件,通过MVC的路由设置就可以轻松的进行语言中的切换。

本节受益于:Asp.net MVC3 高级编程第121页。大家可以自行百度这本书,这应该是国内第一本中文版的MVC3.0教程

现在从项目入手吧(本节也适合其他MVC程序),新建一个语言项目来放资源文件。

一、新建App.Lang,同时新建BaseRes.resx和BaseRes.en.resx或者其他国语言

分别是中文,英文。并引用System.Web类库i

二、处理通讯,配置App.Admin web.config,让这个类生效

在App.Admin中的Core文件夹添加CultureAwareHttpModule文件并继承IHttpModule

代码语言:javascript
复制
using System;
using System.Collections.Generic;
using System.Globalization;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Web;
using System.Web.Routing;

namespace App.Admin
{
    public class CultureAwareHttpModule : IHttpModule
    {
        private CultureInfo currentCulture;
        private CultureInfo currentUICulture;

        public void Dispose() { }
        public void Init(HttpApplication context)
        {
            context.BeginRequest += SetCurrentCulture;
            context.EndRequest += RecoverCulture;
        }
        private void SetCurrentCulture(object sender, EventArgs args)
        {
            currentCulture = Thread.CurrentThread.CurrentCulture;
            currentUICulture = Thread.CurrentThread.CurrentUICulture;
            HttpContextBase contextWrapper = new HttpContextWrapper(HttpContext.Current);
            RouteData routeData = RouteTable.Routes.GetRouteData(contextWrapper);
            if (routeData == null)
            {
                return;
            }
            object culture;
            if (routeData.Values.TryGetValue("lang", out culture))
            {
                try
                {
                    Thread.CurrentThread.CurrentCulture = new CultureInfo(culture.ToString());
                    Thread.CurrentThread.CurrentUICulture = new CultureInfo(culture.ToString());
                }
                catch
                { }
            }
        }
        private void RecoverCulture(object sender, EventArgs args)
        {
            Thread.CurrentThread.CurrentCulture = currentCulture;
            Thread.CurrentThread.CurrentUICulture = currentUICulture;
        }
    }
}

这里必须做个声明:下面2段第一段支持MVC3,第二段支持MVC4

-----------------------MVC3.0

<system.web>

<httpModules> <add name="CultureAwareHttpModule" type=" App.Admin.CultureAwareHttpModule,App.Admin"/> </httpModules> </system.web>

-----------------------MVC4.0 (VS2012 版本配置以下, VS2010的MVC4版本配置同MVC3.0)

<system.webServer> <modules> <add name="CultureAwareHttpModule" type="App.Admin.CultureAwareHttpModule,App.Admin"/> </modules>

</system.webServer>

红色部分在system.web节点内,type包含的是命名空间

三、注册路由

打开RouteConfig.cs,注册为

代码语言:javascript
复制
   public static void RegisterRoutes(RouteCollection routes)
        {
            routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

            routes.MapRoute(
                "Globalization", // 路由名称
                "{lang}/{controller}/{action}/{id}", // 带有参数的 URL
                new { lang = "zh", controller = "Home", action = "Index", id = UrlParameter.Optional }, // 参数默认值
                new { lang = "^[a-zA-Z]{2}(-[a-zA-Z]{2})?$" }    //参数约束
            );

            routes.MapRoute(
                "Default", // 路由名称
                "{controller}/{action}/{id}", // 带有参数的 URL
                new { controller = "Home", action = "Index", id = UrlParameter.Optional } // 参数默认值
            );

        }

路由执行有先后大家都懂的。可以看出最后我们的访问会是这样的

http://localhost:1201/(http://localhost:1201/zh),http://localhost:1201/等

四、将要本地化的项目引用App.Lang

回到Resx文件,打开Resx设置代码为的访问修饰符为public,并添加如下属性,可以看出是键值对应

这里我们以SysSample的index视图为例,回到index上修改如下代码

先引入@using App.Lang;然后修改以下代码

代码语言:javascript
复制
<div class="mvctool">
    <input id="txtQuery" type="text" class="searchText" />
    @Html.ToolButton("btnQuery", "icon-search",BaseRes.Query, perm, "Query", true)
    @Html.ToolButton("btnCreate", "icon-add", BaseRes.Create, perm, "Create", true)
    @Html.ToolButton("btnEdit", "icon-edit", BaseRes.Edit, perm, "Edit", true)
    @Html.ToolButton("btnDetails", "icon-details", BaseRes.Details, perm, "Details", true)
    @Html.ToolButton("btnDelete", "icon-remove", BaseRes.Delete, perm, "Delete", true)
    @Html.ToolButton("btnExport", "icon-export", BaseRes.Export, perm, "Export", true)
</div>

其中的BaseRes.Query就是国际化属性了

预览一下例子(请注意我的URL地址变化)

 现在你可以本地化您的项目了。最后一个声明,如果你要获取当然选中的是什么语言你必须在页面引用

 CultureInfo info = Thread.CurrentThread.CurrentCulture;

通过info.Name可以获取到URL上选择的zh或en

例: 

代码语言:javascript
复制
src='/@info.Name/SysSample/Create'

结果

代码语言:javascript
复制
src='/en/SysSample/Create'
下一篇
举报
领券