1、下载对应环境的sdk
目前企业微信的会话存档仅支持在linux环境和windows环境的sdk
两个环境对应不同的动态库文件
so是C/C++在Linux平台上的动态链接库文件,windows上的动态库文件是dll后缀
因为开发大多数人比较喜欢用macos系统,而在macos的动态库格式是.dylib,
所以在mac系统上无法完成调试。这里也是希望官方可以给出mac版本的sdk。
sdk下载下来时候目录结构不要动,最好是直接导入到项目中,当然里面最重要的还是动态库文件和官方给的demo以及动态库文件。win_sdk在导入之后demo可以直接运行,在linux环境下不可以,会报错no_libWeWorkFinanceSdk,sdk初始化失败,直接用System.load(“指定so文件目录")。建议目前还是在windows环境下实现业务逻辑还是最方便的,等到调试完成就可以在linux环境部署了。
在linux环境下部署如果是直接跑jar包,或者是在tomcat目录下运行。一般可以直接运行。一般出现问题就指定下jvm参数java.library.path即可
如果在docker环境下跑项目,就出现问题了,这个困扰我了一整天,先是试着把宿主机的lib目录挂载到docker中,在Finance类中的静态块中加载动态库直接指向docker中的路径:System.load("/root/wxwork/lib/libWeWorkFinanceSdk_Java.so”),结果又报错找不到该so文件依赖的其他so文件。折腾了挺久也不行。最后在网上找到一个解决方法:
制作一个基于linux系统的带java环境的镜像加载动态库
https://ask.csdn.net/questions/757542
亲测有效的。
2、sdk初始化完成后,就按照相应企业微信的官方文档一步步来,之后还有可能遇到的问题就是拿到会话内容后的解密问题。
这个官方文档的解密并没有给到完成的解决demo,对RSA解密算法不太清楚的人可能会比较难入手 ,这里需要在企业微信的后台配置相应的公钥,自己把私钥保存下来。企业微信后台可以配置多个版本的公钥,在getChatData接口会返回相应的版本号,根据版本号选取相应的私钥进行解密。注意这里生成密钥对选用的是RSA PKCS1,模值为2048bit,网上有很多生成密钥对的工具,可以直接使用。
在线工具:
http://web.chacuo.net/netrsakeypair
当然如果有安全性方面的顾虑,可以自己手动去生成
https://blog.csdn.net/aexlinda/article/details/37693167
这里直接把解密的工具类代码贴出来,直接调用decryptRSA即可拿到解密的内容
需要引入的依赖:
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcpg-jdk16</artifactId>
<version>1.46</version>
</dependency>
<dependency>
<groupId>org.bouncycastle</groupId>
<artifactId>bcpkix-jdk15on</artifactId>
<version>1.64</version>
</dependency>
RSA解密代码示例:
public staticPrivateKey getPrivateKey(String privKeyPEM) throwsException{
String privKeyPEMnew = privKeyPEM.replaceAll("\\n","").replace("-----BEGIN RSA PRIVATE KEY-----","").replace("-----END RSA PRIVATE KEY-----","");
byte[] bytes = java.util.Base64.getDecoder().decode(privKeyPEMnew);
DerInputStream derReader =newDerInputStream(bytes);
DerValue[] seq = derReader.getSequence(0);
BigInteger modulus = seq[1].getBigInteger();
BigInteger publicExp = seq[2].getBigInteger();
BigInteger privateExp = seq[3].getBigInteger();
BigInteger prime1 = seq[4].getBigInteger();
BigInteger prime2 = seq[5].getBigInteger();
BigInteger exp1 = seq[6].getBigInteger();
BigInteger exp2 = seq[7].getBigInteger();
BigInteger crtCoef = seq[8].getBigInteger();
RSAPrivateCrtKeySpec keySpec =newRSAPrivateCrtKeySpec(modulus, publicExp, privateExp, prime1, prime2, exp1, exp2, crtCoef);
KeyFactory keyFactory = KeyFactory.getInstance("RSA");
PrivateKey privateKey = keyFactory.generatePrivate(keySpec);
returnprivateKey;
}
public staticString decryptRSA(String content,PrivateKey privateKey)
throwsException {
Cipher cipher = Cipher.getInstance("RSA");
cipher.init(Cipher.DECRYPT_MODE, privateKey);//getPrivateKey()返回的privateKey
byte[] randomkeybyte = Base64.decodeBase64(content);
byte[] finalrandomkeybyte = cipher.doFinal(randomkeybyte);
String finalrandomkey =newString(finalrandomkeybyte);
returnfinalrandomkey;
}