跳到主要内容

标准化事件及应用归因签名

标准转化事件信息

定义值回传值含义说明
安装应用0应用安装完成 说明: 安装应用事件归因结果回传通过白名单方式向合作伙伴开放,默认不回传(白名单开放方式请联系华为运营)。
激活应用1历史首次激活应用
启动应用2打开应用
次日留存3次日仍然使用应用
付费4在应用内发生付费
提交表单5在应用内提交表单
授权6发生应用的授权
注册7注册应用或服务
关键页面访问9发生关键页面浏览行为
申请14申请服务
下单18将购物清单正式生成订单
预约21预约商品、内容或服务

归因来源签名计算规则

1.按照如下规则(字段顺序及分隔符)拼接待签名的字符串:

adTechId+ '\u2063' + campaignId+ '\u2063' + destinationId+ '\u2063' + serviceTag+ '\u2063' + mmpIdStr + '\u2063' + nonce + '\u2063' + timestamp

其中,mmpIdStr生成规则为:

若归因监测平台的数组不为空,则将归因监测平台中的元素以'\u2063'为连接符进行拼接,假设mmpIds中有两个归因监测平台,拼接示例:

mmpIdStr = mmpId1 + '\u2063' + mmpId2

2.使用分发平台在应用归因服务云侧注册角色时,提供的公钥所对应的私钥,对步骤1拼接的字符串进行签名计算(签名算法:SHA256withRSA/PSS;生成密钥位数:RSA3072)。

3.接口中字段不为空则参与签名/验签,否则不参与签名/验签。

生成签名方法

您可以参考如下代码生成签名,也可以自行生成签名。

import { hilog } from '@kit.PerformanceAnalysisKit';
import { BusinessError } from '@kit.BasicServicesKit';
// 具体引用方法参考本示例代码底部说明
import {AegRsaSign} from "@hw-agconnect/petal-aegis";


const TAG: string = 'SignUtil';
const SEPARATOR: string = '\u2063';

export class SignUtil {
public static genSignContent(adTechId: string, campaignId: string, destinationId: string, mmpIds: string[], serviceTag: string, nonce: string, timestamp: number) {
// mmpIdStr = mmpId1 + '\u2063' + mmpId2
// signContent:string= adTechId+ '\u2063' + campaignId+ '\u2063' + destinationId+ '\u2063' + serviceTag+ '\u2063' + mmpIdStr + '\u2063' + nonce + '\u2063' + timestamp
let content = SignUtil.addSeparator(adTechId)
+ SignUtil.addSeparator(campaignId)
+ SignUtil.addSeparator(destinationId)
+ SignUtil.addSeparator(serviceTag)
+ SignUtil.genMmpIds(mmpIds)
+ SignUtil.addSeparator(nonce)
+ timestamp;
hilog.info(0,TAG,`content = ${JSON.stringify(content)}`);
return content;
}

private static addSeparator(value: string | undefined): string {
return value ? value + SEPARATOR : '';
}

private static genMmpIds(mmpIds: string[]) {
let result: string = '';
for (let mmpId of mmpIds) {
if (mmpId) {
result += SignUtil.addSeparator(mmpId);
}
}
return result;
}

public static getSign(content: string, privateKey: string): Promise<string> {
return new Promise<string>((resolve) => {
AegRsaSign.ohAegSignRSAWithPSSTextBase64(content, privateKey).then(async (sign: string) => {
hilog.info(0, TAG, "getSign success.");
resolve(sign);
}).catch((error: BusinessError) => {
hilog.error(0, TAG, `getSign failed. code is ${error.code}, message is ${error.message}`);
});
})
}
}

其中import {AegRsaSign} from "@hw-agconnect/petal-aegis" , 使用AegRsaSign.ohAegSignRSAWithPSSTextBase64生成签名,使用方法如下:

执行安装命令:ohpm i @hw-agconnect/petal-aegis

具体的接口使用方法,请参见ohAegSignRSAWithPSSTextBase64