Python 为UnityAndroid端自动化接入Tradplus广告SDK

Python 为UnityAndroid端自动化接入Tradplus广告SDK

  • Tradplus介绍
    • 常规接入
      • 进入Android开发文档
      • 选择渠道配置
      • 生成接入代码
      • 人工依赖
      • 下载官网同版本的 Unity插件
    • 使用自动化工具接入
      • 首次 你需要打两个标记来定位
      • 运行工具 控制台会列出最新的十个Tradplus版本 任选其一
      • 然后拖入项目路径后回车开始植入最新版
      • 植入完成后 控制台会输出 end. 这时候工具运行目录下 会自动下载好指定Tradplus版本的Unity插件
      • 其它声明
        • 渠道配置
        • ADMOB BIDDING自定义配置
    • 源码

Tradplus介绍

在这里插入图片描述

常规接入

进入Android开发文档

技术文档: https://docs.tradplusad.com/docs/tradplussdk_android_doc_v6/download

选择渠道配置

在这里插入图片描述

生成接入代码

在这里插入图片描述

人工依赖

容易出错 新人入手也比较麻烦
在这里插入图片描述

下载官网同版本的 Unity插件

在这里插入图片描述

使用自动化工具接入

首次 你需要打两个标记来定位

在Traplus接入开头处 加上

    /// TradPlus Start //

在这里插入图片描述
在Tradplus接入结尾处 加上

    /// TradPlus End //

在这里插入图片描述

运行工具 控制台会列出最新的十个Tradplus版本 任选其一

在这里插入图片描述

然后拖入项目路径后回车开始植入最新版

在这里插入图片描述
在这里插入图片描述

植入完成后 控制台会输出 end. 这时候工具运行目录下 会自动下载好指定Tradplus版本的Unity插件

在这里插入图片描述

其它声明

渠道配置

修改配置文件 ads 需要接入的广告渠道配置
仅需要在第一次和每次运营更换广告渠道的时候 配置一次
在这里插入图片描述

ADMOB BIDDING自定义配置

一般情况下这个版本号是Tradplus官方的人来告诉你这是哪个版本号 改一次就好了
在这里插入图片描述

源码


主运行脚本

#默认服务端口

import requests 
import time
import implant
import downloadUnityPlugins

api = 'https://www.geek7.top:8000/api'
adsChannel = ['UnityAds']
region = '2' # 1: 中国  2: 其它地区


adsChannel.clear()
sdkversionList = []
versionstr = ""
def log( msg ):
    print( msg )

def InitChannel():
    adsChannel.clear()
    with open('./bin/ads','r') as fp:
        for line in fp.readlines():
            adsChannel.append(line.replace('\n',''))

def Run( sdk_version = "10.2.0.1",overrid = True ):
    global versionstr
    InitChannel()
    data = {
        'token' : time.time(),
        'pipe':'tradplussdk',
        'code':829,
        'adchannels':','.join(adsChannel),
        'version':sdk_version,
        'region' : region
    }
    res = requests.get(api,data) 
    j = res.json()
    if 'version' not in j:
        log('erro: not foud version property in result.data')
        return
    if 'data' not in j:
        log('erro: data not in depends')
        return
    appGradleCode = j['data']
    if None == appGradleCode:
        log('GetDependencies fail')
    else:
        print('input you "Assets\\Plugins\\Android" full path')
        print('example: D:\\Git\\2dtoilet\\2dtoilet-client\\Assets\\Plugins')
        print('Or you can try the Android folder to this window.')
        print('current tradplus version list:')
        v = j['version']
        versionstr = '|'.join(v.split(',')[0:10])
        print(versionstr)
        if not overrid:
            sdkversionList.clear()
            sdkversionList.extend(v.split(','))
            return
        srcpath = input('input proj:\n')
        realpath = srcpath.replace('\\','/')
        implant.Run(realpath,appGradleCode)
        u3dzip = j['u3dzip']
        print(f'download unity plugin: {u3dzip}')
        downloadUnityPlugins.dowanlodZip(u3dzip,'./tradplus_unity_plugin_zips')

if __name__ == "__main__":
    log('begin.')
    Run( "10.2.0.1", False )
    
    version = ""
    while True:
        version = input('input you tradplus version: ')
        print(f'pulling the current version dependency of Tradplus: {version}')
        if version in sdkversionList:
            break
        else:
            print(f'current version fail. :{version}')
            print(versionstr)
    Run( version )
    input('end.')


自动化植入mainTemplate.gradle脚本

import os


def Run( projpath, dependsContent ):
    print(f'project path: {projpath}')
    print(f'depend content: {dependsContent}')

    if not projpath.endswith('mainTemplate.gradle'):
       projpath = os.path.join(projpath,'mainTemplate.gradle')

    filterstr = ''
    dependlines = dependsContent.splitlines()
    tradplusContent = False
    admob = False
    admob_bidding = False

    admob_bidding_str = "22.1.0.0"
    with open('./bin/ADMOB BIDDING','r') as fp:
        lines = fp.readlines()
        if len(lines) > 0:
            admob_bidding_str = lines[0]
            print(f"ADMOB BIDDING : {admob_bidding_str}")

    for l in dependlines:
        if l.startswith('dependencies {'):
            tradplusContent = True
        elif l.startswith('android {'):
            filterstr = filterstr[0:-2]
            break
        elif tradplusContent:
            real = l.replace('\"','\'')
            if admob:
                admob = False
                si = real.find('\'')
                ei = real.find('\'',si+1)
                com = real[si:ei+1]
                _import = '''    implementation(%s) {
        exclude module: "play-services-measurement-sdk-api"
    }\n'''%(com)
                filterstr += _import
                admob_bidding = True
                continue
            if admob_bidding and '// ' in real:
                _import = '''    //ADMOB BIDDING
    implementation ('com.applovin.mediation:google-adapter:%s'){
        exclude module: "play-services-measurement-sdk-api"
    }\n'''%(admob_bidding_str)
                filterstr += _import
                admob_bidding = False
            if '// Admob' in real:
                admob = True

            filterstr += f'{real}\n'


    output = ''
    with open(projpath,'r',encoding='UTF-8') as fp:
        begin_write = False
        lines = fp.readlines()
        for line in  lines:
            if line.startswith('    /// TradPlus Start //'):
                output += '    /// TradPlus Start //\n'
                output += filterstr
                begin_write = True
            elif line.startswith('    /// TradPlus End //'):
                output += '    /// TradPlus End //\n'
                begin_write = False
            elif not begin_write:
                output += line

    if len(output) != 0 and output != '':
        print('Under implantation.')
        with open(projpath,'w',encoding='UTF-8') as fp:
            fp.write(output)
        print('Complete implantation.')
    else:
        print('got a little problem')


下载unity最新插件脚本

import requests
import zipfile
import tempfile
import os

def get_data( url ):
    response = requests.get(url)
    return url, response.content

def dowanlodZip( url , dest = "./zip"):
    url, data = get_data( url )  # data为byte字节
    _tmp_file = tempfile.TemporaryFile()  # 创建临时文件
    print(_tmp_file)
 
    _tmp_file.write(data)  # byte字节数据写入临时文件
    # _tmp_file.seek(0)
    
    print(f'extract to: {os.path.join(os.getcwd(),dest)}')
    zf = zipfile.ZipFile(_tmp_file, mode='r')
    for names in zf.namelist():
        f = zf.extract(names, dest)  # 解压到zip目录文件下
        print(f)
    zf.close()
    print('extract completed')

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/279074.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

数据结构与算法教程,数据结构C语言版教程!(第一部分、数据结构快速入门,数据结构基础详解)四

第一部分、数据结构快速入门,数据结构基础详解 数据结构基础,主要研究数据存储的方式。 本章作为数据结构的入门课程,主要让读者明白,数据结构到底是什么,常用的数据存储结构有哪些,数据结构和算法之间到底…

Mac Pycharm在Debug模式报编码(SyntaxError)错误

1. 错误信息: Traceback (most recent call last):File "/Library/Developer/CommandLineTools/Library/Frameworks/Python3.framework/Versions/3.9/lib/python3.9/tokenize.py", line 330, in find_cookieline_string line.decode(utf-8) UnicodeDeco…

TiDB故障处理之让人迷惑的Region is Unavailable

背景 最近某集群扩容了一批物理机,其中 TiKV 节点有6台机器12个实例,同时调整了 label 设置增加了一层机柜级容灾。因为前期做了比较充分的准备工作,到了变更窗口只等着执行scale-out就行,操作过程也很顺利,很快就把所…

Linux之定时任务调度

crond crond是Linux系统中的一个守护进程,主要用于周期性地执行某种任务或等待处理某些事件。而crondtab是配套的工作,用于定时任务的设置。 语法 crontab [选项]常用选项 入门案例 执行crontab -e命令输入任务到调度文件中 */1 * * * * ls -l /et…

burpsuite模块介绍之repeater

导语 repeater是一个用于手动操作和发送个别HTTP请求的简单工具,它可以帮助您分析应用程序的响应。您可以使用repeater从Burp Suite的任何位置发送内部请求,然后修改请求并发送。通过这种方式,您可以测试和调试应用程序,并对请求…

爬虫工作量由小到大的思维转变---<第三十五章 Scrapy 的scrapyd+Gerapy 部署爬虫项目>

前言: 项目框架没有问题大家布好了的话,接着我们就开始部署scrapy项目(没搭好架子的话,看我上文爬虫工作量由小到大的思维转变---<第三十四章 Scrapy 的部署scrapydGerapy>-CSDN博客) 正文: 1.创建主机: 首先gerapy的架子,就相当于部署服务器上的;所以…

Vue2 - v-model 简介

目录 1,原理1.1,作用于表单元素1.2,作用于自定义组件 2,编译结果展示2.2,表单元素2.1,自定义组件 1,原理 官网参考 v-model 是一个语法糖,最终会生成一个属性和一个事件。并且即可…

Android NDK打包armeabi平台架包

NDK打包armeabi 1.降低NDK版本和Cmake版本 sdk.dirE\:\\Android\\sdk //指定ndk版本,不指定默认使用最新的NDK ndk.dirE\:\\Android\\sdk\\ndk\\16.1.4479499修改builde.gradle(app) android{defaultConfig{...//配置 AS 工程的 C/C 源文件编译参数externalNativ…

【算法与数据结构】435、LeetCode无重叠区间

文章目录 一、题目二、解法三、完整代码 所有的LeetCode题解索引,可以看这篇文章——【算法和数据结构】LeetCode题解。 一、题目 二、解法 思路分析:思路和【算法与数据结构】452、LeetCode用最少数量的箭引爆气球类似,也是排序找重叠区间。…

利用Pandas进行高效网络数据获取

利用Pandas进行高效网络数据获取 背景: ​ 最近看到一篇关于使用Pandas模块进行爬虫的文章,觉得很有趣,这里为大家详细说明。 基础铺垫: ​ pd.read_html pandas 库中的一个函数,用于从 HTML 页面中读取表格数据并…

MacBook查看本机IP

嘚吧嘚 其实这也不是什么困难的问题,但是今年刚刚入坑Mac,外加用的频率不是很高,每次使用的时候都查,用完就忘,下次用的时候再查🤮。真的把自己恶心坏了🙈。 所以写篇文章记录一下&#x1f92…

Java学习——设计模式——结构型模式1

文章目录 结构型模式代理模式适配器模式 结构型模式 结构型模式主要涉及如何组合各种对象以便获得更好、更灵活的结构。虽然面向对象的继承机制提供了最基本的子类扩展父类的功能,但结构型模式不仅仅简单地使用继承,而更多地通过组合与运行期的动态组合来…

uniapp多级动态表单规则

最近有个新的业务、主要涉及多层级的动态表单提交,其中又涉及很多类型,踩了很多坑之后,终于研发完毕。 传来的数据格式处理 传来的数据格式涉及比较多的内容,以下举例一个,涉及到规则的填写 规则写法有两种&#xff…

[足式机器人]Part4 南科大高等机器人控制课 CH12 Robotic Motion Control

本文仅供学习使用 本文参考: B站:CLEAR_LAB 笔者带更新-运动学 课程主讲教师: Prof. Wei Zhang 课程链接 : https://www.wzhanglab.site/teaching/mee-5114-advanced-control-for-robotics/ 南科大高等机器人控制课 Ch12 Robotic …

Android MVC 写法

前言 Model:负责数据逻辑 View:负责视图逻辑 Controller:负责业务逻辑 持有关系: 1、View 持有 Controller 2、Controller 持有 Model 3、Model 持有 View 辅助工具:ViewBinding 执行流程:View >…

【Python排序算法系列】—— 选择排序

​ 🌈个人主页: Aileen_0v0 🔥热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法 💫个人格言:"没有罗马,那就自己创造罗马~" 目录 选择排序 过程演示: 选择排序实现代码: 分析选择排序&#xff1a…

Word 将页面方向更改为横向或纵向

文章目录 更改整个文档的方向更改部分页面的方向方法1:方法2: 参考链接 更改整个文档的方向 选择“布局”>“方向”,选择“纵向”或“横向”。 更改部分页面的方向 需要达到下图结果: 方法1: 选:中你要在横向页面…

6130 树的最长路

思路:树的最长路问题可以通过两次 DFS 求解,具体思路如下: 1.第一次 DFS 求树的直径 以任意一个点为起点进行深度优先遍历(DFS),找到与该点距离最远的点 u 。 以 u 为起点进行 DFS ,找到与 u 距…

计算机网络复习5

传输层——端到端 文章目录 传输层——端到端功能传输层的寻址与端口UDPTCPTCP连接管理TCP可靠传输TCP流量控制TCP拥塞控制网络拥塞的处理 功能 从通信和信息处理的角度看,传输层向它上面的应用层提供通信服务,它属于面向通信部分的最高层,同…

nodejs+vue+ElementUi农产品团购销售系统zto2c

目标是为了完成小区团购平台的设计和实现,在疫情当下的环境,方便小区业主购入生活所需,减小居民的生活压力 采用B/S模式架构系统,开发简单,只需要连接网络即可登录本系统,不需要安装任何客户端。开发工具采…