热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

锐浪报表系统支持高效条件查询功能

在即将完成的人事项目中,报表管理问题依然未能得到有效解决。尽管前端采用了MVC开发模式,但与锐浪报表系统的集成存在兼容性问题。虽然简单查询所有数据相对容易实现,但用户希望能够在报表中进行更复杂的条件查询和直接操作。为满足这一需求,我们正积极探索优化方案,以提升系统的查询效率和用户体验。

        人事项目快要结束了,但是报表问题还是得不到解决。我们前台采用MVC开发模式,但是MVC和锐浪不能很好的结合。如果是一下查询所有的数据还是比较简单的,但是用户需求是能对报表直接操作,按条件查询。无奈,找到一个解决办法,那就是将报表单独发布一个系统,当人事系统调用报表时则跳转到报表系统的独立连接。下面来说说如何给锐浪报表单独发布。

       报表插件运行在客户端电脑上,可以用报表插件的编程接口将网页客户端上的数据加载到报表中,如将网页上的UI界面上的数据传入到报表中进行打印等。

       在设计报表模板时,通常会设置数据源连接串与查询SQL语句,如果在报表插件中没有为报表关联服务器URL数据,报表模板中的数据源设置将会被应用,报表插件将尝试从对应数据源中获取报表数据。此种方式会存在严重的弊端,因为连接串中的数据库用户与密码信息是固定的,客户端必须具有直接访问数据库的权限,这样会有很大的安全局限性,特别是对于Internet网(广域网)来说,客户端肯定不能直接访问数据库。WEB报表应该关联报表数据DataURL,从 DataURL 处获取 XML 数据, 这样客户端肯定能访问WEB服务器,这样肯定不存在访问权限限制。除此之外,这种方式获取报表数据需要Windows 客户端提供对应数据库的 OLE DB 驱动程序,如 Oracle、MySQL 等很多数据库在 Windows 下并没有直接安装有其 OLEDB 驱动程序,这样就需要为每个客户端安装 OLE DB 驱动程序,这样也会极大增加软件部署的难度。所以强烈建议不采用这种方式为WEB报表提供数据。

一、在网页中插入报表插件

        在网页中通过插入 object标签将各种浏览器插件嵌入到网页中,Grid++Report报表插件也是通过这样的方式将其嵌入到网页中。Grid++Report为此定义了专门的Javascript 函数来简化此任务,相关函数定义在例子程序的 CreateControl.js代码文件中,每个函数的参数说明在代码中都有详细注释说明。下面是CreateControl.js 代码:

 

//1、变量 gr_InstallPath 等号后面的参数是插件安装文件的所在的网站目录,一般从网站的根目
// 录开始寻址,插件安装文件一定要存在于指定目录下。
//2、gr_Version 等号后面的参数是插件安装包的版本号,如果有新版本插件安装包,应上传新版
// 本插件安装文件到网站对应目录,并更新这里的版本号。
//3、更多详细信息请参考帮助中“报表插件(WEB报表)->在服务器部署插件安装包”部分
var gr_InstallPath = "grinstall"; //实际项目中应该写从根目录寻址的目录,如gr_InstallPath="/myapp/report/grinstall";
var gr_Version = "6,0,15,0819";

//以下注册号为本机开发测试注册号,报表访问地址为localhost时可以去掉试用标志
//购买注册后,请用您的注册用户名与注册号替换下面变量中值
var gr_UserName = '锐浪报表插件本机开发测试注册';
var gr_SerialNo = '8PJH495VA61FLI5TG0L4KB2337F1G7AKLD6LNNA9F9T28IKRU6N33P8Z6XX4BUYB5E9NZ6INMD5T8EN47IX63VV7F9BJHB5ZJQQ6MX3J3V12C4XDHU97SXX6X3VA57KCB6';

//报表插件目前只能在32位浏览器中使用
var _gr_platform = window.navigator.platform;
if (_gr_platform.indexOf("64") > 0)
alert("锐浪Grid++Report报表插件不能运行在64位浏览器中,相关报表与打印功能将无法正常运新,请改用32位浏览器!");

//区分浏览器(IE or not)
var _gr_agent = navigator.userAgent.toLowerCase();
var _gr_isIE = (_gr_agent.indexOf("msie")>0)? true : false;

var gr_CodeBase;
if( _gr_isIE )
gr_CodeBase = 'codebase="' + gr_InstallPath + '/grbsctl6.cab#Version=' + gr_Version + '"';
else
gr_CodeBase = '';

//创建报表对象,报表对象是不可见的对象,详细请查看帮助中的 IGridppReport
//Name - 指定插件对象的ID,可以用js代码 document.getElementById("%Name%") 获取报表对象
//EventParams - 指定报表对象的需要响应的事件,如:" "形式,可以指定多个事件
function CreateReport(PluginID, EventParams)
{
var typeid;
if( _gr_isIE )
typeid = 'classid="clsid:396841CC-FC0F-4989-8182-EBA06AA8CA2F" ';
else
typeid = 'type="application/x-grplugin6-report" ';
typeid += gr_CodeBase;
document.write('');

document.write('');
}

//用更多的参数创建报表打印显示插件,详细请查看帮助中的 IGRPrintViewer
//PluginID - 插件的ID,可以通过 var ReportViewer = document.getElementById("%PluginID%"); 这样的方式获取插件引用变量
//Width - 插件的显示宽度,"100%"为整个显示区域宽度,"500"表示500个屏幕像素点
//Height - 插件的显示高度,"100%"为整个显示区域高度,"500"表示500个屏幕像素点
//ReportURL - 获取报表模板的URL
//DataURL - 获取报表数据的URL
//AutoRun - 指定插件在创建之后是否自动生成并展现报表,值为false或true
//ExParams - 指定更多的插件属性阐述,形如: ""这样的参数串
function CreatePrintViewerEx2(PluginID, Width, Height, ReportURL, DataURL, AutoRun, ExParams)
{
var typeid;
if( _gr_isIE )
typeid = 'classid="clsid:ABB64AAC-D7E8-4733-B052-1B141C92F3CE" ' + gr_CodeBase;
else
typeid = 'type="application/x-grplugin6-printviewer"';
document.write('');
}

//用更多的参数创建报表打印显示插件,详细请查看帮助中的 IGRDisplayViewer
//PluginID - 插件的ID,可以通过 var ReportViewer = document.getElementById("%PluginID%"); 这样的方式获取插件引用变量
//Width - 插件的显示宽度,"100%"为整个显示区域宽度,"500"表示500个屏幕像素点
//Height - 插件的显示高度,"100%"为整个显示区域高度,"500"表示500个屏幕像素点
//ReportURL - 获取报表模板的URL
//DataURL - 获取报表数据的URL
//AutoRun - 指定插件在创建之后是否自动生成并展现报表,值为false或true
//ExParams - 指定更多的插件属性阐述,形如: ""这样的参数串
function CreateDisplayViewerEx2(PluginID, Width, Height, ReportURL, DataURL, AutoRun, ExParams)
{
var typeid;
if( _gr_isIE )
typeid = 'classid="clsid:600CD6D9-EBE1-42cb-B8DF-DFB81977122E" ' + gr_CodeBase;
else
typeid = 'type="application/x-grplugin6-displayviewer"';
document.write('');
}

//以 ReportDesigner 为 ID 创建报表设计器插件(Designer),详细请查看帮助中的 IGRDesigner
//Width - 插件的显示宽度,"100%"为整个显示区域宽度,"500"表示500个屏幕像素点
//Height - 插件的显示高度,"100%"为整个显示区域高度,"500"表示500个屏幕像素点
//LoadReportURL - 读取报表模板的URL,运行时从此URL读入报表模板数据并加载到设计器插件
//SaveReportURL - 保存报表模板的URL,保存设计后的结果数据,由此URL的服务在WEB服务端将报表模板持久保存
//DataURL - 获取报表运行时数据的URL,在设计器中进入打印视图与查询视图时从此URL获取报表数据
//ExParams - 指定更多的插件属性阐述,形如: ""这样的参数串
function CreateDesignerEx(Width, Height, LoadReportURL, SaveReportURL, DataURL, ExParams)
{
var typeid;
if( _gr_isIE )
typeid = 'classid="clsid:CE666189-5D7C-42ee-AAA4-E5CB375ED3C7" ' + gr_CodeBase;
else
typeid = 'type="application/x-grplugin6-designer"';


document.write('');
}

//以 ReportViewer 为 ID 创建报表打印显示器插件(PrintViewer),参数说明参考 CreatePrintViewerEx2
function CreatePrintViewerEx(Width, Height, ReportURL, DataURL, AutoRun, ExParams)
{
CreatePrintViewerEx2("ReportViewer", Width, Height, ReportURL, DataURL, AutoRun, ExParams)
}

//以 ReportViewer 为 ID 创建报表查询显示器插件(DisplayViewer),参数说明参考 CreateDisplayViewerEx2
function CreateDisplayViewerEx(Width, Height, ReportURL, DataURL, AutoRun, ExParams)
{
CreateDisplayViewerEx2("ReportViewer", Width, Height, ReportURL, DataURL, AutoRun, ExParams)
}

//以 ReportViewer 为 ID 创建报表打印显示器插件(PrintViewer),插件大小为100%充满位置区域,插件创建后会自动运行,参数说明参考 CreatePrintViewerEx2
function CreatePrintViewer(ReportURL, DataURL)
{
CreatePrintViewerEx("100%", "100%", ReportURL, DataURL, true, "");
}

//以 ReportViewer 为 ID 创建报表查询显示器插件(DisplayViewer),插件大小为100%充满位置区域,插件创建后会自动运行,参数说明参考 CreateDisplayViewerEx2
function CreateDisplayViewer(ReportURL, DataURL)
{
CreateDisplayViewerEx("100%", "100%", ReportURL, DataURL, true, "");
}

//以 ReportDesigner 为 ID 创建报表设计器插件(Designer),插件大小为100%充满位置区域,参数说明参考 CreateDesignerEx
function CreateDesigner(LoadReportURL, SaveReportURL, DataURL)
{
CreateDesignerEx("100%", "100%", LoadReportURL, SaveReportURL, DataURL, "");
}

    CreateDisplayViewerEx2方法是向网页中插入报表查询显示插件(DisplayViewer),CreateDisplayViewerEx 与 CreateDisplayViewer 是CreateDisplayViewerEx2 的简化版本,目的是为了减少调用参数。开发者应该统一采用 CreateControl.js中的函数来向网页中插入报表插件。

 

二、在网页中插入报表对象

     Grid++Report报表对象是一个不可显示的控件,报表对象在网页中没有直接的显示输出,但调用其方法可以实现很多与报表生成与输出相关的任务。如实现无界面的打印报表,导出报表数据等。报表对象不要求插入在网页BODY 节中,我们一般将其插入在 HEAD 节中。如下代码所示:

 
 

三、在网页中插入报表设计器插件

    Grid++Report报表设计器插件是一个可视化控件,报表设计器插件在网页中可视化地设计报表模板,为用户提供可视化的自定义报表设计功能。下面是在网页中插入设计器插件:

 
 


CreateDesignerEx可以通过最后一个参数可以在创建插件时指定插件的属性值

 
 

四、插件安装包文件部署至服务器

        在部署用 Grid++Report开发的WEB报表时,需要将插件安装包文件一同分发在WEB服务器上,将两个文件(grbsctl6.cab 与grbsctl6.exe)复制到WEB服务器的可下载目录。

        另还要根据实际情况,调整 CreateControl.js文件中的插件部署目录变量值,这样才能保证客户端能找到插件安装包的下载位置。打开 CreateControl.js,将开始处的 gr_InstallPath变量值修改为插件安装包文件所在的网站目录(特别注意:不是文件的磁盘目录),一般采用相对目录或从网站根目录进行寻址的目录。

         举例说明:如将插件安装包复制到网站根目录的 grinstall 子目录下,则CreateControl.js 中 gr_InstallPath 变量应该修改为(vargr_InstallPath = "/grinstall";)。假设服务器 IP 为192.168.1.10,则在浏览器中输入“http://192.168.1.10/grinstall/grbsctl6.cab”,如果能正常下载文件就说明插件安装包已经在服务器成功部署。

 

五、创建报表门户(入口)网页

    报表门户(入口)网页是指在打开各个具体报表网页前的目录(索引/导航)网页,在此网页中实现插件是否已经安装的判断,并实现插件的下载安装。插件在此安装成功后,再打开其它的报表展现网页就可以让报表成功显示出来。

报表门户(入口)网页既可以是一个专门的网页,也可以是其它目录(索引/导航)网页中加入插件安装的代码。


六、浏览器下载安装报表插件说明

    如果已经将插件安装包部署到服务器,且已经创建报表门户网页,则未安装插件的客户端电脑在访问报表门户网页时将会出现插件安装的相关提示界面。以下内容就是对插件自动下载安装的说明,也是对插件部署是否正确的检验。锐浪报表插件支持多浏览器,在不同的浏览器下安装行为有所区别。

计算机生成了可选文字: 收藏夹行锐浪报表插件web报表臼lS报表)演示一全面支页面!此网站需要安装以下该加载项并打算安装加该载项:'加载项贝。n's。ftwareTe。地01。盯c。,Ltd,,中的“锐浪软件份i肚+Rep。rts报表插件”。如果您信任该网站年此网站需要安装锐很报表插件才能保证其正常运行如浏览器的顶部或底部出现提示条,左键点击提示条并运行加载项,按此方式安装最简便锐浪报表插件安装后,点击鲤止重新加载此网站Grid++Rep。rtweb报表功能演示初次访问会自动下载安装报表插件,需要等待几分钟。始终不能看到演示报表,请看关于正安主设置。报表插件相关资料与例子在产品安装中,工戴量新版鱼上鱼即塑:报毫擎鲍臀成多语言支持的’报表插件例子包在启动时习、asp'phP、Jsp置自动选择匹配的。访问益浪刻生直互了解更多关千Ori界面语言,也可以专门指定界面语言,

    至此为止,锐浪报表系统就做好了,接下来将其发布到IIS即可使用。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 


推荐阅读
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 本文将介绍网易NEC CSS框架的规范及其在实际项目中的应用。通过详细解析其分类和命名规则,探讨如何编写高效、可维护的CSS代码,并分享一些实用的学习心得。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • 本文介绍了如何利用npm脚本和concurrently工具,实现本地开发环境中多个监听服务的同时启动,包括HTTP服务、自动刷新、Sass和ES6支持。 ... [详细]
  • 本题探讨如何通过最大流算法解决农场排水系统的设计问题。题目要求计算从水源点到汇合点的最大水流速率,使用经典的EK(Edmonds-Karp)和Dinic算法进行求解。 ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 本文深入探讨了计算机网络的基础概念和关键协议,帮助初学者掌握网络编程的必备知识。从网络结构到分层模型,再到传输层协议和IP地址分类,文章全面覆盖了网络编程的核心内容。 ... [详细]
  • Python 异步编程:ASGI 服务器与框架详解
    自 Python 3.5 引入 async/await 语法以来,异步编程迅速崛起,吸引了大量开发者的关注。本文将深入探讨 ASGI(异步服务器网关接口)及其在现代 Python Web 开发中的应用,介绍主流的 ASGI 服务器和框架。 ... [详细]
  • 随着Redis功能的不断增强和稳定性提升,其应用范围日益广泛,成为软件开发人员不可或缺的技能之一。本文将深入探讨Redis集群的部署与优化,包括主从备份机制、哨兵模式以及集群功能,帮助读者全面理解并掌握Redis集群的应用。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 配置Windows操作系统以确保DAW(数字音频工作站)硬件和软件的高效运行可能是一个复杂且令人沮丧的过程。本文提供了一系列专业建议,帮助你优化Windows系统,确保录音和音频处理的流畅性。 ... [详细]
author-avatar
dbvg2q
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有