教你快速高效接入SDK——打包工具的实现(反编译资源动态整合打渠道包)

整套u8sdk的核心思想,就是让我们的SDK接入成本,能够控制在1,而不是N。啥意思呢?就是,我开发第一款游戏的时候,我接了这些SDK,当我开发第二款,第三款游戏的时候,这套SDK可以尽可能的复用,而不是每开发一款游戏,又从头去接各个渠道sdk。所有的游戏都能够使用同一套SDK接入框架,来快速完成SDK的接入工作。那么,在U8SDK里,我们怎么做到呢?请看我们总体的思路:

游戏A,游戏B,游戏C是三款不同的游戏,对于他们来说,他们只需要调用U8SDK抽象层提供的接口,就完成了所有SDK的接入工作。这个时间,也就是个把小时的时间吧。

但是,我们知道,各个渠道SDK针对不同的游戏,都有不同的APPID,APPKEY等配置信息。所以,我们需要将这些配置信息也放在配置文件中。打包的时候,不同的游戏根据不同的配置,通过打包工具得到各个SDK的渠道包。

那么,像UC,当乐这些SDK是怎么接入的呢?

其实很简单,每个SDK接入,都是单独建立一个工程,引入SDK抽象层的jar包,然后,实现SDK抽象层中的插件接口。然后接好之后,会将SDK需要的资源,classes.dex,以及libs等需要的资源和代码,放在打包工具对应的SDK配置目录中。比如,UC的SDK,会在打包工具config/uc目录下,放置接好之后的SDK资源和代码。

同时,我们还需要两个配置文件。一个是config.xml。我们用他来配置,该渠道的参数配置信息。比如APPID, APPKEY等。同时也配置下,需要将哪些目录拷贝到apk里面的哪些目录中。同时,各个SDK接入都需要在AndroidManifest.xml中配置一些activity,service,permission等。我们把这些信息,放在SDK_Manifest.xml中。然后打包的时候,将这个文件的信息合并到母包的AndroidManifest.xml中。

我们再来看打包工具。你可能会奇怪,打包工具是怎么将只接入了抽象层的游戏母包输出为各个SDK的渠道包。这里,我们就要来看看打包工具所做的工作:

1、打包工具的输入,就是需要打包的apk包,也叫母包。游戏里面引入sdk抽象层的jar包,调用抽象层的接口。完成接入,然后打成apk。

2、打包工具会首先用apktool -d 对母包进行反编译。反编译到该渠道对应的临时工作目录中

3、重命名包名。我们知道在AndroidManifet.xml中的package就是包名,为了防止后面我们重新生成R文件导致冲突,我们对每个渠道都设置一个后缀。比如UC,后缀叫.uc。当乐,后缀.dl 等等。如果渠道SDK有明确要求,使用他们提供的后缀,那就使用他们提供的后缀。如果没有,就自己设置一个。

4、拷贝SDK资源。将该渠道对应的SDK资源,从对应的SDK配置目录中,拷贝到反编译后的临时工作目录中。

1)拷贝SDK的assets目录,libs目录,res目录等

2)将classes.dex也反编译成smali格式,拷贝到反编译临时工作目录中

3)和SDK_Manifest.xml中的内容合并到游戏目录的AndroidManifest.xml中。

5、生成游戏中需要使用的配置。

1)对于之前SDK目录中config.xml中配置的APPID,APPKEY等信息,根据需要,对于需要添加到AndroidManifest.xml中的,我们就将他添加到AndroidManifest.xml中的meta-data中。对于其他参数,我们会在assets目录下生成一个develop_config.properties文件。

2)对于SDK目录下config.xml中配置的插件信息,我们会在assets目录下,生成一个plugin_info.xml文件。这样SDK抽象层会读取这个配置来实例化对应的插件。

6、重新生成R文件。部分渠道需要支持他们的闪屏画面。根据我们的闪屏解决方案(后面会专门来说),我们需要重新生成R文件,来索引我们的闪屏资源图片等信息。

7、重新打包,采用apktool -b重新将合并之后的资源和代码,进行打包

8、签名和优化。部分渠道要求使用他们提供的签名文件,所以,我们对签名文件也采用了配置。可以根据不同的渠道来配置不同的签名文件。

9、经过以上步骤,一个渠道包就生成了。

通过上面这个打包流程,我们已经知道单个渠道包是如何生成的了。那么,像第一张图片中所表示的那样,我们打包工具是同时打出各个不同渠道SDK的渠道包。我们是如何来实现的呢?请看下图:

每个游戏,都有一个全局配置,里面配置了当前需要打包的渠道。这样,打包工具首先会读取该配置,然后按照上面的打包流程,对各个渠道进行打包。最终在输出目录下生成各个渠道对应的渠道包。

至此,我相信你对U8SDK里的打包工具有了一个比较全面的了解。但是,这还不够完善。比如,我们可以将参数从配置中脱离出来,采用界面化的管理方法。这样,你就可以将这套工具给运营或者策划去使用,程序开发人员,就不再需要负责打包的工作了。

打包的效率和速度上,也可以继续不断地进行优化。删除不必要的文件操作,减少不必要的流程等。

打包工具的源码三天三夜都说不完,所以建议,大家对着源码来看,根据上面所说的,慢慢熟悉打包工具,最后能够彻底掌握他,随心所欲完善修改他。

本文作者:小黑

更多文章欢迎访问小黑的博客:http://www.uustory.com

时间: 2024-10-12 18:02:18

教你快速高效接入SDK——打包工具的实现(反编译资源动态整合打渠道包)的相关文章

教你快速高效接入SDK——渠道SDK的接入(就是实现抽象层的接口而已)

题记:很多做游戏开发的人,估计都或多或少地接过渠道SDK,什么UC,当乐,91,小米,360......据统计国内市场当前不下于100家渠道,还包括一些没有SDK的小渠道.每个渠道SDK接入的方法呢,多是大同小异.但是,正是这些小异,又让SDK的接入,产生了无穷无尽的变数.所以,接入SDK之前,如果你没有经验,或者没有被SDK坑过,那么当你看到这系列文章的时候,你很幸运,你可以避免这一切了.如果你之前被坑过,而且还在继续被坑着,那么现在,就是你解脱的时刻. 先将之前的每一篇做个索引,方便亲们查阅

教你快速高效接入SDK——SDK接入抽象层的设计

题记:很多做游戏开发的人,估计都或多或少地接过渠道SDK,什么UC,当乐,91,小米,360......据统计国内市场当前不下于100家渠道,还包括一些没有SDK的小渠道.每个渠道SDK接入的方法呢,多是大同小异.但是,正是这些小异,又让SDK的接入,产生了无穷无尽的变数.所以,接入SDK之前,如果你没有经验,或者没有被SDK坑过,那么当你看到这系列文章的时候,你很幸运,你可以避免这一切了.如果你之前被坑过,而且还在继续被坑着,那么现在,就是你解脱的时刻. 上一篇文章,我们总体地分析并设计了一套

教你快速高效接入SDK——游戏接入SDK(只接入抽象框架)

题记:很多做游戏开发的人,估计都或多或少地接过渠道SDK,什么UC,当乐,91,小米,360......据统计国内市场当前不下于100家渠道,还包括一些没有SDK的小渠道.每个渠道SDK接入的方法呢,多是大同小异.但是,正是这些小异,又让SDK的接入,产生了无穷无尽的变数.所以,接入SDK之前,如果你没有经验,或者没有被SDK坑过,那么当你看到这系列文章的时候,你很幸运,你可以避免这一切了.如果你之前被坑过,而且还在继续被坑着,那么现在,就是你解脱的时刻. 上一篇文章我们说了整个U8 SDK抽象

教你快速高效接入SDK——总体思路和架构

题记:很多做游戏开发的人,估计都或多或少地接过渠道SDK,什么UC,当乐,91,小米,360......据统计国内市场当前不下于100家渠道,还包括一些没有SDK的小渠道.每个渠道SDK接入的方法呢,多是大同小异.但是,正是这些小异,又让SDK的接入,产生了无穷无尽的变数.所以,接入SDK之前,如果你没有经验,或者没有被SDK坑过,那么当你看到这系列文章的时候,你很幸运,你可以避免这一切了.如果你之前被坑过,而且还在继续被坑着,那么现在,就是你解脱的时刻. 完成一个SDK的接入并没有多少技术含量

教你快速高效接入SDK——关于Application的适配和代理

我们知道,每个android应用程序中都有一个唯一的上下文Application对象,这个Application一般我们不需要去关心他,应用启动时,系统会自动创建一个默认的Application实例.但是,因为Application在整个应用中是唯一的,也就是说,他是一个单例.所以,有的应用就可能希望利用Application来完成一些工作. 好在,在android中,实现一个自定义的Application是很简单的.直接自定义一个类继承Application,然后在AndroidManifes

教你快速高效接入SDK——U8Server的初步分析

在U8SDK整套框架总体架构那篇文章,我们就给出了服务器端的解决方案,为此,我们加入了一个U8Server,来作为U8SDK整套框架的服务器端的统一用户认证中心和支付中心.那么,为了方便,我们这里再来引用一下登陆认证的流程图: 回顾下我们之前的分析,U8Server作为统一的登陆认证中心,针对的是多款游戏,那么每款游戏在接入SDK之前,就需要向U8Server申请一个AppID以及AppKey.这样,申请的过程,也就是在U8 Server中加入一条该游戏的数据记录.接下来,游戏需要配置每一个第三

教你快速高效接入SDK——服务器端支付回调的处理方式

今天着重把之前渠道服务器端SDK的时候,遇到的一个蛋疼的问题给解决了. 按照之前我们搭建U8Server的思路,U8Server是可以完美支持多款游戏的.包括登录认证和支付回调.登录认证,没啥好说的.统一的接口即可,和客户端的协议对应上.支付回调呢?各个渠道的支付回调逻辑,对于每款游戏来说都是一样的,然后每个游戏填写的登录回调地址,也都一样. U8Server采用J2EE成熟框架实现,各个游戏的各个渠道的参数,是配置在数据库中,通过后台管理工具来完成添加,修改,删掉等操作. 之前我们的流程,相信

教你快速高效接入SDK——统一sdk服务器的实现

U8Server是采用J2EE框架SSH2实现的.当然你也可以采用任何其他你熟悉的语言实现.上一篇文章中,我们从类的抽象中,大致梳理了一下U8Server所要完成的工作.大的方向上,U8Server需要实现统一的用户登录认证,和支付中心两大功能.更深入的细节,U8Server需要完成以下功能: 游戏管理:查询游戏,创建游戏(同时生成游戏的唯一appID,appKey等),编辑游戏,删除游戏等功能. 渠道商管理:查询渠道商,创建渠道商(设置该渠道商对应的登陆认证地址,支付回调地址等操作.),编辑渠

教你快速高效接入SDK——Unity统一接入渠道SDK(Unity篇)

上一篇,我们着重讲解了用Unity开发的手游,在接入U8SDK时,Android中的部分.接下来,这一篇,我们就来看看,在Unity工程中,我们需要怎么调用上一篇中我们提供的各种接口,以及怎么接收Android中的消息通知,比如登录成功,切换帐号成功等. 在写代码之前,我们先要做一个简单的配置,在Project面板中,按照Unity官方的要求,新建一个Plugins文件夹,在Plugins文件夹下,再建立一个Android文件夹.这里,将会放置所有Android工程相关的文件. 1.将上一篇中,