mp3dj,广州婚纱街,粤y
根据市场需求,基于.net core平台开发的需要实现多语言版本。经过方案讨论和比对,决定采用.net自带的本地化功能来实现多语言。话不多说,直接上实现方式。
首先修改startup.cs
在public void configureservices(iservicecollection services)方法中加入:
//设置语言包文件夹名称 services.addlocalization(o => { o.resourcespath = "language"; });
services.addmvc().setcompatibilityversion(compatibilityversion.version_2_1).addviewlocalization(languageviewlocationexpanderformat.suffix);
这里指定语言包所在目录,相对于项目根目录下。从上图中看到项目根目录下有一个language文件夹。
在public void configure(iapplicationbuilder app, ihostingenvironment env)方法中加入:
ilist<cultureinfo> supportedcultures = new list<cultureinfo> { new cultureinfo("zh-cn"), new cultureinfo("zh"), new cultureinfo("en-us") }; app.userequestlocalization(new requestlocalizationoptions {
//这里指定默认语言包 defaultrequestculture = new requestculture("zh-cn"), supportedcultures = supportedcultures, supporteduicultures = supportedcultures });
到这里启动文件就设置好了。
在根目录下新建language目录,用于存放语言包
语言包下的目录结构和mvc对应,控制器对应控制器,视图对应视图。
目录下新建资源文件:
core加载资源文件的方式有三种:url,cookie,请求头。我们这里采用cookie。所以在打开首页的时候写了一个cookie:
response.cookies.append(".aspnetcore.culture", "c=en-us|uic=en-us");
.aspnetcore.culture为cookie key。接下来就可以开始使用语言包了。
控制器中使用:
在控制器中加入:
private readonly istringlocalizer<homecontroller> _localizer; public homecontroller(istringlocalizer<homecontroller> localizer) { _localizer = localizer; }
接下来在使用语言的地方:
_localizer["资源文件中定义的名称"]就可以读取到相应的语言了。
在视图中使用:
视图顶部引用:
@using microsoft.aspnetcore.mvc.localization @inject iviewlocalizer localizer
在要使用语言的地方就可以使用了:
localizer["welcome"]
如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复
asp.net搭建博客,使用BlogEngine.NET+MySql搭建博客
网友评论