cordova plugin add cordova-plugin-rangersapplog
如您使用CocoaPods远程集成,请参考【外部】iOS SDK集成1.1~1.4小节;
如您需手动引入集成,请参考1.5小节。
如需使用实时埋点检测(https://www.volcengine.com/docs/6285/66054)功能,请参考【外部】iOS SDK集成 第3节,配置Scheme。
如您使用远程集成,请参考【外部】Android SDK集成 1.1~1.5小节;
如您需手动引入集成,请参考1.7小节。
如需使用实时埋点检测(https://www.volcengine.com/docs/6285/66054)功能,请参考【外部】Android SDK集成 第3节,配置Scheme。
说明
SDK会在初始化的时候就采集用户信息,请确保您采集用户信息之前已经获得用户授权。
合规建议操作如下:
用户授权后再进行SDK的初始化,取得用户授权前所有的信息都不会采集,预置事件也不会被采集。
在开始集成前,首先需要在集团中接入一个项目及应用,进行SDK集成前,您需要获取对应应用的appid信息。
私有化场景下您可以在「全局设置」->「系统设置」->「集团设置」-> 「项目列表」中查看项目详情,可查看其中的appid,详情请参见集团设置。
私有化部署版本需要获取数据上送地址。
如您不清楚此地址,请联系您的项目经理或客户成功经理。
Cordova目前需在原生端代码中完成初始化,分别初始化Android SDK、iOS SDK。
如您使用SaaS部署版本,请参考如下代码:
Cordova目前需在原生端代码中完成初始化,分别初始化Android SDK、iOS SDK。
如您使用私有化部署版本,请参考如下代码:
如您的产品中有账户体系,请在用户登录后立即设置uuid,以保证用户登录前后口径一致性。
const AppLog = cordova.plugins.AppLog; // 登录时设置您账号体系的ID, 并保证其唯一性 AppLog.setUserUniqueId('{{USER_UNIQUE_ID}}',(v)=>{ console.log("登录成功"); },(err) =>{ console.log(err.message); });
在账户登出时调用。
const AppLog = cordova.plugins.AppLog; // 登出时设置uuid为null AppLog.setUserUniqueId(null,()=>{ console.log("登出成功"); },(err) =>{ console.log(err.message); });
设置用户属性,存在则覆盖,不存在则创建。
const AppLog = cordova.plugins.AppLog; // 示例:设置用户属性,属性名为key,属性值为value AppLog.profileSet({ "key": "value" }, () => { console.log('设置用户属性成功'); }, (err) => { console.log('设置用户属性失败:' + err.message); });
设置用户属性,存在则不设置,不存在则创建,适合首次相关的用户属性,比如首次访问时间等。
const AppLog = cordova.plugins.AppLog; // 示例:设置用户属性,属性名为key_once,属性值为value_once AppLog.profileSetOnce({ "key_once": "value_once" }, () => { console.log('设置用户属性成功'); }, (err) => { console.log('设置用户属性失败:' + err.message); });
设置数值类型的属性,可进行累加。
const AppLog = cordova.plugins.AppLog; // 示例:设置用户属性,属性名为key,属性值为1 AppLog.profileIncrement({ "key": 1 }, () => { console.log('设置用户属性成功'); }, (err) => { console.log('设置用户属性失败:' + err.message); });
设置List类型的用户属性,可持续向List内添加。
const AppLog = cordova.plugins.AppLog; // 示例:置用户属性,属性名为key,原本已有属性值,现添加属性值为value_append AppLog.profileAppend({ "key": "value_append" }, () => { console.log('设置用户属性成功'); }, (err) => { console.log('设置用户属性失败:' + err.message); });
删除用户的属性。
const AppLog = cordova.plugins.AppLog; // 示例:删除用户属性,属性名为key AppLog.profileUnset("key", () => { console.log('设置用户属性成功'); }, (err) => { console.log('设置用户属性失败:' + err.message); });
可以直接传入 key,从配置中读取需要的值(Anrdoid 不支持)。
const AppLog = cordova.plugins.AppLog; // 示例:获取 key 为 ab_test_key 的 value AppLog.getABTestConfigValueForKey("ab_test_key", (value) => { console.log('获取Ab实验值成功:' + value); }, (err) => { console.log('获取Ab实验值失败:' + err.message); });
返回值是所有实验版本ID,以逗号隔开(Anrdoid 不支持)。
const AppLog = cordova.plugins.AppLog; // 示例:获取所有 ab sdk version AppLog.getAbSdkVersions((vids) => { console.log('获取AbSdkVersions成功:' + vids); }, (err) => { console.log('获取AbSdkVersions失败:' + err.message); });
用户行为日志采用事件event+属性params的形式,事件一般对应多个属性,也可以仅有事件没有属性。
仅上报事件的代码埋点,示例如下:
const AppLog = cordova.plugins.AppLog; // 示例:上报事件event,该事件不包含属性 AppLog.onEventV3("event", {}, () => { console.log('调用上报埋点成功'); }, (err) => { console.log('调用上报埋点失败:' + err.message); });
上报事件和对应属性的代码埋点,示例如下:
const AppLog = cordova.plugins.AppLog; // 示例:上报事件event,该事件包含两个属性 // 一个string类型的属性,属性名为key_string,属性值为value_string // 一个int类型的属性,属性名为key_int,属性值为10 AppLog.onEventV3("event", { "key_string": "value_string", "key_int": 10 }, () => { console.log('调用上报埋点成功'); }, (err) => { console.log('调用上报埋点失败:' + err.message); });
关于自定义 “公共属性” 请注意:
const AppLog = cordova.plugins.AppLog; // 示例:设置自定义的公共属性,属性名为key_public,属性值为value_public AppLog.setHeaderInfo({ "key_public": "value_public" }, () => { console.log('设置公共属性成功'); }, (err) => { console.log('设置公共属性失败:' + err.message); });
请注意 deviceid 是火山生成的 id,不是原始设备id,此功能Android暂不支持。
const AppLog = cordova.plugins.AppLog; // 示例:获取did AppLog.getDeviceID((did) => { console.log('获取did成功:' + did); }, (err) => { console.log('获取did失败:' + err.message); });