我的网站使用如下创建的自定义文化:
var cib = new CultureAndRegionInfoBuilder("en-gb-xxxx", CultureAndRegionModifiers.None);
cib.LoadDataFromCultureInfo(new CultureInfo("en-gb"));
cib.LoadDataFromRegionInfo(new RegionInfo("en"));
cib.Register();
使用方式如下:
Thread.CurrentThread.CurrentCulture = CultureInfo.CreateSpecificCulture("en-gb-xxxx");
Thread.CurrentThread.CurrentUICulture = new CultureInfo("en-gb-xxxx");
一切工作正常,直到我想使用 ReportViewer 控件呈现报告为止。报告文本呈现正常,但图像失败,并且出现以下错误:
System.Globalization.CultureNotFoundException:不支持文化。参数名称:culture 4096 (0x1000) 是无效的区域性标识符
经过大量谷歌搜索后,我发现很多其他人都在问同样的问题,不幸的是总是没有得到解答。 这篇文章非常清楚地描述了问题,但没有提供任何解决方案。
如果没有解决办法,有没有人可以提供解决方法?
由于没有答案,我不得不破解:
首先,我创建了一个
CustomReportViewer
,继承自原生 Microsoft.Reporting.WebForms.ReportViewer
并覆盖 OnPreRender
方法。它检查登录用户的文化(保存在会话中)并回滚到父文化(如果有)。
protected override void OnPreRender(EventArgs e)
{
var culture = new CultureInfo(HttpContext.Current.Session["UserCulture"]);
if (culture.CompareInfo.LCID != culture.LCID){
var baseCulture = new CultureInfo(culture.CompareInfo.LCID);
System.Threading.Thread.CurrentThread.CurrentCulture = baseCulture;
System.Threading.Thread.CurrentThread.CurrentUICulture = baseCulture;
}
base.OnPreRender(e);
}
然后我改变了aspx页面中的对象:
<web:CustomReportViewer ID="ReportViewer1" runat="server" AsyncRendering="false" SizeToReportContent="true" ProcessingMode="Remote">
瞧瞧
我不会接受这个答案,希望有人能想出一些......更干净的东西
我找到了上述问题的解决方案:
问题:
在报表查看器中不支持导出文化。参数名称:culture 4096 (0x1000) 是无效的区域性标识符。
解决方案::
1.) 在顶部添加以下指令
<% @Import Namespace="System.Globalization" %>
<% @Import Namespace="System.Threading" %>
或者
using System.Threading;
using System.Globalization;
2.) 添加事件如下:
protected void FPReportViewer_PreRender(object sender, EventArgs e)
{
CultureInfo ci = new CultureInfo("en-US");
Thread.CurrentThread.CurrentCulture = ci;
Thread.CurrentThread.CurrentUICulture = ci;
}
3.) 更新 Reportviewer html 标签如下:
<rsweb:ReportViewer runat="server" ID="FPReportViewer" OnPreRender="FPReportViewer_PreRender" AsyncRendering="false" width="100%" SizeToReportContent="True"> </rsweb:ReportViewer>
愿这段代码对您有帮助。
非常感谢!
在发送到 SSRS 之前尝试一下
Thread.CurrentThread.CurrentCulture =
Thread.CurrentThread.CurrentUICulture =
CultureInfo.DefaultThreadCurrentCulture =
CultureInfo.DefaultThreadCurrentUICulture = CultureInfo.GetCultureInfo("en-US");
例如:
[SessionExpire]
public ActionResult ReportProduct(string ExpenseCenter)
{
Thread.CurrentThread.CurrentCulture =
Thread.CurrentThread.CurrentUICulture =
CultureInfo.DefaultThreadCurrentCulture =
CultureInfo.DefaultThreadCurrentUICulture = CultureInfo.GetCultureInfo("en-US");
ReportViewer reportViewer = new ReportViewer();
reportViewer.ProcessingMode = ProcessingMode.Remote;
reportViewer.SizeToReportContent = true;
reportViewer.AsyncRendering = false;
reportViewer.ZoomMode = ZoomMode.FullPage;
reportViewer.Width = Unit.Percentage(100);
reportViewer.Height = Unit.Percentage(100);
var serverReport = reportViewer.ServerReport;
serverReport.ReportPath = "/Reports/ReportPrice";
serverReport.ReportServerUrl = new Uri("http://ssrs-server:94/ReportServer_MSSQLSERVER2016/");
serverReport.SetParameters(GetParametersServer());
serverReport.Refresh();
ViewBag.ReportViewer = reportViewer;
return View();
}
当您在不使用 ReportViewer 的情况下直接将 rdlc 报告渲染/导出为其他格式时,就会有这个答案:LocalReport 方法渲染的线程文化