HarmonyOS NEXT实战:接入QQ SDK
##HarmonyOS Next实战##三方SDK##教育##
参考资料 移动应用接入流程: https://wiki.connect.qq.com/%e7%a7%bb%e5%8a%a8%e5%ba%94%e7%94%a8%e6%8e%a5%e5%85%a5%e6%b5%81%e7%a8%8b
HarmonyOS_SDK环境搭建: https://wiki.connect.qq.com/harmonyos_sdk%e7%8e%af%e5%a2%83%e6%90%ad%e5%bb%ba
SDK Demo下载: https://wiki.connect.qq.com/sdk%e4%b8%8b%e8%bd%bd
移动应用接入流程: 移动应用通过以下几个步骤,即可接入互联开放平台 [ https://connect.qq.com ] : 开发者注册 > 移动应用申请 > 移动应用开发 > 调用OpenAPI
- 开发者注册 在QQ互联开放平台首页 http://connect.qq.com/ ,点击右上角的“登录”按钮,使用QQ账号登录,登录成功后会跳转到开发者注册页面,在注册页面需要提交公司或个人的基本资料。
- 移动应用接入申请 · 移动应用接入前,需首先进行申请,获得对应的appid与appkey,以保证后续流程中可正确对移动应用与用户进行验证与授权。 · 如果您的PC应用已经接入腾讯开放平台,则不需要重新获得appid与appkey,只需使用接入腾讯开放平台时获得的appid,即可添加为移动应用。 · 添加移动应用:开发者注册成功后,会跳转到“管理中心”页面。点击“添加移动应用”,填写相应的信息。 · 移动应用信息填写完成,点击“确定”后,移动应用注册完成,进入管理中心,可以查看到移动应用获取的appid和appkey
- 移动应用开发 进入控制台页面,可以看到移动应用申请处于“开发”状态。移动应用上线,首先需对移动应用进行开发,即完成QQ登录功能并正常放置QQ登录按钮。
- 使用QQ互联提供的OpenAPI 完成移动应用的开发后,即可在“管理中心”的“控制台”页面,点击“当前流程”下的“申请上线”,流程处于“审核”状态。 提交审核后,腾讯会在两个工作日完成审核,审核通过后,移动应用即正式上线。
开发说明 QQ登录功能使用国际通用的OAuth2.0协议进行验证与授权,可通过以下方式进行移动应用开发: (1)QQ互联分别提供了iOS和Android的SDK开发包。如果手机安装了QQ,则启动手机QQ进行SSO登录。如没有安装,则通过手机系统的浏览器进行登录。登录的流程已经集成在SDK里,建议开发者使用此方法。详见:SDK下载 (2)根据QQ登录OAuth2.0协议,自主开发,此方法自定义程度较高,需要与现有系统进行整合的移动应用可选用此方法。
鸿蒙项目配置: 添加依赖,执行命令
ohpm i @tencent/qq-open-sdk
运行后在工程级 oh-package.json5 文件中可看到新增依赖库
"dependencies": {
"@tencent/qq-open-sdk": "^1.0.3"
}
修改模块配置: 修改entry的module.json5文件,配置skills
"skills": [
{
"entities": [
"entity.system.home",
"entity.system.browsable"
],
"actions": [
"action.system.home",
"ohos.want.action.viewData"
],
"uris": [
{
"scheme": "qqopenapi", // 接收 QQ 回调数据
"host": "xxxxxxxxx", // 业务申请的互联 appId,如果填错会导致 QQ 无法回调
"pathRegex": "\\b(auth|share)\\b",
"linkFeature": "Login",
}
]
}
]
继续修改entry的module.json5文件,增加querySchemes
"querySchemes": [
"https",
"qqopenapi"
]
增加SDK工具类: 添加QQOpenApiHolder
import { SdkConfig } from '@heduohao/bases'
import { IQQOpenApi, OpenApiConfig, QQOpenApiFactory } from '@tencent/qq-open-sdk'
export class QQOpenApiHolder {
private static qqOpenApi: IQQOpenApi
private constructor() {
}
public static create(): IQQOpenApi {
if (!QQOpenApiHolder.qqOpenApi) {
let openApiOption: OpenApiConfig = {
forceEnableWeb: false,
autoHandleAuthResult: true,
}
QQOpenApiHolder.qqOpenApi =
QQOpenApiFactory.createApi(SdkConfig.QQ_SDK_APP_ID, openApiOption)
}
return QQOpenApiHolder.qqOpenApi
}
public static getInstance(): IQQOpenApi {
return QQOpenApiHolder.qqOpenApi
}
}
EntryAbility接入QQOpenApiHolder
onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');
QQOpenApiHolder.create()
}
onNewWant(want: Want, _launchParam: AbilityConstant.LaunchParam): void {
QQOpenApiHolder.getInstance()?.handleResult(want)
}