分几步进行,第一步要实现:IReportServerCredentials 接口
第二步:拖入ReportViewer控件
第三步:进行报表传参控制。具体如下图描述。。。。代码部分参考下附件
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using TajimaOA.UI;
using System.Data;
using Microsoft.Reporting.WebForms;
namespace TajimaOA.UI.BISSRSViewer
{
public partial class BISSRSViewer : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
//string l_ReportServerUrl = System.Web.Configuration.WebConfigurationManager.AppSettings["BIReportServerUrl"];//获取报表服务地址
if (!IsPostBack)
{
string l_CompanyID = this.Request["CompanyID"];
string l_DepartmentID = this.Request["DepartmentID"];
string l_EmployeeID = this.Request["EmployeeID"];
string l_IsGetCurrentUserID = this.Request["GetUser"];
//项目
string l_ProjectID = this.Request["ProjectID"];//2014-04-18 add by WesChen 项目ID
string l_ProjectState = this.Request["ProjectState"];//2014-04-18 add by WesChen 项目状态
//任务
string l_TaskID = this.Request["TaskID"];//2014-04-18 add by WesChen 项目任务ID
string l_TaskState = this.Request["TaskState"];//2014-04-18 add by WesChen 项目任务ID
string l_TaskStponeCode = this.Request["TaskStponeCode"];//2014-04-18 add by WesChen 项目任务延期编号
string l_ReportCode = this.Request["ReportCode"];
TajimaOA.UI.Areas.BI.Controllers.SSRSReport.SSRSManagerController l_ServiceClient = new Areas.BI.Controllers.SSRSReport.SSRSManagerController();
DataTable l_dt = l_ServiceClient.GetReportSettingByReportCode(l_ReportCode);
if (l_dt == null || l_dt.Rows.Count == 0)
{
}
else
{
string l_ReportServerUrl = l_dt.Rows[0]["ServerUrl"].ToString();
string l_ReportFolder = l_dt.Rows[0]["FolderCode"].ToString();
string l_Report = l_dt.Rows[0]["ReportCode"].ToString();
string l_SSRSUser = System.Web.Configuration.WebConfigurationManager.AppSettings["BISSRS-User"];//获取凭证用户名
string l_SSRSPassword = System.Web.Configuration.WebConfigurationManager.AppSettings["BISSRS-Password"];//获取凭证口令
string l_SSRSDomainName = System.Web.Configuration.WebConfigurationManager.AppSettings["BISSRS-DomainName"];//获取凭证域
BI_RptViewer.ServerReport.ReportServerCredentials = new CustomReportCredentials(l_SSRSUser, l_SSRSPassword, l_SSRSDomainName);
BI_RptViewer.ServerReport.ReportServerUrl = new Uri(l_ReportServerUrl.Trim());
BI_RptViewer.ServerReport.ReportPath = l_ReportFolder + l_Report;
BI_RptViewer.ShowBackButton = true;
BI_RptViewer.ShowPrintButton = true;
//2014-03-05 add by WesChen 增加报表参数
List<ReportParameter> l_ParList = new List<ReportParameter>();
if (l_IsGetCurrentUserID == "Y")
{
ReportParameter l_RptPar_CurrentUserID = new ReportParameter();
l_RptPar_CurrentUserID.Name = "CurrentUserID";
Guid l_CurrentUserID = TajimaOA.UI.Common.ComonMethods.GetCurrentUserID();//当前登陆用户ID
l_RptPar_CurrentUserID.Values.Add(l_CurrentUserID.ToString());
l_ParList.Add(l_RptPar_CurrentUserID);
}
if (!string.IsNullOrEmpty(l_CompanyID))
{
ReportParameter l_RptPar_CompanyID = new ReportParameter();
l_RptPar_CompanyID.Name = "CompanyID";
l_RptPar_CompanyID.Values.Add(l_CompanyID);
l_ParList.Add(l_RptPar_CompanyID);
}
if (!string.IsNullOrEmpty(l_DepartmentID))
{
ReportParameter l_RptPar_DepartmentID = new ReportParameter();
l_RptPar_DepartmentID.Name = "DepartmentID";
l_RptPar_DepartmentID.Values.Add(l_DepartmentID);
l_ParList.Add(l_RptPar_DepartmentID);
}
if (!string.IsNullOrEmpty(l_EmployeeID))
{
ReportParameter l_RptPar_EmployeeID = new ReportParameter();
l_RptPar_EmployeeID.Name = "EmployeeID";
l_RptPar_EmployeeID.Values.Add(l_EmployeeID);
l_ParList.Add(l_RptPar_EmployeeID);
}
//-------------------------------------------
//2014-04-18 add by WesChen 项目ID
if (!string.IsNullOrEmpty(l_ProjectID))
{
ReportParameter l_RptPar_ProjectID = new ReportParameter();
l_RptPar_ProjectID.Name = "ProjectID";
l_RptPar_ProjectID.Values.Add(l_ProjectID);
l_ParList.Add(l_RptPar_ProjectID);
}
//2014-04-18 add by WesChen 项目状态
if (!string.IsNullOrEmpty(l_ProjectState))
{
ReportParameter l_RptPar_ProjectState = new ReportParameter();
l_RptPar_ProjectState.Name = "ProjectState";
l_RptPar_ProjectState.Values.Add(l_ProjectState);
l_ParList.Add(l_RptPar_ProjectState);
}
//------------------------------------------
//2014-04-18 add by WesChen 项目任务ID
if (!string.IsNullOrEmpty(l_TaskID))
{
ReportParameter l_RptPar_ProjectTaskID = new ReportParameter();
l_RptPar_ProjectTaskID.Name = "ProjectTaskID";
l_RptPar_ProjectTaskID.Values.Add(l_TaskID);
l_ParList.Add(l_RptPar_ProjectTaskID);
}
//2014-04-18 add by WesChen 项目任务ID
if (!string.IsNullOrEmpty(l_TaskState))
{
ReportParameter l_RptPar_TaskState = new ReportParameter();
l_RptPar_TaskState.Name = "TaskState";
l_RptPar_TaskState.Values.Add(l_TaskState);
l_ParList.Add(l_RptPar_TaskState);
}
//2014-04-18 add by WesChen 项目任务是否延期
if (!string.IsNullOrEmpty(l_TaskStponeCode))
{
ReportParameter l_RptPar_TaskStponeCode = new ReportParameter();
l_RptPar_TaskStponeCode.Name = "TaskStponeCode";
l_RptPar_TaskStponeCode.Values.Add(l_TaskStponeCode);
l_ParList.Add(l_RptPar_TaskStponeCode);
}
if (l_ParList.Count > 0)
{
BI_RptViewer.ServerReport.SetParameters(l_ParList);
}
}
}
}
}
[Serializable]
public class CustomReportCredentials : Microsoft.Reporting.WebForms.IReportServerCredentials
{
// local variable for network credential.
private string _UserName;
private string _PassWord;
private string _DomainName;
public CustomReportCredentials(string UserName, string PassWord, string DomainName)
{
_UserName = UserName;
_PassWord = PassWord;
_DomainName = DomainName;
}
public System.Security.Principal.WindowsIdentity ImpersonationUser
{
get
{
return null; // not use ImpersonationUser
}
}
public System.Net.ICredentials NetworkCredentials
{
get
{
// use NetworkCredentials
return new System.Net.NetworkCredential(_UserName, _PassWord, _DomainName);
}
}
public bool GetFormsCredentials(out System.Net.Cookie authCookie, out string user, out string password, out string authority)
{
// not use FormsCredentials unless you have implements a custom autentication.
authCookie = null;
user = password = authority = null;
return false;
}
}
}
http://www.flybi.net/question/2835
- Spring 4 官方文档学习(十三)集成其他web框架
重点是通用配置,非常建议看一下!有助于理解Spring的ApplicationContext与Servlet Container的关系! 1.介绍 Spring Web Flow SWF目标是成为we ...
- 使用Apache CXF和Spring集成创建Web Service(zz)
使用Apache CXF和Spring集成创建Web Service 您的评价: 还行 收藏该经验 1.创建HelloWorld 接口类 查看源码 打印? 1 package ...
- 5.把报表集成到Web应用程序中-生成网页和导出两种方式
转自:https://wenku.baidu.com/view/104156f9770bf78a65295462.html 第四部分,把报表集成到Web应用程序中 用MyEclipse新建一个Web ...
- Spark与Spring集成做web接口
需要实现的功能: 写访问spark的接口,也就是从web上输入网址就能把我们需要的信息通过提交一个job然后返回给我们json数据. 成果展示: 通过url请求,然后的到一个wordcount的jso ...
- SignalR SelfHost实时消息,集成到web中,实现服务器消息推送
先前用过两次SignalR,但是中途有段时间没弄了,今天重新弄,发现已经忘得差不多了,做个笔记! 首先创建一个控制台项目Nuget添加引用联机搜索:Microsoft.AspNet.SignalR.S ...
- SharePoint RBS 安装(集成Office Web Apps)
前言 本文完全原创,转载请说明出处,希望对大家有用. 本篇博客是个人总结,一方面以便日后查看,另一方面希望能为其他人提供一些便利. 阅读目录 安装RBS 为多个内容数据库开启RBS 正文 目的:在Sh ...
- Python Tornado集成JSON Web Token方式登录
本项目github地址 前端测试模板如下: Tornado restful api 项目 项目结构如下: 项目组织类似于django,由独立的app模块构成. 登录接口设计 模式:post -> ...
- .Net Core集成Office Web Apps(二)
想要使用OWA需要一台单独的服务器来部署,这对很多人造成困难.而写该文的目的是为了分享有个OWA的集成步骤,它不仅适用于.Net开发环境,其它语言也是一样的,只要实现了需要的服务接口.并且该文不局限与 ...
- .Net Core集成Office Web Apps(一)
最近开始学习.Net Core,并使用Visual Studio Code工具来开发.感觉开发起来特别的方便,但是有个头疼的地方:许多的类库被修改了,一时半会儿还熟悉不了,需要查阅官方API... M ...
随机推荐
- NOIP2005 谁拿了最多奖学金
1谁拿了最多奖学金 (scholar.pas/c/cpp) [问题描述] 某校的惯例是在每学期的期末考试之后发放奖学金.发放的奖学金共有五种,获取的条件各自不同: 1) 院士奖学金,每人800 ...
- Android SDK Manager无法更新的解决办法
Fetching https://dl-ssl.google.com/android/repository/addons_list-1.xmlFailed to fetch URL https://d ...
- Code First 更新数据库结构
参考:http://blog.csdn.net/sxycxwb/article/details/12186159 0.删除之前的数据库 1.Run the Enable-Migrations comm ...
- 有关按位DP
这是一道正式比赛的题目 数据范围是 10^999 ~ 10^1000 的两个整数以及一个k我记得好像是不超过100,计算两个数中间有多少个每一位相乘最后和k取摸等于0的数.这道题对于不会按位dp的人是 ...
- Mysql的函数使用方法
今天有点临时需求要计算一张表的结果,不想写代码,想到了mysql的自定义函数.碰到了很多问题,为了方便一下使用,在此记录一下. 需求:一张表中,有比分,需要查询出比赛id和比赛结果. 分析: ...
- HDU-4691 Front compression 后缀数组
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4691 后缀数组模板题,求出Height数组后,对Height做RMQ,然后直接统计就可以了... // ...
- delphi 常用属性+方法+事件+代码+函数
内容居中(属性) alignment->tacenter mome控件 禁用最大化(属性) 窗体-> BorderIcons属性-> biMaximize-> False 让鼠 ...
- nyoj 199 无线网络覆盖
无线网络覆盖 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 我们的乐乐同学对于网络可算得上是情有独钟,他有一个计划,那就是用无线网覆盖郑州大学. 现在学校给了他一个 ...
- nyoj 448 寻找最大数
寻找最大数 时间限制:1000 ms | 内存限制:65535 KB 难度:2 描述 请在整数 n 中删除m个数字, 使得余下的数字按原次序组成的新数最大, 比如当n=920813467185 ...
- ASP.NET- 无刷新上传使用jQuery插件之ajaxFileUpload
灰常好,我已经使用过里面的代码了,可以用,原文地址:http://www.cnblogs.com/kissdodog/archive/2012/12/15/2819025.html 一.ajaxFil ...