今日头条(OCPC)广告激活数据对接-JAVA版

2023-11-03 16:40

本文主要是介绍今日头条(OCPC)广告激活数据对接-JAVA版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近在今日头条投广告,头条反馈可以按照实际激活数据的转换来付费,也就是说,只有用户真的下载并打开应用了才收费,过程类似与早年间的GHOST系统预装软件

下面说下头条的整个逻辑:

头条处理逻辑

1、用户在头条点击广告页,广告页引领用户去下载,用户下载后打开应用,头条吧这个用户的设备信息以及一些广告信息和回掉信息推送给监测服务器
2、应用将设备的唯一信息传递给监测服务器
3、监测服务器,视时机,将客户端传递的设备信息和头条传递近7天的设备信息进行匹配
4、匹配成功后调用接口回传给今日头条,那么这就完成了一次成功的转换,头条就开始扣你钱了

监测服务器处理逻辑

1、需要开发一个GET请求的接口用来接收头条的推送数据,最好分两个接口(IOS,android)
下面是源码:
// IOS获取头条推送数据@RequestMapping(value = "/ttpushIos", method = RequestMethod.GET)@ResponseBodypublic String ttpushIos(String adid, String cid, String idfa, String mac, String os,String timestamp, String convert_id, String callback) {TouTiao touTiao =new TouTiao(adid, cid, idfa, mac, os, timestamp, convert_id, callback, "", "0", "");logger.info("今日头条回馈IOS数据" + touTiao.toString());touTiaoService.insertSelective(touTiao);//持久化return "success";}

iOS和安卓的接口信息字段不一样,也可能会变,参照最新的头条文档就行,总之需要吧数据存储到本地

2、接受客户端传递的设备信息,这个就是普通的接口,自己写下就行,这里不贴代码了

3、接受到头条和客户端的设备信息后,监测服务器需要比对,并将信息反馈给头条

具体处理代码就不贴了,下面贴下签名和加密部分

// 使用 HMAC-SHA1 签名方法对对url进行签名String sig = "";try {sig = new HmacSHA1Util().HmacSHA1Encrypt(url, key);} catch (Exception e) {logger.info("HMAC-SHA1 签名方法对对url进行签名失败");e.printStackTrace();}

下面是工具类的源码:
public class HmacSHA1Util {private static final String MAC_NAME = "HmacSHA1";private static final String ENCODING = "UTF-8";/*** 使用 HMAC-SHA1 签名方法对对encryptText进行签名* * @param encryptText 被签名的字符串* @param encryptKey 密钥* @return 返回被加密后的字符串* @throws Exception*/public static String HmacSHA1Encrypt(String encryptText, String encryptKey) throws Exception {byte[] data = encryptKey.getBytes(ENCODING);// 根据给定的字节数组构造一个密钥,第二参数指定一个密钥算法的名称SecretKey secretKey = new SecretKeySpec(data, MAC_NAME);// 生成一个指定 Mac 算法 的 Mac 对象Mac mac = Mac.getInstance(MAC_NAME);// 用给定密钥初始化 Mac 对象mac.init(secretKey);byte[] text = encryptText.getBytes(ENCODING);// 完成 Mac 操作byte[] digest = mac.doFinal(text);StringBuilder sBuilder = bytesToHexString(digest);return sBuilder.toString();}/*** 转换成Hex* * @param bytesArray*/public static StringBuilder bytesToHexString(byte[] bytesArray) {if (bytesArray == null) {return null;}StringBuilder sBuilder = new StringBuilder();for (byte b : bytesArray) {String hv = String.format("%02x", b);sBuilder.append(hv);}return sBuilder;}/*** 使用 HMAC-SHA1 签名方法对对encryptText进行签名* * @param encryptData 被签名的字符串* @param encryptKey 密钥* @return 返回被加密后的字符串* @throws Exception*/public static String hmacSHA1Encrypt(byte[] encryptData, String encryptKey) throws Exception {byte[] data = encryptKey.getBytes(ENCODING);// 根据给定的字节数组构造一个密钥,第二参数指定一个密钥算法的名称SecretKey secretKey = new SecretKeySpec(data, MAC_NAME);// 生成一个指定 Mac 算法 的 Mac 对象Mac mac = Mac.getInstance(MAC_NAME);// 用给定密钥初始化 Mac 对象mac.init(secretKey);// 完成 Mac 操作byte[] digest = mac.doFinal(encryptData);StringBuilder sBuilder = bytesToHexString(digest);return sBuilder.toString();}
}

base64加密

 // 对其进行base64加密sig = new Base64Util().getBase64(sig);url = url + "&signature=" + sig;
工具类源码:
public class Base64Util {// 加密public static String getBase64(String str) {byte[] b = null;String s = null;try {b = str.getBytes("utf-8");} catch (UnsupportedEncodingException e) {e.printStackTrace();}if (b != null) {s = Base64.encodeBytes(b);}return s;}// 解密public static String getFromBase64(String s) {byte[] b = null;String result = null;if (s != null) {try {b = Base64.decode(s);result = new String(b, "utf-8");} catch (Exception e) {e.printStackTrace();}}return result;}public static void main(String[] args) {String string1 = "你好nnnn!";System.out.println(getBase64(string1));System.out.println(getFromBase64(getBase64(string1)));}
}

广告主配置:

以上都准备号了之后,下面进入头条网站,新建转化,下面说下这几个东西都怎么填写



需要用户填写的就是1、2、5项
对于第5项

填写过程中,一定要仔细比对,一旦提交不能更改,只能再次新建
其余的就可以参照头条的API文档进行编写了




这篇关于今日头条(OCPC)广告激活数据对接-JAVA版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/339507

相关文章

java如何解压zip压缩包

《java如何解压zip压缩包》:本文主要介绍java如何解压zip压缩包问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java解压zip压缩包实例代码结果如下总结java解压zip压缩包坐在旁边的小伙伴问我怎么用 java 将服务器上的压缩文件解压出来,

SpringBoot中SM2公钥加密、私钥解密的实现示例详解

《SpringBoot中SM2公钥加密、私钥解密的实现示例详解》本文介绍了如何在SpringBoot项目中实现SM2公钥加密和私钥解密的功能,通过使用Hutool库和BouncyCastle依赖,简化... 目录一、前言1、加密信息(示例)2、加密结果(示例)二、实现代码1、yml文件配置2、创建SM2工具

Spring WebFlux 与 WebClient 使用指南及最佳实践

《SpringWebFlux与WebClient使用指南及最佳实践》WebClient是SpringWebFlux模块提供的非阻塞、响应式HTTP客户端,基于ProjectReactor实现,... 目录Spring WebFlux 与 WebClient 使用指南1. WebClient 概述2. 核心依

Spring Boot @RestControllerAdvice全局异常处理最佳实践

《SpringBoot@RestControllerAdvice全局异常处理最佳实践》本文详解SpringBoot中通过@RestControllerAdvice实现全局异常处理,强调代码复用、统... 目录前言一、为什么要使用全局异常处理?二、核心注解解析1. @RestControllerAdvice2

Spring IoC 容器的使用详解(最新整理)

《SpringIoC容器的使用详解(最新整理)》文章介绍了Spring框架中的应用分层思想与IoC容器原理,通过分层解耦业务逻辑、数据访问等模块,IoC容器利用@Component注解管理Bean... 目录1. 应用分层2. IoC 的介绍3. IoC 容器的使用3.1. bean 的存储3.2. 方法注

MySQL 删除数据详解(最新整理)

《MySQL删除数据详解(最新整理)》:本文主要介绍MySQL删除数据的相关知识,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、前言二、mysql 中的三种删除方式1.DELETE语句✅ 基本语法: 示例:2.TRUNCATE语句✅ 基本语

Spring事务传播机制最佳实践

《Spring事务传播机制最佳实践》Spring的事务传播机制为我们提供了优雅的解决方案,本文将带您深入理解这一机制,掌握不同场景下的最佳实践,感兴趣的朋友一起看看吧... 目录1. 什么是事务传播行为2. Spring支持的七种事务传播行为2.1 REQUIRED(默认)2.2 SUPPORTS2

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java进程异常故障定位及排查过程

《Java进程异常故障定位及排查过程》:本文主要介绍Java进程异常故障定位及排查过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、故障发现与初步判断1. 监控系统告警2. 日志初步分析二、核心排查工具与步骤1. 进程状态检查2. CPU 飙升问题3. 内存

java中新生代和老生代的关系说明

《java中新生代和老生代的关系说明》:本文主要介绍java中新生代和老生代的关系说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、内存区域划分新生代老年代二、对象生命周期与晋升流程三、新生代与老年代的协作机制1. 跨代引用处理2. 动态年龄判定3. 空间分