开发工具:Android Studio集成方式:Gradle在线集成安卓版本支持:minSdkVersion 19集成前准备注册账号使用秒验SDK之前,需要先在MobTech官网注册开发者账号并注册应用获取Mob提供的AppKey和AppSecret,详情可以点击查看创建应用流程提交审核一键登录是运营商提供的能力,在使用秒验SDK之前,您需要在Mob开发者后台提交秒验审核,详情可以点击查看秒验审核流程秒验SDK流程图
集成配置秒验SDK提供了两种集成方式,您可根据需要进行选择。需要注意的是,两种集成方式在功能上无任何区别,仅为集成方式不同,选取其中一种即可。Gradle集成配置SDK地址Android Studio的代码库配置方式随Gradle插件的不同版本有所不同。请根据您当前Gradle插件的版本,选择相应的配置方式。【7.0及以上版本】打开项目级“settings.gradle”文件,配置Maven仓地址,注意修改 repositoriesMode为 RepositoriesMode.PREFER_SETTINGS。 pluginManagement {
repositories {
gradlePluginPortal()
google()
mavenCentral()
maven {
url "https://mvn.mob.com/android"
}
}
}
dependencyResolutionManagement {
// repositoriesMode.set(RepositoriesMode.FAIL_ON_PROJECT_REPOS)
repositoriesMode.set(RepositoriesMode.PREFER_SETTINGS)
repositories {
gradlePluginPortal()
google()
mavenCentral()
maven {
url "https://mvn.mob.com/android"
}
}
}
打开Android Studio项目级build.gradle文件,配置MobSDK插件地址 buildscript {
dependencies {
// 增加MobSDK插件配置
classpath "com.mob.sdk:MobSDK2:+"
// 增加google services插件配置,用于集成FCM,不集成FCM可不配置
classpath 'com.google.gms:google-services:4.3.14'
}
}
plugins {
id 'com.android.application' version 'x.x.x' apply false
id 'com.android.library' version 'x.x.x' apply false
}
【7.0以下版本】打开Android Studio项目级build.gradle文件。在allprojects ->repositories里面配置maven仓地址。 allprojects {
repositories {
maven {
url "https://mvn.mob.com/android"
}
}
}
在buildscript->repositories中配置maven仓地址。 buildscript {
repositories {
maven {
url "https://mvn.mob.com/android"
}
}
}
在buildscript->dependencies中配置AppGallery Connect插件地址 buildscript {
dependencies {
//增加MobSDK插件配置
classpath "com.mob.sdk:MobSDK2:+"
}
}
添加依赖打开应用级的build.gradle文件。添加mob插件配置。请根据实际情况选择:方式一:在“com.android.application” 插件下一行添加如下配置。 apply plugin: 'com.mob.sdk'
方式二:在“plugins”中添加如下配置。 plugins {
id 'com.android.application'
id 'com.mob.sdk'
}
在文件末尾添加mob配置代码 MobSDK {
appKey "替换为MobTech官方申请的appkey"
appSecret "替换为MobTech官方申请的appkey对应的appSecret"
SecVerify {}
}
配置标识在gradle.properties中添加代码MobSDK.spEdition=IZNAO
Google Play 版本如果您的应用需要上架Google商店,请务必使用Google Play 版本。在gradle.properties中添加代码,如已添加 MobSDK.spEdition相关配置,则修改值为 GPP即可。MobSDK.spEdition=GPP
至此,Gradle集成方式已经完成。离线集成获取SDK在进行离线集成之前,请先联系在线客服获取离线SDK。添加SDK把获取到的离线SDK包放入项目中的libs文件夹内。引入SDK通过上一步添加SDK至项目中后,SDK包还未进行引用,需要添加下方所示引入代码后才可使用。implementation fileTree(dir: 'libs', include: ['.aar', '.jar'])
配置清单文件复制下方提供的清单文件代码至您的项目AndroidManifest.xml文件中。<manifest
<application
<------ start 需要添加的内容 start ------>
<meta-data
android:name="Mob-AppKey"
android:value="您的MOBSDK-Appkey" />
<meta-data
android:name="Mob-AppSecret"
android:value="您的MOBSDK-AppSecret" />
<provider
android:name="com.mob.MobProvider"
android:exported="false"
android:multiprocess="true"
android:authorities="${applicationId}.com.mob.MobProvider" />
<------ end 需要添加的内容 end ------>
</application>
</manifest>
至此,离线集成方式已经完成。http协议支持由于Android 9.0开始,系统强制使用https请求,运营商暂不支持https取号,因此需要关闭9.0系统的强制https功能,请在manifest的 Application 节点增加 usesCleartextTraffic 设置,如下所示:<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:usesCleartextTraffic="true">
指定so库(可选)电信免密登录能力使用了so库,开发者可根据自身应用支持的cpu架构,选择使用不同so库。// 根据需要选择对应的.so库
android {
defaultConfig {
applicationId '您的ApplicationId'
ndk {
// 选择要添加的对应 cpu 类型的so库,多个abi以“,”分隔。
abiFilters 'armeabi-v7a'
// 可指定的值为 'armeabi-v7a', 'arm64-v8a', 'armeabi', 'x86', 'x86_64',
}
}
}
添加混淆代码秒验SDK已经做了混淆处理,再次混淆会导致不可预期的错误,请在您的混淆脚本中添加如下的配置,跳过对秒验SDK的混淆操作-ignorewarnings
关闭某个运营商功能时编译通不过可以加上下面的代码
-dontpreverify
for SecVerify
-keep class com.mob.*{;}
for CTCC
-keep class cn.com.chinatelecom.account.*{;}
for CUCC
-dontwarn com.unicom.online.account.shield.**
-keep class com.unicom.online.account.shield.* {;}
-keep class com.sdk.*{;}
for CMCC
-dontwarn com.cmic.gen.sdk.**
-keep class com.cmic.gen.sdk.*{;}
-keep class com.cmic.sso.sdk.*{;}
for CUCCXW
-keep class com.unicom.xiaowo.account.shield.*{;}
另如有用到AndResGuard混淆资源问题,请在whiteList中添加如下混淆配置:秒验
R.anim.sec_verify_*,
R.drawable.sec_verify_*,
R.layout.sec_verify_*,
R.string.sec_verify_*,
R.color.sec_verify_*,
R.dimen.sec_verify_*,
R.style.sec_verify_*,
R.drawable.customized_toggle_*,
R.drawable.customized_checkbox_selector,
R.drawable.dialog_loading,
移动
R.anim.umcsdk_*,
R.drawable.umcsdk_*,
R.string.umcsdk_*,
R.dimen.umcsdk_*,
电信
R.anim.ct_account_*,
R.drawable.ct_account_*,
R.string.ct_account_*,
R.style.CtAuthDialog,
"R.anim.sec_verify_*",
"R.drawable.sec_verify_*",
"R.layout.sec_verify_*",
"R.string.sec_verify_*",
"R.color.sec_verify_*",
"R.dimen.sec_verify_*",
"R.style.sec_verify_*",
"R.drawable.customized_toggle_*",
"R.drawable.customized_checkbox_selector",
"R.drawable.dialog_loading",
"R.id.sec_verify_*",
"R.id.common_dialog_*",
"R.anim.umcsdk_*",
"R.drawable.umcsdk_*",
"R.string.umcsdk_*",
"R.dimen.umcsdk_*",
"R.anim.ct_account_*",
"R.drawable.ct_account_*",
"R.string.ct_account_*",
"R.style.CtAuthDialog",
"R.id.ct_account_*",
"R.id.ct_auth_*",
"R.string.service_name" ,
"R.style.Dialog_Common",
"R.id.progress_bar" ,
"R.drawable.loading"
隐私授权启动业务为保证您的App在集成MobSDK之后能够满足工信部相关合规要求,您应确保App安装首次冷启动且取得用户阅读您《隐私政策》授权之后,调用 MobSDK.submitPolicyGrantResult回传隐私协议授权结果。反之,如果用户不同意您App《隐私政策》授权,则不能调用 MobSDK.submitPolicyGrantResult回传隐私协议授权结果。 请参考秒验SDK隐私政策通用方案/**
- com.mob.MobSDK.class
- 回传用户隐私授权结果
- @param isGranted 用户是否同意隐私协议
*/
public static void submitPolicyGrantResult(boolean isGranted)
增加App数据采集主动控制器方案/**
- com.mob.MobSDK.class
- 回传用户隐私授权结果
- @param isGranted App数据采集主动控制器子类实例
- @param isGranted 用户是否同意隐私协议
*/
public static void submitPolicyGrantResult(MobCustomController cont, boolean isGranted);
示例代码注:submitPolicyGrantResult是MobSDK的业务起点。调用位置开发者可以自己指定,只需在使用SDK功能之前调用即可,强烈建议开发者在终端用户点击应用隐私协议弹窗同意按钮后调用。App数据采集主动控制器用来限制MobSDK采集并提供可选的数据维度和扩展功能。因相关信息的不收集将会对其对应的功能造成影响,请开发者结合业务实际需要进行合理配置。秒验SDK扩展业务功能设置可参考: https://www.mob.com/wiki/detailed?wiki=657&id=78 ,其它App数据采集主动控制器的配置方法可参考:https://www.mob.com/wiki/detailed?wiki=664&id=714MobSDK.submi...(new MobCustomController() {
// TODO 重写控制器
}, true);
// 或者
MobSDK.submitPolicyGrantResult(true);
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。