企业微信存档二次开发

按照官方文档下载sdk(windows或linux),里面包含使用demo,目前使用的是windows的sdk,然后将动态链接库.dll文件放到windows的C盘System32文件夹下,这时运行demo,控制台会显示0(Finance.Init(sdk, R.CORPID, R.SECRET)初始化成功,使用前必须初始化),sdk是调用Finance.NewSdk()生成的;如果控制下还显示getchatdata :{“errcode”:301042,“errmsg”:“get chatdata whiteip not match, hint: [1599354620_109_ee5ba2a913b13f4fc1b127091c758464], from ip: 223.104.64.207, more info at https://open.work.weixin.qq.com/devtool/query?e=301042”,“chatdata”:[]},则表示你的ip没有添加到企业微信会话功能的信任ip中,所以"chatdata":[],需要添加。

另外特别注意,企业微信保存的三天的消息内容,如果你设置的seq值为0,而limit设置的值太小(不超过1000),可能控制显示null,或者拉取到的密文返回参数中publickey_ver(公钥版本号为旧的)。解encrypt_random_key(版本的公钥进行非对称加密后base64加密的密文)时要使用自己在存档功能设置的公钥版本对应的私钥去解,不然会报错,同时公钥使用的RSA psck1的算法加密,所以解密时留意采用相同的方式去解。解RSA前要先对64编码进行解码,可使用Base64.decodeBase64(str);然后使用Cipher rsa = Cipher.getInstance("RSA/ECB/PKCS1Padding", "BC");构造PKCS1的Cipher,使用里面的API进行初始化和解码操作。最终返回的byte [] 可使用new String(rsaDecode,"UTF-8");得到string类型的encrypt_random_key。接下来可用Finance解析密文的API解析密文了。
  • 5
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
企业微信提供了丰富的API接口,可以通过API实现会话存档的功能。 首先需要获取企业微信的access_token,用于调用API接口。可以使用以下代码获取access_token: ```python import requests corpid = '企业ID' corpsecret = '应用的Secret' def get_access_token(): url = 'https://qyapi.weixin.qq.com/cgi-bin/gettoken' params = { 'corpid': corpid, 'corpsecret': corpsecret } response = requests.get(url, params=params) access_token = response.json().get('access_token', '') return access_token ``` 获取access_token后,可以使用以下代码调用API接口获取会话记录: ```python import requests access_token = 'ACCESS_TOKEN' chatid = '会话ID' seq = 0 # 初始seq设置为0,后续每次请求会返回新的seq值 def get_chat_log(): url = 'https://qyapi.weixin.qq.com/cgi-bin/appchat/getmsglist' params = { 'access_token': access_token, 'chatid': chatid, 'seq': seq } response = requests.get(url, params=params) chat_log = response.json() new_seq = chat_log.get('next_cursor', 0) return chat_log, new_seq ``` 上述代码中,需要将access_token和chatid替换为实际的值。调用get_chat_log函数可以获取一段会话记录,并返回新的seq值,用于下一次请求时更新。 获取到会话记录后,可以将其保存到数据库或文件中。可以使用Python内置的sqlite3库或第三方ORM库如SQLAlchemy来实现数据的存储。 注意:企业微信的API接口有调用频率限制,建议进行合理的控制和调用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值