【发布时间】:2011-04-18 01:36:08
【问题描述】:
每当我尝试在报告服务器上列出报告时,都会收到错误消息“请求失败,HTTP 状态 401:未经授权”。奇怪的是,当我在我的开发机器上运行 asp.net 应用程序并点击服务器报告服务 web 服务 url (http://www.example.com/reports/reportservice2005.asmx?wsdl) 但当 asp.net 应用程序安装在服务器上时(运行 iis 7)点击相同的网址我得到了错误。这是我的设置:
服务器:
SQL Server 报告服务 2008(非 R2)
网络服务网址:http://www.example.com/reports/reportservice2005.asmx?wsdl
客户
创建了一个代理 ReportingServices2005.cs
Web.config 有
列出报告的代码:
<asp:ListView ID="lvReportList" runat="server">
<LayoutTemplate>
<ul>
<asp:PlaceHolder runat="server" ID="itemPlaceholder"></asp:PlaceHolder>
</ul>
</LayoutTemplate>
<ItemTemplate>
<li>
<asp:HyperLink runat="server" ID="hpReportLink" NavigateUrl='<%#Eval("Url")%>'><%#Eval("Name")%></asp:HyperLink>
</li>
</ItemTemplate>
<EmptyDataTemplate>
<div>
No reports to display.
</div>
</EmptyDataTemplate>
代码背后:
protected void Page_Load(object sender, EventArgs e)
{
if (!Page.IsPostBack)
{
string rWebServiceUrl = ConfigurationManager.AppSettings["RSWebserviceUrl"];
string reportServerFolder = ConfigurationManager.AppSettings["ReportServerFolder"];
string domain = ConfigurationManager.AppSettings["RSDomain"];
string userName = ConfigurationManager.AppSettings["RSUsername"];
string password = ConfigurationManager.AppSettings["RSPassword"];
objRS.Url = rWebServiceUrl;
objRS.Credentials = new NetworkCredential(userName, password, domain);
ReportingServices2005.CatalogItem[] items = objRS.ListChildren(reportServerFolder, false);
var reportList = from p in items
select new
{
Name = p.Name,
Url = String.Format("{0}?reportPath={1}/{2}", ReportViewerUrl, reportServerFolder, p.Name)
};
lvReportList.DataSource = reportList;
lvReportList.DataBind();
}
}
【问题讨论】:
标签: c# sql web-services ssrs-2008