mirror of
https://gitee.com/binary/weixin-java-tools.git
synced 2025-11-02 12:38:22 +08:00
210 lines
6.4 KiB
Java
210 lines
6.4 KiB
Java
package com.tencent.wework;
|
||
|
||
import lombok.extern.slf4j.Slf4j;
|
||
|
||
import java.util.List;
|
||
|
||
/**
|
||
* 企业微信会话内容存档Finance类
|
||
* 注意:
|
||
* 此类必须配置在com.tencent.wework路径底下,否则会报错:java.lang.UnsatisfiedLinkError: com.xxx.Finance.NewSdk()
|
||
* <p>
|
||
* Q:JAVA版本的sdk报错UnsatisfiedLinkError?
|
||
* A:请检查是否修改了sdk的包名。
|
||
* <p>
|
||
* 官方文档:
|
||
* https://developer.work.weixin.qq.com/document/path/91552
|
||
*
|
||
* @author <a href="https://github.com/0katekate0">Wang_Wong</a>
|
||
* @date 2022-01-17
|
||
*/
|
||
@Slf4j
|
||
public class Finance {
|
||
|
||
private static volatile long sdk = -1L;
|
||
private static Finance finance = null;
|
||
private static final String SO_FILE = "so";
|
||
private static final String DLL_FILE = "dll";
|
||
|
||
public native static long NewSdk();
|
||
|
||
/**
|
||
* 初始化函数
|
||
* Return值=0表示该API调用成功
|
||
*
|
||
* @param [in] sdk NewSdk返回的sdk指针
|
||
* @param [in] corpid 调用企业的企业id,例如:wwd08c8exxxx5ab44d,可以在企业微信管理端--我的企业--企业信息查看
|
||
* @param [in] secret 聊天内容存档的Secret,可以在企业微信管理端--管理工具--聊天内容存档查看
|
||
* @return 返回是否初始化成功
|
||
* 0 - 成功
|
||
* !=0 - 失败
|
||
*/
|
||
public native static int Init(long sdk, String corpid, String secret);
|
||
|
||
/**
|
||
* 拉取聊天记录函数
|
||
* Return值=0表示该API调用成功
|
||
*
|
||
* @param [in] sdk NewSdk返回的sdk指针
|
||
* @param [in] seq 从指定的seq开始拉取消息,注意的是返回的消息从seq+1开始返回,seq为之前接口返回的最大seq值。首次使用请使用seq:0
|
||
* @param [in] limit 一次拉取的消息条数,最大值1000条,超过1000条会返回错误
|
||
* @param [in] proxy 使用代理的请求,需要传入代理的链接。如:socks5://10.0.0.1:8081 或者 http://10.0.0.1:8081
|
||
* @param [in] passwd 代理账号密码,需要传入代理的账号密码。如 user_name:passwd_123
|
||
* @param [out] chatDatas 返回本次拉取消息的数据,slice结构体.内容包括errcode/errmsg,以及每条消息内容。
|
||
* @return 返回是否调用成功
|
||
* 0 - 成功
|
||
* !=0 - 失败
|
||
*/
|
||
public native static int GetChatData(long sdk, long seq, long limit, String proxy, String passwd, long timeout, long chatData);
|
||
|
||
/**
|
||
* 拉取媒体消息函数
|
||
* Return值=0表示该API调用成功
|
||
*
|
||
* @param [in] sdk NewSdk返回的sdk指针
|
||
* @param [in] sdkFileid 从GetChatData返回的聊天消息中,媒体消息包括的sdkfileid
|
||
* @param [in] proxy 使用代理的请求,需要传入代理的链接。如:socks5://10.0.0.1:8081 或者 http://10.0.0.1:8081
|
||
* @param [in] passwd 代理账号密码,需要传入代理的账号密码。如 user_name:passwd_123
|
||
* @param [in] indexbuf 媒体消息分片拉取,需要填入每次拉取的索引信息。首次不需要填写,默认拉取512k,后续每次调用只需要将上次调用返回的outindexbuf填入即可。
|
||
* @param [out] media_data 返回本次拉取的媒体数据.MediaData结构体.内容包括data(数据内容)/outindexbuf(下次索引)/is_finish(拉取完成标记)
|
||
* @return 返回是否调用成功
|
||
* 0 - 成功
|
||
* !=0 - 失败
|
||
*/
|
||
public native static int GetMediaData(long sdk, String indexbuf, String sdkField, String proxy, String passwd, long timeout, long mediaData);
|
||
|
||
/**
|
||
* @param [in] encrypt_key, getchatdata返回的encrypt_key
|
||
* @param [in] encrypt_msg, getchatdata返回的content
|
||
* @param [out] msg, 解密的消息明文
|
||
* @return 返回是否调用成功
|
||
* 0 - 成功
|
||
* !=0 - 失败
|
||
* @brief 解析密文
|
||
*/
|
||
public native static int DecryptData(long sdk, String encrypt_key, String encrypt_msg, long msg);
|
||
|
||
public native static void DestroySdk(long sdk);
|
||
|
||
public native static long NewSlice();
|
||
|
||
/**
|
||
* @return
|
||
* @brief 释放slice,和NewSlice成对使用
|
||
*/
|
||
public native static void FreeSlice(long slice);
|
||
|
||
/**
|
||
* @return 内容
|
||
* @brief 获取slice内容
|
||
*/
|
||
public native static String GetContentFromSlice(long slice);
|
||
|
||
/**
|
||
* @return 内容
|
||
* @brief 获取slice内容长度
|
||
*/
|
||
public native static int GetSliceLen(long slice);
|
||
|
||
public native static long NewMediaData();
|
||
|
||
public native static void FreeMediaData(long mediaData);
|
||
|
||
/**
|
||
* @return outindex
|
||
* @brief 获取mediadata outindex
|
||
*/
|
||
public native static String GetOutIndexBuf(long mediaData);
|
||
|
||
/**
|
||
* @return data
|
||
* @brief 获取mediadata data数据
|
||
*/
|
||
public native static byte[] GetData(long mediaData);
|
||
|
||
public native static int GetIndexLen(long mediaData);
|
||
|
||
public native static int GetDataLen(long mediaData);
|
||
|
||
/**
|
||
* @return 1完成、0未完成
|
||
* @brief 判断mediadata是否结束
|
||
*/
|
||
public native static int IsMediaDataFinish(long mediaData);
|
||
|
||
/**
|
||
* 判断Windows环境
|
||
*
|
||
* @return
|
||
*/
|
||
public static boolean isWindows() {
|
||
String osName = System.getProperties().getProperty("os.name");
|
||
log.info("Loading System Libraries, Current OS Version Is: {}", osName);
|
||
return osName.toUpperCase().contains("WINDOWS");
|
||
}
|
||
|
||
/**
|
||
* 加载系统类库
|
||
*
|
||
* @param libFiles 类库配置文件
|
||
* @param prefixPath 类库文件的前缀路径
|
||
*/
|
||
public Finance(List<String> libFiles, String prefixPath) {
|
||
boolean isWindows = Finance.isWindows();
|
||
for (String file : libFiles) {
|
||
String suffix = file.substring(file.lastIndexOf(".") + 1);
|
||
if (isWindows) {
|
||
// 加载dll文件
|
||
if (suffix.equalsIgnoreCase(DLL_FILE)) {
|
||
System.load(prefixPath + file);
|
||
}
|
||
} else {
|
||
// 加载so文件
|
||
if (suffix.equalsIgnoreCase(SO_FILE)) {
|
||
System.load(prefixPath + file);
|
||
}
|
||
}
|
||
}
|
||
|
||
}
|
||
|
||
/**
|
||
* 初始化类库文件
|
||
*
|
||
* @param libFiles
|
||
* @param prefixPath
|
||
* @return
|
||
*/
|
||
public synchronized static Finance loadingLibraries(List<String> libFiles, String prefixPath) {
|
||
if (finance != null) {
|
||
return finance;
|
||
}
|
||
finance = new Finance(libFiles, prefixPath);
|
||
return finance;
|
||
}
|
||
|
||
/**
|
||
* 单例sdk
|
||
*
|
||
* @return
|
||
*/
|
||
public synchronized static long SingletonSDK() {
|
||
if (sdk > 0) {
|
||
return sdk;
|
||
}
|
||
sdk = Finance.NewSdk();
|
||
return sdk;
|
||
}
|
||
|
||
/**
|
||
* 销毁sdk,保证线程可见性
|
||
*
|
||
* @return
|
||
*/
|
||
public synchronized static void DestroySingletonSDK(long destroySDK) {
|
||
sdk = 0L;
|
||
Finance.DestroySdk(destroySDK);
|
||
}
|
||
|
||
}
|