1、选择需要生成二维码的自建应用,点击【查看】按钮,在d出的窗口中可以看到API码等信息。
2、在API码旁边点击【生成】按钮,系统会自动生成一个二维码,并显示在页面上。
3、将二维码保存或打印出来,即可供其他用户扫描添加该企业应用。企业微信通讯录中的API码(也称为企业自建应用的API密钥)可以通过扫描生成对应的二维码,以便其他用户快速添加该企业应用。
企业微信API消息去重可以通过以下步骤实现:1. 在数据库中新增一张表,记录已经发送过的消息的MessageID。
2. 每次发送消息时,先查询新消息的MessageID是否在该表中存在。
3. 如果不存在则发送消息,并将新消息的MessageID插入到该表中。
4. 如果存在则不发送消息。
这样可以保证同一条消息只会被发送一次,避免重复发送。
您好!很高兴能为您解答, 用了tp框架,那你要留意了,本文以Thinkphp3.2.3 php版本5.3为例坑1
下载官方的处理接口的范例,放在Thinkphp>Library>Wechat(自建)目录下
修改WXBizMsgCrypt.php为WXBizMsgCrypt.class.php
在WXBizMsgCrypt中声明命名空间namespace Wechat
在你需要的控制器中引入类use Wechat WXBizMsgCrypt
之后就是使用官方的sample copy进你的项目简单修改下就算整合完成了,过程挺简单的,但是!在PHP5.3之前构造函数的写法和PHP5.3之后有变化,构造函数不能再以类名当作函数名来命名,必须要使用__construct声明一个构造函数,也就是说用官方的例子来整合是肯定会报错的,当然前提是你用的也是PHP5.3之后的版本。
所以还需要
修改WXBizMsgCrypt文件中WXBizMsgCrypt函数名,改为__construct
修改pkcs7Encoder文件中pkcs7Encoder函数名,改为__construct
大功告成,可能不适用于低版本的Thinkphp 或者php5.3以下,我没做过其他版本的测试
坑2
填写企业号回调信息点击保存不成功时,多点几次真的有奇效!
这不是玩笑~~因为企业号发给开发者的随机签名里面,很有可能包含+号,当你get url的时候,php会自动把+号过滤为空格,导致发来的签名和实际地址签名不一致,signature验证就不会通过了,会报40001: 签名验证错误。
当然,你也可以把空格再还原为+号,这样能确保与发送的签名地址一致。(我觉得这是微信回调的一个小bug,签名里不应该带有这样特殊意义的符号)
坑3
全部都通过验证了,也返回微信要的明文了,还是不通过,what?打印到本地看看,也没错啊,百度我都搜遍了,什么去掉文件BOM头,改header头,通通都试过了,我真的的的确确解密了,而且把解密的结果返回给了微信,还是不行啊,WTF。。
真的返回了明文么?你以为打印到本地就是对的么?错了。有个东西叫缓冲区
缓冲区的东西是不会打印到本地的,微信在访问你网址的时候,先get到的东西是缓冲区内容而不是你输出的明文。所以,要先清除缓冲区,办法是在echo前使用ob_clean(),估计其他框架也一样。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)