news 2026/4/18 12:31:22

Uniapp——安卓Android友盟一键登录插件教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Uniapp——安卓Android友盟一键登录插件教程

文章目录

    • 概要
    • 1.Android原生添加友盟SDK
    • 2.实现插件module;
    • 3.JS端使用教程
    • 技术细节
    • 小结

概要

提示:请先学习博主之前插件教程,再来学习此篇文章

地址如下:Uniapp——开发Android插件教程

1.Android原生添加友盟SDK



2.实现插件module;

提示:需要创建对应的module类

/** * 为满足工信部合规要求,请确保按照合规指南进行预初始化 * https://developer.umeng.com/docs/119267/detail/182050 */UMConfigure.preInit(this,"替换为Appkey,服务后台位置:应用管理 -> 应用信息 -> Appkey","渠道信息");/* * 0.在Application的onCreate方法中初始化Appkey等信息 */UMConfigure.init(this,"替换为Appkey,服务后台位置:应用管理 -> 应用信息 -> Appkey","渠道信息",UMConfigure.DEVICE_TYPE_PHONE,"");/* * 1.初始化获取token实例 */mTokenListener=newUMTokenResultListener(){}/* * 2.初始化SDK实例 */umVerifyHelper=UMVerifyHelper.getInstance(context,mTokenListener);/* * 3.设置SDK密钥 */umVerifyHelper.setAuthSDKInfo();/* * 4.检测终端网络环境是否支持一键登录或者号码认证 */umVerifyHelper.checkEnvAvailable();/* * 5.若步骤4支持,则根据业务情况,调用预取号或者一键登录接口 * 详见demo接入工程 */umVerifyHelper.getLoginToken(context,5000);

具体如何使用:
提示:

invoke调用javascript回调方法,此方法将在调用后被销毁。
invokeAndKeepAlive 调用javascript回调方法并保持回调活动以备以后使用。

publicclassOneLoginEventextendsUniModule{publicUniJSCallbackcallback;publicVerifyHelperumVerifyHelper;/// 所有的监听回调事件,都会执行publicUMTokenResultListenermTokenListener=newUMTokenResultListener(){@OverridepublicvoidonTokenSuccess(Strings){Log.e(TAG,"onTokenSuccess--"+s);if(s.code=="600024"){/** *预取号码信息,建议在 APP 登录页初始化时调用,提高后续授权页的打开速度。 *不要在 App 启动初始化时调用,避免接口调用资源浪费 *@param overdueTime 预取信息有效期 单位ms *@param listener 预取结果回调函数 */umVerifyHelper.accelerateLoginPage(5000,newUMPreLoginResultListener(){@OverridepublicvoidonPreLoginSuccess(longtime){Log.e(TAG,"onPreLoginSuccess--"+time);}@OverridepublicvoidonPreLoginFail(StringfailReason){Log.e(TAG,"onPreLoginFail--"+failReason);}});}elseif(s.code=="600000"){///说明一键登录成功Stringtoken=s.token;///将token给到JS端,根据token获取到手机号和用户信息,完成登录流程;callback.invoke(token);///关闭登录页面quitLoginPage();}}@OverridepublicvoidonTokenFail(StringfailReason){Log.e(TAG,"onTokenFail--"+failReason);}};//1.初始化SDK@UniJSMethod(uiThread=true)publicvoidinitSDK(JSONObjectoptions,UniJSCallbackcallback){Log.e(TAG,"testAsyncFunc--"+options);if(callback!=null){JSONObjectdata=newJSONObject();data.put("code","success");callback.invoke(data);}UMConfigure.preInit(this,"替换为Appkey,服务后台位置:应用管理 -> 应用信息 -> Appkey","渠道信息");/* * 0.在Application的onCreate方法中初始化Appkey等信息 */UMConfigure.init(this,"替换为Appkey,服务后台位置:应用管理 -> 应用信息 -> Appkey","渠道信息",UMConfigure.DEVICE_TYPE_PHONE,"");}//2.注册监听事件@UniJSMethod(uiThread=true)publicvoidregister(JSONObjectoptions,UniJSCallbackcallback){Log.e(TAG,"checkEnvAvailable--"+options);umVerifyHelper=UMVerifyHelper.getInstance(mUniSDKInstance.getContext(),mTokenListener);/** * 设置SDK密钥信息 * @param secret 密钥信息 需要从服务端获取 */umVerifyHelper.setAuthSDKInfo("替换为SDK密钥信息,服务后台位置:应用管理 -> 应用信息 -> SDK密钥");}//3.检查环境是否支持号码认证/** * SDK环境检查函数,检查终端是否支持号码认证,通过UMTokenResultListener返回code * * @param type 1:本机号码校验 2:一键登录 * 600024 终端支持认证 * 600013 系统维护,功能不可用 */@UniJSMethod(uiThread=true)publicvoidcheckEnvAvailable(JSONObjectoptions,UniJSCallbackcallback){Log.e(TAG,"checkEnvAvailable--"+options);umVerifyHelper.checkEnvAvailable(2);}//4.唤起一键登录授权页面,在用户授权后获取一键登录的 Token@UniJSMethod(uiThread=true)publicvoidgetLoginToken(JSONObjectoptions,UniJSCallbackcallback){umVerifyHelper.getLoginToken(5000);}//4.登录成功,或者登录页面关闭后,调用该接口关闭授权页面@UniJSMethod(uiThread=true)publicvoidquitLoginPage(JSONObjectoptions,UniJSCallbackcallback){umVerifyHelper.quitLoginPage();}}

3.JS端使用教程

// require插件名称constoneLoginEvent=uni.requireNativePlugin('OneLoginEvent');// 使用插件oneLoginEvent.initSDK({position:'bottom',},result=>{///响应回调});// 使用插件oneLoginEvent.register({},result=>{///响应回调,这里可以获取到来自原生SDK的code、和token;具体自行测试,if(result.code=='600000'){//是用户一键登录成功,并获取到了token//这里拿到token,调用后台接口获取用户数据; 下面需要自行实现登录逻辑}});///执行检测方法之后;会执行 register 方法里面的回调oneLoginEvent.checkEnvAvailable({},result=>{});///执行检测方法之后;会执行 唤起一键登录界面oneLoginEvent.getLoginToken({},result=>{});

技术细节

提示:请先学习博主之前插件教程,再来学习此篇文章

地址如下:Uniapp——开发Android插件教程

小结

提供先进的推理,复杂的指令,更多的创造力。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/17 6:44:20

大模型高效微调--P-Tuning v2

文章目录P-Tuning v2 概述核心改进关键技术细节代码示例性能对比局限性https://github.com/THUDM/P-tuning-v2 P-Tuning v2 概述 P-Tuning v2 是清华大学团队提出的一种参数高效微调(Parameter-Efficient Fine-Tuning, PEFT)方法,旨在改进传…

作者头像 李华
网站建设 2026/4/17 22:56:36

6、PowerShell 安全与代码签名:深入解析与实践指南

PowerShell 安全与代码签名:深入解析与实践指南 1. PowerShell 配置文件概述 PowerShell 有多种类型的配置文件,不同的配置文件在适用范围和功能上有所不同。 - 所有用户主机特定配置文件 :PowerShell 控制台的所有用户主机特定配置文件名为 Microsoft.PowerShell_pro…

作者头像 李华
网站建设 2026/4/18 3:45:48

13、Windows 10 系统维护全攻略

Windows 10 系统维护全攻略 1. 系统维护概述 Windows 10 就像一辆汽车,要想让它运行良好,就需要进行维护。Windows 10 通过“安全和维护”屏幕,让用户了解与计算机健康状况有关的问题,该屏幕将问题分为“安全”和“维护”两部分。同时,可靠性监视器可以帮助你定位硬件和…

作者头像 李华
网站建设 2026/4/17 14:00:18

6、PowerShell 安全与代码签名全解析

PowerShell 安全与代码签名全解析 一、PowerShell 配置文件 PowerShell 有不同类型的配置文件,这些配置文件在不同的使用场景下发挥着重要作用。 1. 所有用户主机特定配置文件 :PowerShell 控制台的所有用户主机特定配置文件名为 Microsoft.PowerShell_profile.ps1 。…

作者头像 李华
网站建设 2026/4/18 3:47:05

7、PowerShell 代码签名与脚本编写最佳实践

PowerShell 代码签名与脚本编写最佳实践 代码签名 在使用 PowerShell 时,代码签名是保障脚本和配置文件安全性的重要手段。数字证书通常以 SPC 和 PVK 文件组合的形式颁发,例如 Verisign 或 Thawte 提供的证书。若要使用代码签名证书对 PowerShell 脚本或配置文件进行数字签…

作者头像 李华
网站建设 2026/4/18 3:51:28

16、使用 PowerShell 脚本管理 Exchange 服务器

使用 PowerShell 脚本管理 Exchange 服务器 在 Exchange 服务器管理中,PowerShell 脚本可以帮助管理员自动化执行各种任务,例如监控数据库中的空白空间、批量创建邮件启用的用户账户等。本文将介绍两个实用的 PowerShell 脚本: GetEvent1221Info.ps1 和 ProvisionExchan…

作者头像 李华