KB: 121052
·
更新时间:2019-06-17 13:58:30
本文档为一键登录Android SDK接入文档
号码认证服务Android SDK目前主要提供功能:
(1)设备是否已开启蜂窝数据网络判断,这个是号码网关认证的前提条件
(2)获取一键登录token接口(目前支持中国移动2/3/4G、中国联通3/4G中国电信4G)目前SDK提供aar包。
(1)Number Authenticate SDK 获取
开通服务后,在控制台下载SDK。
将aar拷贝至工程的libs目录下。
(2)APP工程AndroidManifest.xml增加Activity声明
(2)//联通电信授权页(3)<activity android:name="com.mobile.auth.gatewayauth.LoginAuthActivity" android:configChanges="orientation|keyboardHidden|screenSize" android:exported="false" android:launchMode="singleTop" android:screenOrientation="portrait" />(4)//协议页面webview<activityandroid:name="com.mobile.auth.gatewayauth.activity.AuthWebVeiwActivity" android:configChanges="orientation|keyboardHidden|screenSize" android:exported="false" android:launchMode="singleTop" android:screenOrientation="portrait" />(6)//移动授权页<activity android:name="com.cmic.sso.sdk.activity.LoginAuthActivity" android:configChanges="orientation|keyboardHidden|screenSize" android:launchMode="singleTop" android:screenOrientation="portrait" />
(3)混淆keep规则
-keep class cn.com.chinatelecom.gateway.lib.** {*;}-keep class com.unicom.xiaowo.login.** {*;}-keep class com.cmic.sso.sdk.** {*;}-keep class com.mobile.auth.gatewayauth.** {*;}-keep class android.support.v4.** { *;}-keep class org.json.**{*;}-keep class com.alibaba.fastjson.** {*;}
(4)增加fastjson依赖,若已依赖请忽略。
gradle:compile 'com.alibaba:fastjson:1.2.5'maven:<dependency> <groupId>com.alibaba</groupId> <artifactId>fastjson</artifactId> <version>1.2.5</version></dependency>
lib依赖:直接点击下载。
/** * 函数名:getInstance * @param context * @param tokenListener * 返回:PhoneNumberAuthHelper 实例 */public static PhoneNumberAuthHelper getInstance(Context context, TokenResultListener tokenListener)/** * SDK初始化函数,检查终端是否支持号码认证,并读取SIM卡中号码 * @return InitResult * boolean can4GAuth 是否能支持4g网关认证 */public InitResult checkAuthEnvEnable()/** * 设置SDK是否debug模式运行 * @param isDebug true则输出关键步骤运行日志 */public void setDebugMode(boolean isDebug);/** * 退出登录授权页,授权页的退出完全由APP控制 * SDK完成回调后,不会立即关闭授权页面,需要开发者主动调用离开授权页面方法去完成页面的关闭*/public void quitAuthActivity();/** * 预取号码信息,建议在getLoginToken之前调用,加速授权页打开速度。 * @param overdueTime 预取信息有效期 单位分钟 * @param listener 预取结果回调函数 */public void preLogin(final int overdueTime, final PreLoginResultListener listener)public interface PreLoginResultListener { /** * @param vendor 返回预取成功运营商 */ void onTokenSuccess(String vendor); /** * @param vendor 返回预取失败运营商 * @param ret 返回失败原因 */ void onTokenFailed(String vendor, String ret);}/** * 唤起一键登录授权页面,在用户授权后获取一键登录的Token * @param totalTimeout 超时时间 单位ms */public void getLoginToken (int timeout):/** * 动态添加控件 * @param viewID 开发者自定义控件名称 * @param viewConfig 配置开发者自定义控件的控件来源、位置和处理逻辑 */public void addAuthRegistViewConfig(String viewID, AuthRegisterViewConfig viewConfig)/** * 修改授权页面主题,开发者可以通过 此方法修改授权页面主题 * 需在 getLoginToken接口之前调用 * @param authUIConfig 登录授权页UI自定义配配置 */public void setAuthUIConfig (AuthUIConfig authUIConfig)
1.首先并不能100%读取成功,是否能读取成功,需要用户授予“READ_PHONE_STATE”权限。
2.其次SIM卡有物理写入本机号码,而是否写入本机号码,并不是100%,要看发卡机构是否规范。
3.且从sim卡读取出来的本机号码,仅仅只是在读取成功时,去帮忙用户预填手机号至号码输入框,减少用户输入的交互优化,而且用户也是可以去修改预填的号码。
4.最后无论是否读取成功号码,通过服务端进行号码认证是必不可少的,因为仅仅从sim卡读取手机号码,并不能保证其准确性与真实性。
若出现权限相关问题,请检查APP的权限是否申请正常。正常引用aar,权限会自动merge。若权限没有merge,需要添加如下权限。
<uses-permission android:name="android.permission.INTERNET" /><uses-permission android:name="android.permission.READ_PHONE_STATE" /><uses-permission android:name="android.permission.ACCESS_WIFI_STATE" /><uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" /><uses-permission android:name="android.permission.CHANGE_NETWORK_STATE" />
中国移动支持2G/3G/4G、中国联通支持3G/4G、中国电信支持4G,但2G网络下认证失败率稍高。
注意混淆keep规则在proguard-rules.pro文件的增加
请检查开发的APK的包名和签名,与阿里云后台创建应用的提交的信息是否一致
终端侧的SDK仅仅是通过用户的移动网络获取token,最终判断用户输入的号码是否是本机号码,需要通过应用服务端带上终端侧获取到的token与用户输入的号码,调用云通信服务端提供的认证API,认证的动作是服务端与服务端之间的通信,SDK不能独立完成。
公司名称:上海德诚网联网络技术服务有限公司
客服热线:021-61958165
联系邮箱:wangt@netlink.net.cn
举报邮箱:jubao@netlink.net.cn
地址:上海市闵行区东兰路320号5号楼201室