概述
UserAgent(简称UA)是一个特殊的字符串,它包含了设备类型、操作系统及版本等关键信息。如果页面无法正确识别UA,可能会导致一系列异常情况,例如页面布局错误、渲染问题以及逻辑错误等。
默认UserAgent结构
从API version 11起,Web组件基于ArkWeb的内核。
-
默认UserAgent定义
Mozilla/5.0 ({deviceType}; {OSName} {OSVersion}; {DistributionOSName} {DistributionOSVersion}) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36 ArkWeb/{ArkWeb VersionCode} {Mobile} {扩展区}
-
举例说明
Mozilla/5.0 (Phone; OpenHarmony 5.0; HarmonyOS 5.0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/114.0.0.0 Safari/537.36 ArkWeb/4.1.6.1 Mobile
字段 | 含义 |
---|---|
deviceType | 当前的设备类型。 取值范围: - Phone:手机设备 - Tablet:平板设备 - PC:2in1设备 |
OSName | 基础操作系统名称。 默认取值:OpenHarmony |
OSVersion | 基础操作系统版本,两位数字,M.S。 默认取值:例如 5.0 。 |
DistributionOSName | 发行版操作系统名称。 默认取值:HarmonyOS |
DistributionOSVersion | 发行版操作系统版本,两位数字,M.S。 默认取值:例如 5.0 |
ArkWeb | HarmonyOS版本Web内核名称。 默认取值:ArkWeb |
ArkWeb VersionCode | ArkWeb版本号,格式a.b.c.d。 默认取值:例如4.1.6.1 |
deviceCompat | 前向兼容字段。 默认取值:Mobile |
扩展区 | 三方应用可以扩展的字段。 三方应用使用ArkWeb组件时,可以做UserAgent扩展,例如加入应用相关信息标识。 |
说明:
- 当前通过UserAgent中是否含有"Mobile"字段来判断是否开启前端HTML页面中meta标签的viewport属性。当UserAgent中不含有"Mobile"字段时,meta标签中viewport属性默认关闭,此时可通过显性设置metaViewport属性为true来覆盖关闭状态。
- 建议通过
OpenHarmony
关键字识别是否是HarmonyOS设备,同时可以通过deviceType识别设备类型用于不同设备上的页面显示。
自定义UserAgent结构
在下面的示例中,通过getUserAgent()接口获取当前默认用户代理,支持开发者基于默认的UserAgent去定制UserAgent。
// xxx.ets
import { webview } from '@kit.ArkWeb';
import { BusinessError } from '@kit.BasicServicesKit';
@Entry
@Component
struct WebComponent {
controller: webview.WebviewController = new webview.WebviewController();
build() {
Column() {
Button('getUserAgent')
.onClick(() => {
try {
let userAgent = this.controller.getUserAgent();
console.info("userAgent: " + userAgent);
} catch (error) {
console.error(`ErrorCode: ${(error as BusinessError).code}, Message: ${(error as BusinessError).message}`);
}
})
Web({ src: 'www.example.com', controller: this.controller })
}
}
}
以下示例通过setCustomUserAgent()接口设置自定义用户代理,会覆盖系统的用户代理。建议将扩展字段追加在默认用户代理的末尾。
当Web组件src设置了url时,建议在onControllerAttached回调事件中设置UserAgent,设置方式请参考示例。不建议将UserAgent设置在onLoadIntercept回调事件中,会概率性出现设置失败。如果未在onControllerAttached回调事件中设置UserAgent。再调用setCustomUserAgent方法时,可能会出现加载的页面与实际设置UserAgent不符的异常现象。
当Web组件src设置为空字符串时,建议先调用setCustomUserAgent方法设置UserAgent,再通过loadUrl加载具体页面。
// xxx.ets
import { webview } from '@kit.ArkWeb';
import { BusinessError } from '@kit.BasicServicesKit';
@Entry
@Component
struct WebComponent {
controller: webview.WebviewController = new webview.WebviewController();
// 三方应用相关信息标识
@State customUserAgent: string = ' DemoApp';
build() {
Column() {
Web({ src: 'www.example.com', controller: this.controller })
.onControllerAttached(() => {
console.info("onControllerAttached");
try {
let userAgent = this.controller.getUserAgent() + this.customUserAgent;
this.controller.setCustomUserAgent(userAgent);
} catch (error) {
console.error(`ErrorCode: ${(error as BusinessError).code}, Message: ${(error as BusinessError).message}`);
}
})
}
}
}
在下面的示例中,通过getCustomUserAgent()接口获取自定义用户代理。
// xxx.ets
import { webview } from '@kit.ArkWeb';
import { BusinessError } from '@kit.BasicServicesKit';
@Entry
@Component
struct WebComponent {
controller: webview.WebviewController = new webview.WebviewController();
@State userAgent: string = '';
build() {
Column() {
Button('getCustomUserAgent')
.onClick(() => {
try {
this.userAgent = this.controller.getCustomUserAgent();
console.log("userAgent: " + this.userAgent);
} catch (error) {
console.error(`ErrorCode: ${(error as BusinessError).code}, Message: ${(error as BusinessError).message}`);
}
})
Web({ src: 'www.example.com', controller: this.controller })
}
}
}
常见问题
如何通过UserAgent来识别HarmonyOS操作系统中不同设备
HarmonyOS设备的识别主要通过UserAgent中的系统版本和设备类型两个维度来判断。
建议同时检查系统版本和设备类型,以确保更准确的设备识别。
-
系统版本识别
通过UserAgent中的
{OSName}
字段的OpenHarmony
关键字来识别HarmonyOS系统。// 参考代码,检测是否为HarmonyOS系统 const isHarmonyOS = () => /OpenHarmony/i.test(navigator.userAgent);
-
设备类型识别
通过deviceType字段来识别不同设备类型。
// 参考代码,检测是否为手机设备 const isPhone = () => /Phone/i.test(navigator.userAgent); // 参考代码,检测是否为平板设备 const isTablet = () => /Tablet/i.test(navigator.userAgent); // 参考代码,检测是否为2in1设备 const is2in1 = () => /PC/i.test(navigator.userAgent);
如何模拟HarmonyOS操作系统的UserAgent进行前端调试
在Windows/Mac/Linux等操作系统中,可以通过Chrome/Edge/Firefox等浏览器DevTools提供的UserAgent复写能力,模拟HarmonyOS UserAgent。