1、下載對(duì)應(yīng)環(huán)境的sdk
目前企業(yè)微信的會(huì)話存檔僅支持在linux環(huán)境和windows環(huán)境的sdk
兩個(gè)環(huán)境對(duì)應(yīng)不同的動(dòng)態(tài)庫(kù)文件
so是C/C++在Linux平臺(tái)上的動(dòng)態(tài)鏈接庫(kù)文件,windows上的動(dòng)態(tài)庫(kù)文件是dll后綴
因?yàn)殚_(kāi)發(fā)大多數(shù)人比較喜歡用macos系統(tǒng),而在macos的動(dòng)態(tài)庫(kù)格式是.dylib,
所以在mac系統(tǒng)上無(wú)法完成調(diào)試。這里也是希望官方可以給出mac版本的sdk。
sdk下載下來(lái)時(shí)候目錄結(jié)構(gòu)不要?jiǎng)?,最好是直接?dǎo)入到項(xiàng)目中,當(dāng)然里面最重要的還是動(dòng)態(tài)庫(kù)文件和官方給的demo以及動(dòng)態(tài)庫(kù)文件。win_sdk在導(dǎo)入之后demo可以直接運(yùn)行,在linux環(huán)境下不可以,會(huì)報(bào)錯(cuò)no_libWeWorkFinanceSdk,sdk初始化失敗,直接用System.load(“指定so文件目錄")。建議目前還是在windows環(huán)境下實(shí)現(xiàn)業(yè)務(wù)邏輯還是最方便的,等到調(diào)試完成就可以在linux環(huán)境部署了。
在linux環(huán)境下部署如果是直接跑jar包,或者是在tomcat目錄下運(yùn)行。一般可以直接運(yùn)行。一般出現(xiàn)問(wèn)題就指定下jvm參數(shù)java.library.path即可
如果在docker環(huán)境下跑項(xiàng)目,就出現(xiàn)問(wèn)題了,這個(gè)困擾我了一整天,先是試著把宿主機(jī)的lib目錄掛載到docker中,在Finance類(lèi)中的靜態(tài)塊中加載動(dòng)態(tài)庫(kù)直接指向docker中的路徑:System.load("/root/wxwork/lib/libWeWorkFinanceSdk_Java.so”),結(jié)果又報(bào)錯(cuò)找不到該so文件依賴(lài)的其他so文件。折騰了挺久也不行。最后在網(wǎng)上找到一個(gè)解決方法:
制作一個(gè)基于linux系統(tǒng)的帶java環(huán)境的鏡像加載動(dòng)態(tài)庫(kù)
https://ask.csdn.net/questions/757542
親測(cè)有效的。
2、sdk初始化完成后,就按照相應(yīng)企業(yè)微信的官方文檔一步步來(lái),之后還有可能遇到的問(wèn)題就是拿到會(huì)話內(nèi)容后的解密問(wèn)題。
這個(gè)官方文檔的解密并沒(méi)有給到完成的解決demo,對(duì)RSA解密算法不太清楚的人可能會(huì)比較難入手 ,這里需要在企業(yè)微信的后臺(tái)配置相應(yīng)的公鑰,自己把私鑰保存下來(lái)。企業(yè)微信后臺(tái)可以配置多個(gè)版本的公鑰,在getChatData接口會(huì)返回相應(yīng)的版本號(hào),根據(jù)版本號(hào)選取相應(yīng)的私鑰進(jìn)行解密。注意這里生成密鑰對(duì)選用的是RSA PKCS1,模值為2048bit,網(wǎng)上有很多生成密鑰對(duì)的工具,可以直接使用。
在線工具:
http://web.chacuo.net/netrsakeypair
當(dāng)然如果有安全性方面的顧慮,可以自己手動(dòng)去生成
https://blog.csdn.net/aexlinda/article/details/37693167

這里直接把解密的工具類(lèi)代碼貼出來(lái),直接調(diào)用decryptRSA即可拿到解密的內(nèi)容
需要引入的依賴(lài):
<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;
}