企业微信会话存档踩过的坑,sdk初始化及RSA解密问题

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;

}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容