集成要求
环境要求
条目 | 说明 |
---|---|
兼容版本 | Android 5.0及以上系统 |
支持架构 | armeabi, armeabi-v7a, arm64-v8a, x86, x86_64 |
集成步骤
安装配置
添加仓库
在项目根目录的 build.gradle
加入maven库的配置
allprojects {
repositories {
...
mavenCentral()
}
}
如果您的 Gradle 版本是 7 或更高版本,请将下方配置添加到工程的 settings.gradle
repositories {
...
mavenCentral()
}
添加依赖
在应用主模块的 build.gradle
中,声明SDK包依赖
dependencies {
implementation 'com.trustdecision.android:mobrisk:4.7.0'
implementation 'com.trustdecision.android:apisign:1.1.1'
}
配置ABI类型
SDK目前支持多种ABI类型,建议接入方在主模块build.gradle
文件内添加 abiFilters
配置选择所需要的架构类型,具体架构,请以您自己需要支持的架构为准!
defaultConfig {
...
ndk {
abiFilters 'armeabi-v7a', 'arm64-v8a'
}
}
接口签名
方法定义
public static TDAPISignResult sign(Context context, String path);
结构体定义
public class TDAPISignResult {
// 签名结果
private String sign;
// 签名状态码
private int code;
// 异常信息
private String msg;
}
最佳实践
待保护的API形如:https://cn.apitd.net/de/v1?name=jacky&age=12
TDAPISignResult signResult = TDRisk.sign(context, "de/v1");
if(signResult.code() == 0) {
// 获取签名并使用
String signature = signResult.signature();
} else {
// 获取错误信息和状态码
String message = signResult.message();
int code = signResult.code();
// 继续业务逻辑,此处签名可以用空字符替代
}
状态检查
通过加签返回的结构体拿到的状态码为0,则加签成功
TDAPISignResult.code == 0
混淆打包
如果开发者需要使用 proguard 进行混淆打包,请在 proguard 配置文件添加如下代码:
-keep class com.trustdecision.**{*;}
状态码
错误码 | 错误信息 | 处理方式 |
---|---|---|
0 | 成功 | / |
2000 | path为空 | 请设置path参数 |
22xx | 内部错误 | 请联系同盾技术支持 |
4001 | 调用so文件失败,可能是SDK依赖的so文件已经缺失 | 请检查当前设备所使用的架构是否有配置到项目中 |
4002 | 调用SDK失败 | 请检查apisign模块是否引入到项目中 |