设备安全服务-应用设备状态检测
介绍
本示例向您介绍如何在应用中获取DeviceToken用于对应用的设备状态进行检测。
需要使用设备安全服务接口 @kit.DeviceSecurityKit。
效果预览
Sample工程的配置与使用
在DevEco中配置Sample工程的步骤如下
- [创建项目]及[应用]。
- 打开Sample应用,使用[AppGallery Connect]配置的应用包名替换app.json5文件中的bundleName属性值。
- 使用[AppGallery Connect]配置的应用Client ID替换module.json5文件中的client_id属性值。
- 生成SHA256应用签名证书指纹并添加到[AppGallery Connect]对应的应用配置中,证书指纹生成请参考应用开发准备中的[添加公钥指纹]章节。
- 在开通安全检测服务,具体Device Security Kit开发指南。
Sample工程使用说明
- 运行该 Sample 应用前,先对设备进行联网。
- 运行该 Sample 应用,点击"CheckSysIntegrity"按钮获取系统完整性检测结果,点击"CheckUrlThreat"按钮获取URL检测结果,如果获取成功,页面会显示检测结果,如果获取失败,页面会显示相应的错误码。
具体实现
本示例展示系统完整性检测,URL检测的功能在页面中直接调用,使用safetyDetect.checkSysIntegrity()方法获取当前设备的系统完整性检测结果,使用safetyDetect.checkUrlThreat()方法获取URL检测结果。
源码参考SafetyDetectModel.ts
import { hilog } from '@kit.PerformanceAnalysisKit';
import { safetyDetect } from '@kit.DeviceSecurityKit';
import { BusinessError} from '@kit.BasicServicesKit';
const TAG: string = '[SafetyDetectModel]';
function checkSysIntegrityPromise(): Promise<String> {
return new Promise(async (resolve, reject) => {
let strLen: number = 16;
let srcStr: string = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefhijklmnopqrstuvwxyz0123456789";
let randomStr: string = "";
for (let i = 0; i < strLen; i++) {
randomStr += srcStr.charAt(Math.floor(Math.random() * srcStr.length));
}
let sysIntegrityRequest: safetyDetect.SysIntegrityRequest = {
nonce: randomStr
}
try {
hilog.info(0x0000, TAG, 'CheckSysIntegrity begin.');
let sysIntegrityResponse: safetyDetect.SysIntegrityResponse =
await safetyDetect.checkSysIntegrity(sysIntegrityRequest);
let result: string = sysIntegrityResponse.result;
resolve(result);
hilog.info(0x0000, TAG, 'Succeeded in checkSysIntegrity: %{public}s', result);
}
catch (err) {
hilog.error(0x0000, TAG, 'CheckSysIntegrity failed: %{public}d %{public}s', err.code, err.message);
reject(err);
}
});
}
function checkUrlThreatPromise(): Promise<String> {
return new Promise(async (resolve, reject) => {
let urlCheckRequest: safetyDetect.UrlCheckRequest = {
urls: ['https://an.example.test','https://www.huawei.com']
}
try {
hilog.info(0x0000, TAG, 'CheckUrlThreat begin.');
let urlCheckResponse: safetyDetect.UrlCheckResponse = await safetyDetect.checkUrlThreat(urlCheckRequest);
let results: safetyDetect.UrlCheckResult[] = urlCheckResponse.results;
let resultStr: string = "";
for (let result of results) {
let url: string = result.url;
let threat: safetyDetect.UrlThreatType = result.threat;
resultStr = resultStr + "url: " + url + " threat: " + threat + "\n";
}
resolve(resultStr);
hilog.info(0x0000, TAG, 'Succeeded in checkUrlThreat: %{public}s', resultStr);
}
catch (err) {
hilog.error(0x0000, TAG, 'CheckUrlThreat failed: %{public}d %{public}s', err.code, err.message);
reject(err);
}
});
}
export class SafetyDetectModel {
private dispalyText: String = '';
async checkSysIntegrity(callback: Function) {
this.dispalyText = '';
await checkSysIntegrityPromise().then((token) => {
this.dispalyText = token;
callback(this.dispalyText);
}).catch((err: BusinessError) => {
this.dispalyText = 'check SysIntegrity failed, errCode is ' + err.code;
callback(this.dispalyText);
});
}
async checkUrlThreat(callback: Function) {
this.dispalyText = '';
await checkUrlThreatPromise().then((token) => {
this.dispalyText = token;
callback(this.dispalyText);
}).catch((err: BusinessError) => {
this.dispalyText = 'check UrlThreat failed, errCode is ' + err.code;
callback(this.dispalyText);
});
}
}
let safetyDetectModel = new SafetyDetectModel();
export default safetyDetectModel as SafetyDetectModel;
以上就是本篇文章所带来的鸿蒙开发中一小部分技术讲解;想要学习完整的鸿蒙全栈技术。可以在结尾找我可全部拿到!
下面是鸿蒙的完整学习路线,展示如下:
除此之外,根据这个学习鸿蒙全栈学习路线,也附带一整套完整的学习【文档+视频】,内容包含如下:
内容包含了:(ArkTS、ArkUI、Stage模型、多端部署、分布式应用开发、音频、视频、WebGL、OpenHarmony多媒体技术、Napi组件、OpenHarmony内核、鸿蒙南向开发、鸿蒙项目实战)等技术知识点。帮助大家在学习鸿蒙路上快速成长!
鸿蒙【北向应用开发+南向系统层开发】文档
鸿蒙【基础+实战项目】视频
鸿蒙面经
为了避免大家在学习过程中产生更多的时间成本,对比我把以上内容全部放在了↓↓↓想要的可以自拿喔!谢谢大家观看!