嗨 - 我计划基于“Accept-Language”标头,通过基于该标头设置 CurrentUICulture 来处理错误字符串等的服务器端本地化,但显然它不会通过异步调用,下面是示例代码来说明问题,是否有处理异步调用本地化的默认方法?
public async Task<HttpResponseMessage> GetAsync()
{
//set the current ui culture, to say "fr-FR", based on "Accept-Language" header
Thread.CurrentThread.CurrentUICulture = CultureInfo.GetCultureInfo("**fr-FR**");
var task = httpClient.PutAsync(endpoint, content)
//do some processing
var res = await task;
var culture = Thread.CurrentThread.CurrentUICulture.Name; **//ITS NOT necessarily fr-FR**
//do some more processing
//and handle localizations etc.
return res;
}
我正在寻找一种更干净/无缝的方法来处理存在真正异步操作(特别是)的情况下的本地化。对于await 调用之后的代码
编辑:为清楚起见,将 Task.Run() 替换为 httpClient.PutAsync
Task.Run
and Task.Factory.StartNew
没有任何上下文。这是预期的行为。当您使用时,上下文会被保留await
关键词。所以你可以这样做:
public static async Task<IEnumerable<string>> GetAsync()
{
//set the current ui culture, to say "fr-FR", based on "Accept-Language" header
Thread.CurrentThread.CurrentUICulture = CultureInfo.GetCultureInfo("fr-FR");
//do some processing
var s = await GetSomething();
var culture = Thread.CurrentThread.CurrentUICulture.Name; //It's ja-JP
return new[] { s, s };
}
public static Task<string> GetSomething()
{
var cuture = Thread.CurrentThread.CurrentUICulture.Name; // It's fr-FR
var tcs = new TaskCompletionSource<string>();
Thread.CurrentThread.CurrentUICulture = CultureInfo.GetCultureInfo("ja-JP");
tcs.SetResult("<something>");
return tcs.Task;
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)