.Net Crystal Reports 13 可以使用应用程序池身份登录 SQL Server 吗?

Posted

技术标签:

【中文标题】.Net Crystal Reports 13 可以使用应用程序池身份登录 SQL Server 吗?【英文标题】:.Net can Crystal Reports 13 use app pool identity to login to SQL Server? 【发布时间】:2018-10-04 23:59:59 【问题描述】:

我在网络表单中嵌入了一个水晶报表,但它无法使用应用程序池标识连接到 SQL Server。我们有一个使用服务帐户访问 Web 应用程序的 sql 服务器。我已经使用服务帐户凭据配置了应用程序池 ID。我的 Web 应用程序能够连接到 SQL Server。 水晶报表 13 和 SQL SERVER 2016 web.config

<add name="ConnName" connectionString="server=ServerName; database=DB_Name; Trusted_Connection=yes;" providerName="System.Data.SqlClient"

并更改了 Crystal Report 数据库设置

SqlConnectionStringBuilder conString = new SqlConnectionStringBuilder(ConfigurationManager.ConnectionStrings["ConnName"].ToString());
foreach (CrystalDecisions.Shared.IConnectionInfo RC in CReport.DataSourceConnections)

    RC.SetConnection(connectionInfo.ServerName, connectionInfo.DatabaseName, true);
    foreach (ReportDocument subReport in CReport.Subreports)
    
        foreach (CrystalDecisions.Shared.IConnectionInfo subConn in subReport.DataSourceConnections)
        
        rptConn.SetConnection(connectionInfo.ServerName, connectionInfo.DatabaseName, true);
        
    

即使我更改了报告连接,它仍然提示登录数据库。 如何使用服务帐户凭据动态设置 sql server 的水晶报表登录?或者如果我使用受信任的连接,我该如何模拟应用程序池身份。

【问题讨论】:

【参考方案1】:

以下是取自Click to go to site 的示例代码。 这是示例代码,但却是一个很好的起点。和你目前的比较一下,看看有什么不同。

using System;
using System.Windows.Forms;
using CrystalDecisions.CrystalReports.Engine;
using CrystalDecisions.Shared;

namespace WindowsApplication1

    public partial class Form1 : Form
    
        public Form1()
        
            InitializeComponent();
        

        private void button1_Click(object sender, EventArgs e)
        
            ReportDocument cryRpt = new ReportDocument();
            TableLogOnInfos crtableLogoninfos = new TableLogOnInfos();
            TableLogOnInfo crtableLogoninfo = new TableLogOnInfo();
            ConnectionInfo crConnectionInfo = new ConnectionInfo();
            Tables CrTables ;

            cryRpt.Load("PUT CRYSTAL REPORT PATH HERE\CrystalReport1.rpt");

            crConnectionInfo.ServerName = "YOUR SERVER NAME";
            crConnectionInfo.DatabaseName = "YOUR DATABASE NAME";
            crConnectionInfo.UserID = "YOUR DATABASE USERNAME";
            crConnectionInfo.Password = "YOUR DATABASE PASSWORD";

            CrTables = cryRpt.Database.Tables ;
            foreach (CrystalDecisions.CrystalReports.Engine.Table CrTable in CrTables)
            
                crtableLogoninfo = CrTable.LogOnInfo;
                crtableLogoninfo.ConnectionInfo = crConnectionInfo;
                CrTable.ApplyLogOnInfo(crtableLogoninfo);
            

            crystalReportViewer1.ReportSource = cryRpt;
            crystalReportViewer1.Refresh(); 
        
    


【讨论】:

以上是关于.Net Crystal Reports 13 可以使用应用程序池身份登录 SQL Server 吗?的主要内容,如果未能解决你的问题,请参考以下文章

用于 Visual Studio 2012 的 Crystal Reports 13.07 未在浏览器中呈现

更改 Crystal Reports 查看器连接字符串 ASP.NET

VS2015环境下Crystal Reports(水晶报表)的安装使用

Microsoft Visual Studio Ultimate 2012 中用于 .NET 的 Crystal Reports

Vb.net 和 Crystal Reports 添加组和子报表

Crystal Reports v13.0.2000.0.:为啥“where”子句在子报表中不起作用?