本文是个验 HarmonyOS SDK 的集成文档,用于指导个验鸿蒙版本 SDK 的集成,读者需具有一定 HarmonyOS ArkTs 编程知识基础。
条目 | 资源 |
---|---|
开发目标 | HarmonyOS Next Release |
开发环境 | DevEco Studio 5.0.3.900 |
HarmonyOS | API Version 12 Release |
包增量 | 1.4M |
网络制式 | 移动 2G/3G/4G/5G,联通 3G/4G/5G,电信 4G/5G(2G/3G 网络下时延相对较高,成功率相对较低) |
网络环境 | 打开蜂窝数据流量并且给予应用蜂窝数据权限 |
本文默认读者已经具有基础的鸿蒙知识,以及项目工程结构如下:
GtsdkDemo/
|- entry/ (项目主模块)
| |- libs/ (第三方库,用户手动创建)
| |- src/ (代码目录)
| |- oh-package.json5(模块级oh-package.json5文件)
|- build-profile.json5
|- hvigorfile.ts
|- oh-package.json5 (顶层oh-package.json5文件)
| ......
注:其中 “......” 表示省略其他与本教程无关的内容,以下 “......” 表示相同意义,不再重复说明。
鸿蒙应用的bundlename
鸿蒙应用的fingerprint
fingerprint长度为64个字符
//在程序里调用该方法获取当前签名
getSign(): string {
let bundleFlags = bundleManager.BundleFlag.GET_BUNDLE_INFO_WITH_SIGNATURE_INFO;
let bundleInfo = bundleManager.getBundleInfoForSelfSync(bundleFlags)
return bundleInfo.signatureInfo.fingerprint
}
应用唯一标识
填入鸿蒙应用的appIdentifier信息。该appIdentifier信息就是在华为AppGallery Connect上获取到的APPID值,保存后无法修改。
创建个推应用
在开发者中心提交 APP 包名等信息后即可获取 APPID 等参数,然后等十分钟左右运营商侧报备成功后就可以正常使用了。点击前往开发者中心创建应用
HarmonyOS 压缩包附带的 demo 文件夹中是个验的示例工程,使用 DevEco Studio 打开示例工程,成以下配置步骤进行本地测试:
将签名配置改成您的签名配置;
将 APPID 换成您的信息(需注意 APPID 和包名/包签名的一致性);
参照服务端接入文档完成服务端接口的对接,注意客户端 APPID 与服务端保持一致。如未完成该步
骤则仅能体验APP端功能,不能获取真实手机号。
将获取的 GY-HM-XXX.har 文件拖拽到模块中的 libs 文件夹下。
在拖入 .har 到 libs 文件夹后,还要检查 .har 是否被 install ,要在模块的 oh-package.json5 下添加如下代码
dependencies": {
"@getui/gysdk": "file:./libs/GY-HM-XXX.har"
}
配置APPID(必选) 和 CHANNEL(非必选)
项目的module.json5文件中配置appid
"metadata": [
{
"name": "GETUI_APPID",
//替换成个推平台申请的appid
"value":"APPID"
},
{
"name": "GT_INSTALL_CHANNEL",
"value": 'CHANNEL'
}]
module.json5 权限配置:
sdk内部已配置了以下权限
"requestPermissions": [
{
//允许应用程序联网,用于访问网关和认证服务器
"name": "ohos.permission.INTERNET",
},
{
//获取网络状态,判断是否数据、wifi等
"name": "ohos.permission.GET_NETWORK_INFO"
},
{
//允许获取wifi信息
"name": "ohos.permission.GET_WIFI_INFO"
},
{
//允许应用配置数据网络
"name": "ohos.permission.SET_NETWORK_INFO"
},
{
//用于创建唯一的gyuid标识
"name": "ohos.permission.APP_TRACKING_CONSENT",
"reason": "$string:gy_oaid_tracking"
}
]
工程配置
请设置 useNormalizedOHMUrl 为true,查看工程级build-profile.json5:
"products": [
{
"name": "default",
//换成app报备时的签名
"signingConfig": "xxxxxx",
"compatibleSdkVersion": "5.0.0(12)",
"runtimeOS": "HarmonyOS",
"buildOption": {
"strictMode": {
"useNormalizedOHMUrl": true
}
}
}
]
为了保证 SDK 服务稳定,开发者需在 App《隐私政策》的 “与授权合作伙伴共享”条款中,将 个推的用户隐私政策 加入其中。在判断用户已经同意隐私政策后、或者弹出确认框用户同意后再初始化 gysdk,注意:此时SDK功能尚未启用,GYUID暂未生成。详情可查看:个推合规指南 。
生成唯一的客户端ID,即GYUID,为了保障一键认证可以正常使用,您务必确保用户同意《隐私政策》之后,调用初始化 方法。若不调用则无法注册GYUID ,一键认证功能无法正常使用
public init(config: GyConfig): Promise<GyResponse>
GyConfig配置包含以下信息
参数 | 类型 | 说明 |
---|---|---|
context | Context | 上下文 |
debug | boolean | 设置是否开启 SDK 日志打印功能,默认为false |
preLoginUseCache | boolean | 预登录是否支持缓存,默认为true |
channel | string | 设置当前的渠道 |
ePreLogin
预登录获取带星PN登录
isPreLoginResultValid
判断eAccountLogin
拉起授权页,点击登录成功返回token关闭授权页
closeAuthLoginPage
可关闭当前授权页在登录前调用,登录成功后预登录结果就失效了,如果需要再次登录请重新调用ePreLogin
确保预登录的有效性
public ePreLogin(timeout: number): Promise<GyResponse>
参数 | 类型 | 说明 |
---|---|---|
timeout | number | 超时时间 |
此接口会拉起授权页登录才能获取token,成功获取token即可用于服务端取号
public eAccountLogin(timeout: number, config?: GyAuthThemeConfig): Promise<GyResponse>
参数 | 类型 | 说明 |
---|---|---|
timeout | number | 超时时间 |
config | GyAuthThemeConfig | 移动的授权页样式配置 |
为了确保用户在登录过程中将手机号码信息授权给开发者使用的知情权,一键登录需要开发者提供授权页登录页面供用户授权确认。开发者必须弹出授权页,明确告知用户当前操作会将用户的本机号码信息传递给应用。
授权页示例如下:
注意:
1、页面必要元素有:号码栏(NumberTextview),品牌露出(SloganTextview),登录按钮(LoginButton),隐私确认(PrivacyCheckbox),隐私标题(PrivacyTextview);
2、开发者不得通过任何技术手段,破解授权页,或将上述授权页面的必要元素内容隐藏、覆盖、或者动态变更;
3、登录按钮文字描述必须包含“登录”或“注册”等文字,不得诱导用户授权;
4、对于接入GYSDK并上线的应用,我方和运营商会对上线的应用授权页面做审查,如果有出现未按要求弹出或设计授权页面的,将关闭应用的认证取号服务。
SDK不会主动关闭授权页,需要开发者在回调结束后自行实现关闭授权页
public closeAuthLoginPage()
getVerifyToken
获取校验token(对于双卡手机,则认证是否为当前流量对应的本机号码)verifyPhoneNumber
验证手机号码是否为本机号码获取需要校验的手机号码的token
public getVerifyToken(phone: string, timeout: number): Promise<GyResponse>
参数 | 类型 | 说明 |
---|---|---|
phone | string | 需进行认证的手机号码 |
timeout | number | 超时时间 |
验证手机号码是否为本机号码
public verifyPhoneNumber(token: string, processId:
string, phone: string, operatorType: number): Promise<GyResponse>
以下参数可以通过getVerifyToken
返回的GyResponse
中获取
参数 | 类型 | 说明 |
---|---|---|
timeout | number | 超时时间 |
processId | string | 流水号 |
phone | string | 需进行认证的手机号码 |
operatorType | number | 运营商类型 |