【官方发布】FineReportV8.0之微信集成

楼主
我是社区第78位番薯,欢迎点我头像关注我哦~

前述说明:微信企业号中可以有多个独立应用,该文档适用于在微信企业号中创建独立的报表应用,并且需要进行微信账号单点登录报表服务器进行权限对接的情况。
1. 报表服务器环境准备
1.1 报表服务器要求
您的报表服务器必需是外网可以访问的,并且如果是http协议则访问端口不限,如果是https协议访问端口必需包含443;
您的报表服务器必需是8.0及以上版本的。
您的Jdk必需是1.6及以上版本的。
1.2 微信管理插件安装
为了简化微信集成,FR开发了微信管理插件,将微信的相关配置从后台转为前台可视化界面操作,实现了微信集成基本信息配置、内置回调URL验证、同步微信通讯录并与报表用户关联实现单点登录以及定时发送消息至微信成员。FR还在继续开发常用的管理界面。
  • 安装插件

跟技术支持索要微信管理插件包,将解压后的fr-plugin-weixin-1.0文件夹拷贝到服务器报表工程WEB-INF\plugins目录中,并且将其中的fr-plugin-weixin-1.0.jar包拷贝到WEB-INF\lib下。
  • 修改web.xml文件

打开服务器报表工程WEB-INF下的web.xml,在其中新增WeiXinServer,如下:<servlet>
    <servlet-name>WeiXinServer</servlet-name>
    <servlet-class>com.fr.wei.plugin.weixin.web.WeiXinServlet</servlet-class>
    <load-on-startup>0</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>WeiXinServer</servlet-name>
    <url-pattern>/WeiXinServer</url-pattern>
  </servlet-mapping>


修改后的web.xml如:
<?xml version="1.0" encoding="UTF-8"?>
<web-app
   xmlns="http://java.sun.com/xml/ns/j2ee"
   xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
   xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
   version="2.4">

  <display-name>Template WebApp</display-name>

    <mime-mapping>
  <extension>msi</extension>
  <mime-type>application/x-msi</mime-type>
  </mime-mapping>

  <servlet>
    <servlet-name>ReportServer</servlet-name>
    <servlet-class>com.fr.web.ReportServlet</servlet-class>
    <load-on-startup>0</load-on-startup>
  </servlet>

  <servlet>
    <servlet-name>WeiXinServer</servlet-name>
    <servlet-class>com.fr.wei.plugin.weixin.web.WeiXinServlet</servlet-class>
    <load-on-startup>0</load-on-startup>
  </servlet>

  <servlet-mapping>
    <servlet-name>WeiXinServer</servlet-name>
    <url-pattern>/WeiXinServer</url-pattern>
  </servlet-mapping>

  <servlet-mapping>
    <servlet-name>ReportServer</servlet-name>
    <url-pattern>/ReportServer</url-pattern>
  </servlet-mapping>

</web-app>

  • 安装后的效果

安装微信管理插件后,打开报表管理平台,管理系统下会增加“微信管理”节点,微信相关的配置管理都将会放在这个节点中去配置;

同时,设置定时任务的最后一步输出设置中,会增加“推送微信消息”

微信管理插件的使用我们在回调模式配置及定时推送消息至微信中详细介绍。
1.3 手机浏览器报表插件
微信集成的企业应用中打开的只能是HTML5页面,不能使用FR新版移动app的原生解析功能。FR开发了手机浏览器HTML5浏览方式,实现手机浏览器中报表的自适应、参数界面分离等效果。移动终端HTML5浏览方式仅对分页报表进行了处理,详细请查阅移动端Html5报表
  • 安装插件

跟技术支持索要HTML5插件包,将解压后的fr-plugin-h5Report-1.0文件夹拷贝到服务器报表工程WEB-INF\plugins目录下,并将fr-plugin-h5Report-1.0.jar这个包拷贝到WEB-INF\lib下面。
1.4 需要commons-codec-1.9.jar包
报表服务器请使用jdk1.6或以上的版本。需要将commons-codec-1.9.jar包拷贝到报表服务器\WEB-INF\lib下面,如果已经存在其他版本,则可以不需要再导入;
1.5 更换JCE无限制权限策略文件
需要根据jdk版本,替换%JDK_HOME%\jre\lib\security目录下的local_policy.jar和US_export_policy.jar这两个jar包,此为JCE无限制权限策略文件,如果不做这步操作,会有java.security.InvalidKeyException:illegal Key Size异常,从而不能正确进行微信AES解密。
请到官网下载对应的JCE版本:http://www.oracle.com/technetwork/java/javase/downloads/index.html
2. 报表微信企业应用
2.1 创建报表微信企业应用
管理员登录微信企业号,根据提示新建应用,创建后进入应用,可以看到应用的基本信息,其中需要关注的信息有:
应用ID:微信号中可能有很多个应用,后台开发的时候需要根据应用ID来决定是在哪个应用中进行响应
可见范围:微信权限控制
应用模式:应用模式主要分成两种:
普通模式:这个模式下不能调用微信的接口,只能设置固定的菜单及回复的消息;如果需要的微信应用比较简单,菜单都是固定的,可以用这种模式,但是报表就无法绑定用户了,查看报表的时候就需要先登录(除非报表不做权限控制);
回调模式:开发者可以通过企业号提供的接口,获取微信用户信息,实现自动回复、自定义菜单等个性化功能。

2.2 回调模式配置
原理说明:我们在应用中需要调用微信开放的接口做开发,所以选择“回调模式”,这样微信服务器会在客户手机和开发者服务器间架起一个桥梁,通过消息的传递和响应,实现与用户的交互操作:

上面这个流程走通,需要微信服务器和开发者服务器先建立通信,这样才能构建一个完整的链路。进入回调模式,开启模式后,可以看到,下面的功能都是不可用状态,需要设置好回调URL及密码后才能用的。

我们点开修改,会看到有3个参数,都是我们需要关注的:

URL:开发服务器接收微信收企业号服务器推送请求的地址,支持http或https协议,这个URL就相当于开发服务器的后台引擎,微信服务器推送的请求都是到这个地址,另外注意,这个地址必须是外网可以访问的,且如果是http协议,端口支持80等端口,https协议端口必需包含443;
Token:可由企业任意填写也可以随机获取,用于生成签名;
EncodingAESKey:用于消息体的加密,是AES密钥的Base64编码,点击随机获取就可以获得。
验证时,企业号会向验证url发送一个get请求,例如:

  1. xxurl?msg_signature=5c45ff5e21c57e6ad56bac8758b79b1d9ac89fd3×tamp=1409659589&nonce=263014780&echostr=P9nAzCzyDtyTWESHep1vC5X9xho%2FqYX3Zpb4yKa9SKld1DsH3Iyt3tP3zNdtp%2B4RPcs8TgAE7OaBO%2BFZXvnaqQ%3D%3D   
复制代码



消息中会有四个参数,并且会以AES方式加密:
msg_signature:消息体签名
timestamp:时间戳
nonce:随机数字串
echostr:随机加密字符串
开发服务器需要解析出Get请求的参数,对参数进行解密,然后使用之前的Token、EncodingAESKey这两个值进行验证,成功后,微信服务器与开发服务器间的通信就建立起来了。
  • 具体步骤如下:

进入微信管理后台,进入应用>回调模式,修改回调URL及秘钥,随机生成Token和EncodingAESKey,先不要点保存;
登陆FR管理平台,点击管理系统>微信管理节点:

点击后,我们将微信企业号的基本信息配置好,如下左图为FR中的配置界面,右图为微信中的回调URL配置界面:

将之前在微信管理平台中生成Token及EncodingAESKey这两个值拷贝到左侧FR的基本信息中;
将企业ID及管理组秘钥即corpid及secret填写到FR基本信息中,这两个值的查看请看3.1及3.2。
FR中微信管理节本信息填写完毕后保存;
接收数据URL固定,如:http://review.finedevelop.com:8081/ReportServer?op=weixin,将这个URL写入到右边微信企业号管理平台的回调URL处;
点击右侧微信的保存了,如果验证成功,则效果如下:

2.3 微信用户与报表用户关联
15年7月份FR与微信集成时,需要通过OAuth2接口获取微信用户,并且在后台根据微信用户匹配对应的报表用户及密码,实现报表的单点登录。
15年8月份对此进行了改进,在FR提供的微信管理中,增加微信成员的管理,可以通过界面化绑定微信成员与报表用户,通过后台登录报表。
不需要实现OAuth2接口获取微信用户、不需要后台匹配报表用户及密码、也不需要在后台实现单点登陆,真正实现无缝集成,下面就来看看是如何用的。
进入FR报表管理平台fs,点击“微信管理”节点,除了基本信息外,增加了“微信成员管理”,点击效果如下:

表格中会自动读取微信企业号通讯录中的所有成员,并且在每次打开该页面时刷新为最新的;
默认“微信成员与报表用户相同”,因为大部分情况下,微信成员名和报表用户名是统一的;
如果您的微信成员名与报表用户名是不一样的,此时,可以取消勾选“微信成员与报表用户相同”设置,此时报表用户名,可以将微信成员与报表用户进行关联,如下图:

2.4 挂报表
在微信企业号管理平台中,进入应用>回调模式,设置自定义菜单

添加事件类型选择跳转到网页,url链接规则如下:

  • https://open.weixin.qq.com/connect/oauth2/authorize?appid=xxxxxxxxx&redirect_uri=xxxxx&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect  



链接中需要包含以下参数:
appid:企业的应用ID即CorpID
redirect_uri:授权后重定向的回调链接地址,报表访问url,需要使用urlencode对链接进行处理
response_type:返回类型,此时固定为:code
scope:应用授权作用域,此时固定为:snsapi_base
state:重定向后会带上state参数,企业可以填写a-zA-Z0-9的参数值
wechat_redirect:微信终端使用此参数判断是否需要带上身份信息
例如,正常报表访问url为:
  1. http://review.finedevelop.com:8081/WeiXin/ReportServer?reportlet=WeiXin/swll.cpt
复制代码

将url中ReportServer换成WeiXinServer,替换后url为
  1. http://review.finedevelop.com:8081/WeiXin/WeiXinServer?reportlet=WeiXin/swll.cpt
复制代码

这个连接需要进行urlencode(utf-8编码),可以到http://51tools.info/urlencode.aspx转换一下,编码后url为:
  1. http%3a%2f%2freview.finedevelop.com%3a8081%2fWeiXin%2fWeiXinServer%3freportlet%3dWeiXin%2fswll.cpt
复制代码

最终,微信中网页链接地址为:
  1. https://open.weixin.qq.com/connect/oauth2/authorize?appid=xxxx&redirect_uri=http%3a%2f%2freview.finedevelop.com%3a8081%2fWeiXin%2fWeiXinServer%3freportlet%3dWeiXin%2fswll.cpt&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect
复制代码

这样报表就挂好了,可以通过手机进入微信应用,查看效果。
2.5 微信单点登陆及权限控制
  • 单点登陆

2.4中,我们在微信应用中挂上了报表,在手机上,您可以看到是不需要登陆,直接可以查看结果的。而如果您使用手机浏览器访问相同的报表,您会发现,是需要登录的。那是因为,通过2.3将微信成员与报表用户关联后,通过微信企业应用进入查看报表时,在FR后台,我们会使用微信的OAuth2接口进行用户验证并获取对应微信成员名,然后关联报表用户并自动登录,从而实现微信单点登陆。
  • 权限控制

微信应用的菜单是在微信中管理,所以哪些成员可以看到的哪些报表这是在微信中控制。比如您可以创建过个报表应用,每个应用的查看权限选择不同的成员或组。
用户在微信中打开报表,是否可以查看报表的内容,以及可以查看的数据这部分是在FR报表端控制的,控制方法与PC端是一样的,比如可以通过角色控制可查看的报表,可以在报表模板中通过sql语句通过用户名过滤来实现不同用户看到的数据不同等等。
2.6 定时发送消息至成员
开发服务器可以主动的发送消息给企业成员,比如使用FR定时器生成好报表后,发送消息给相应的人员进行查看。进入FR管理平台,添加定时任务:

到输出设置这步,比如我们将定时生成的结果挂在“定时结果”这个目录下面,并且命名为test:
注:微信成员需要有这个目录的查看权限,才能够查看生成的结果,具体用法请查阅FR帮助文档定时器部分

通知与存档选择推送微信消息,例如下设置,这样定时任务结束后,Saber这个微信成员以及产品部门的所有成员都可以收到消息

定时生成结果的文件名:对应发送消息的标题名
企业应用ID:发消息至哪个应用,如何查看应用ID见3.1.3
微信用户:发消息给哪些成员,下拉框中会自动读取微信通讯录中的所有成员,多个成员之间用|分割,比如Jane|Saber
部门ID:发消息给某个部门的所有成员,该属性与微信用户是并的关系,不同部门之间也用|分割
消息内容:定义消息的正文内容
定时结果访问连接:勾选的话会在消息正文最后加上定时生成的结果连接,点击后就可以直接打开定时结果;不选的话则只发送纯文本消息。
定时任务设置好后,比如任务每天都会执行,每次执行后就会推送消息给对应的成员,效果如下:

点击链接,就可以看到定时生成的结果。
3. 微信企业号管理平台使用
3.1 需要关注的参数
  • CorpID

登录微信企业号管理平台,点击设置,可以看到当前微信企业号的账号信息,其中就有我们要的企业ID,如下图:

  • Secret

登录微信企业号管理平台,点击设置,进入权限管理,选择开发管理员,最下面就可以看到CorpID及开发凭据Secret

  • 应用ID

因为一个企业号中是可以有创建多个应用的,如果后台想主动发送消息等,需要明确是发往那个应用,此时就需要应用ID,我们可以进入微信企业管理平台,进入应用中心,点击应用,就可以看到应用ID了:

  • 部门ID

后台想主动发消息给某个部门的所有成员时,会通过部门ID来指定部门,可以进入微信企业管理平台,点击通讯录,鼠标移上对应的部门,点击后面的小箭头,就可以看到当前部门ID了:

3.2 应用权限控制
登录微信企业号管理平台,进入应用中心,选择应用比如报表应用,可以看到该应用对应的应用管理组:

点击左侧设置按钮,进入权限管理:

选择应用的管理组,如我们这边是“开发管理员”,给这个管理组开启应用的发消息和管理的权限,这样我们才能在开发服务器端主动的向该应用发送消息、管理菜单等操作,否则后台调用微信接口的时候,会报没有权限。


分享扩散:
参与人数 +1 F豆 +1 理由
windy_gui + 1 666

查看全部评分

沙发
发表于 2015-9-24 11:47:14
真是赞赞赞  
板凳
发表于 2015-9-24 11:57:10
教科书式的文档啊
地板
发表于 2015-9-24 14:33:34
厉害,感谢大神感谢帆软{:8_209:}
5楼
发表于 2015-9-24 16:13:31
顶!d=====( ̄▽ ̄*)b
6楼
发表于 2015-9-25 13:40:39
这东西不错,
7楼
发表于 2015-9-25 14:10:20
路过留名。。。。。。
8楼
发表于 2015-9-25 14:47:32
大神,有微信管理界面,但定时调度里没有微信推送是哪里设置错了啊。
9楼
发表于 2015-9-26 20:12:05
写的真详细……{:8_209:}
10楼
发表于 2015-10-19 10:28:57
代码,出现html代码!请楼主修改一下!
参与人数 +1 F豆 +30 理由
传说哥 + 30 很给力!

查看全部评分

11楼
发表于 2015-10-24 14:12:58
红线部分是否错误
12楼
发表于 2015-10-25 18:39:44
微信企业号里面,展示效果有联动,钻透,适配性这些功能吗
13楼
发表于 2015-11-6 07:49:02
微信设置回调模式配置已成功,但在 “微信管理”-“微信成员管理”  ,未显示微信用户,在日志中显示:JSONArray[0] not found.

这是哪里出问题了?

14楼
发表于 2015-12-19 19:49:04
真心感谢,试的时候一定要一步一步。
15楼
发表于 2016-1-12 16:01:57
{:8_209:}                    
16楼
发表于 2016-1-26 09:40:09
好高的上呀!
17楼
发表于 2016-2-21 23:51:49
ddd哈哈啊哈不错啊啊!
18楼
发表于 2016-6-30 16:54:58
学习了
19楼
发表于 2016-11-7 16:13:08
很想用 但看不懂 公司还没开通外网访问 局域网可以访问吗
20楼
发表于 2017-1-4 10:46:37
教科书!
21楼
发表于 2017-1-4 10:47:45
教科书!
22楼
发表于 2017-5-16 10:10:28
我感觉需要更新,前面一部分,已经不适用了。
23楼
发表于 2017-6-24 08:48:06
留个脚印,学习用,谢谢楼主
24楼
发表于 2017-8-14 18:39:10
怎么图片都看不到了
25楼
发表于 2017-8-28 18:53:37
插件怎么下载不了啊
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

37回帖数 2关注人数 43516浏览人数
最后回复于:2020-1-3 08:54

返回顶部 返回列表