Android渠道包自动发布市场,Android Gradle实现打包指定渠道后自动上传到fir

fir分三个主要步骤1.获取fir上传凭证

2.上传APK+APP logo图标

3.获取最新的下载地址供别人下载

注:python使用的是requests网络请求库

1.获取fir上传凭证

AAffA0nNPuCLAAAAAElFTkSuQmCC

image.png

代码如下:# 第一步:获取fir上传凭证

print("get fir upload certificate")

icondict = {}  # 后面上传图标和apk需要使用的参数,这里保存下来

binarydict = {}        try:

req = requests.post("http://api.fir.im/apps",

{'type': 'android', 'bundle_id': apppackage, 'api_token': apitoken})

resjson = req.json()

icondict = (resjson["cert"]["icon"])

binarydict = (resjson["cert"]["binary"])            print("get fir upload certificate success")

except Exception:            print("get fir upload certificate error")

traceback.print_exc()

2.上传APK+logo图标

AAffA0nNPuCLAAAAAElFTkSuQmCC

image.png

代码如下:# 第二步:上传APK

try:            print("uploading apk......")

apkfile = {'file': open(apkpath, 'rb')}

param = {"key": binarydict["key"],                     "token": binarydict["token"],                     "x:name": appname,                     "x:version": appversion,                     "x:build": appbuild,                     "x:changelog": apkchangelog}

req = requests.post(url=binarydict["upload_url"], files=apkfile, data=param, verify=False)

except Exception as e:            print("upload apk error")

traceback.print_exc()# 第三步:上传APK logo

try:

apklogofile = {'file': open(apklogo, 'rb')}

param = {"key": icondict["key"],                     "token": icondict["token"]}

req = requests.post(url=icondict["upload_url"], files=apklogofile, data=param, verify=False)

except Exception:            print("upload apk error")

traceback.print_exc()

3.获取最新的下载地址

AAffA0nNPuCLAAAAAElFTkSuQmCC

image.png

代码如下:# 第四步:获取APK最新下载地址

queryurl = 'http://api.fir.im/apps/latest/%s?api_token=%s&type=android' % (apppackage, apitoken)        try:

req = requests.get(queryurl)

update_url = (req.json()["update_url"])            print("upload apk success, update url is " + update_url)

except Exception:            print("upload apk error")

traceback.print_exc()

代码里面如下参数都是动态传入的,配合AndroidStudio自带的gradle使用

appname = sys.argv[1]  # app名称

apppackage = sys.argv[2]  # 唯一包名,也即是bundle_id

appversion = sys.argv[3]  # app版本号

appbuild = sys.argv[4]  # app build号

apitoken = sys.argv[5]  # fir token

apklogo = sys.argv[6]  # 等待上传的APK logo路径

apkpath = sys.argv[7]  # 等待上传的APK路径

apkchangelog = sys.argv[8]  # 等待上传的APK更新日志(可能没有填写)

完整代码# encoding = utf-8import sysimport tracebackimport requests

requests.packages.urllib3.disable_warnings()def uploadtofir():

# 参数检查

paramnum = 8

syslen = len(sys.argv)    if syslen 

print("please input param")        return

else:        # 基础参数

appname = sys.argv[1]  # app名称

apppackage = sys.argv[2]  # 唯一包名,也即是bundle_id

appversion = sys.argv[3]  # app版本号

appbuild = sys.argv[4]  # app build号

apitoken = sys.argv[5]  # fir token

apklogo = sys.argv[6]  # 等待上传的APK logo路径

apkpath = sys.argv[7]  # 等待上传的APK路径

apkchangelog = syslen == 9 and sys.argv[8] or ""  # 等待上传的APK更新日志(可能没有填写)

# 第一步:获取fir上传凭证

print("get fir upload certificate")

icondict = {}  # 后面上传图标和apk需要使用的参数,这里保存下来

binarydict = {}        try:

req = requests.post("http://api.fir.im/apps",

{'type': 'android', 'bundle_id': apppackage, 'api_token': apitoken})

resjson = req.json()

icondict = (resjson["cert"]["icon"])

binarydict = (resjson["cert"]["binary"])

print("get fir upload certificate success")        except Exception:

print("get fir upload certificate error")

traceback.print_exc()        # 第二步:上传APK

try:

print("uploading apk......")

apkfile = {'file': open(apkpath, 'rb')}

param = {"key": binarydict["key"],                     "token": binarydict["token"],                     "x:name": appname,                     "x:version": appversion,                     "x:build": appbuild,                     "x:changelog": apkchangelog}

req = requests.post(url=binarydict["upload_url"], files=apkfile, data=param, verify=False)        except Exception as e:

print("upload apk error")

traceback.print_exc()        # 第三步:上传APK logo

try:

apklogofile = {'file': open(apklogo, 'rb')}

param = {"key": icondict["key"],                     "token": icondict["token"]}

req = requests.post(url=icondict["upload_url"], files=apklogofile, data=param, verify=False)        except Exception:

print("upload apk error")

traceback.print_exc()        # 第四步:获取APK最新下载地址

queryurl = 'http://api.fir.im/apps/latest/%s?api_token=%s&type=android' % (apppackage, apitoken)        try:

req = requests.get(queryurl)

update_url = (req.json()["update_url"])

print("upload apk success, update url is " + update_url)        except Exception:

print("upload apk error")

traceback.print_exc()if __name__ == '__main__':

uploadtofir()

Android Gradle配置

将上面写好的.py文件复制到项目的app目录下(非project目录),同时在app级别下的gradle文件中添加如下代码(添加到android{}里面)//自定义一个任务,实现打包meisha渠道自动上传到fir

task assembleWithFir{

dependsOn 'assembleXXXXRelease'//打包自己需要的渠道

doLast{

def appname="你的APP名称"

def apppackage=project.android.defaultConfig.applicationId

def appversion=project.android.defaultConfig.versionName

def appbuild=project.android.defaultConfig.versionCode

def apitoken="你的fir ApiToken"

def apklogo="你的APK LOGO"

def apkpath="你的APK本地地址"

def apkchangelog=""

//调用python脚本  这个脚本需要放在app工程目录下,不要放在project目录下

def process="python UploadToFir.py ${appname} ${apppackage} ${appversion} ${appbuild} ${apitoken} ${apklogo} ${apkpath} ${apkchangelog}".execute()            //打印Python脚本日志,便于出错调试

ByteArrayOutputStream result = new ByteArrayOutputStream()

def inputStream = process.getInputStream()            byte[] buffer = new byte[1024]            int length            while ((length = inputStream.read(buffer)) != -1) {

result.write(buffer, 0, length)

}

println(result.toString("utf-8"))

}

}

至此全部搞定,同步一下gradle后发现多了一个assembleWithFir命令

AAffA0nNPuCLAAAAAElFTkSuQmCC

image.png

双击assembleWithFir开始打包刚才指定的渠道,之后自动上传APK到fir,如下点击该连接就能查看相关了

AAffA0nNPuCLAAAAAElFTkSuQmCC

image.png

注意事项:.py python文件要放在app级别的目录下(非project)

确保电脑已安装python运行环境,requests网络请求库

作者:CKTim

链接:https://www.jianshu.com/p/833cc4d0c0ae

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android studio vfs,Android Studio:尝试呈现XML布局的InvalidVirtualFileAccessException

我正在尝试在我的应用中预览xml布局(任何xml布局).我正在使用Android Studio 1.5 Preview 2.我一遍又一遍地收到此错误:InvalidVirtualFileAccessException:访问无效的虚拟文件:file:// D:/Scott/Android/Studio/MyApp/app/build/intermediates/classes/debug/com/scott/myapp/…

android 基类fragment,Android DialogFragment 基类的定制

鸿洋博客介绍:DialogFragment的基本使用好处:1:使用DialogFragment来管理对话框,当旋转屏幕和按下后退键时可以更好的管理其声明周期,它和Fragment有着基本一致的生命周期2.DialogFragment也允许开发者把Dialog作为内嵌…

升级鸿蒙系统无法选择应用,申请鸿蒙系统有一个应用选择怎么选择呢

[分享交流]申请鸿蒙系统有一个应用选择怎么选择呢34364电梯直达huafen774590890新学乍练发表于 2020-12-18 22:19:17来自:HUAWEI Mate 30 Pro 5G最新回复 2020-12-19 09:31:55要怎么选择大家知道吗?想着你的狼自成一派发表于 2020-12-18 22:22:29来自&am…

html5 网页游戏论文,JavaScript编写的网页小游戏,很给力

以下为游戏代码:var timerID null;var INT 40;var loadFLG 0;var gameFLG 0;var missFLG 0;var tim 0;var blcol new Array(5); // block colorvar blsta new Array(40); // block statusvar blNO new Array(40); // block Novar blclr 0; // clear block…

c 插件读取有属性的html6,廖雪峰的JS教程6-jQuery

jQueryjQuery是JavaScript世界中使用最广泛的一个库。jQuery这么流行,肯定是因为它解决了一些很重要的问题。实际上,jQuery能帮我们干这些事情:消除浏览器差异:你不需要自己写冗长的代码来针对不同的浏览器来绑定事件,…

html5中的css特性,浅谈HTML5 CSS3的新交互特性

本文标题的这副图片,是用phosotshop制作的。但是,在搜索引擎中你却无法搜索到它,搜索引擎还没有强大到能够识别图片里面的文字。并且由于图片的体积不算太小,可能网速慢的网友在浏览的时候不得不耐心的等待图片的刷新。那么&#…

html表格通过邮件发送,通过html表格发电子邮件

[email protected]>Create this tableThe field "what" is for different categoriesCREATE TABLE email_notify (ID int(11) DEFAULT ‘0‘ NOT NULL,What varchar(60) DEFAULT ‘0‘ NOT NULL,Name varchar(60) DEFAULT ‘0‘ NOT NULL,Email varchar(60) DEFAU…

计算机专业知识多选题证监会,2019年国家公务员考试中国证监会(计算机类)专业科目考试大纲...

2019年国家公务员考试中国证监会(计算机类)专业科目考试大纲由国家公务员考试网公告解读栏目由提供,更多关于2019国家公务员考试大纲,计算机类国考考试大纲,证监会国考考试大,国家公务员考试公告解读的内容,请关注国家公务员考试网/广东公务员考试网&…

计算机和网络老是断开,电脑插上网线还是显示断开连接怎么办

在网络故障处理中遇到过千奇百怪的问题,这里就说一个比较怪异的问题。一个网线插口,有的电脑插上网线可以正常上网,而有的电脑插上就显示断开连接。试了好多办法,换了网线,换了插口,换了路由器,…

计量经济学第六版计算机答案,伍德里奇计量经济学导论计算机习题第六章第13题c_6.13...

伍德里奇计量经济学导论计算机习题第六章第13题,答案和MATLAB代码clear,clc;% c6.13 by% 打开文字文件和数据文件importdata(meap00_01.des);dataxlsread(meap00_01);% 检验所用数据是否为非空Isnanisnan(data(:,[3,5,8,9]));asum(Isnan);bfind(a0);data1data(b,:);% 变量命名m…

思品课如何使用计算机教学课件,小学思品获奖论文巧用多媒体,优化思品课堂教学...

小学思品获奖论文巧用多媒体,优化思品课堂教学摘要:信息技术辅助课堂教学,有利于促进思想品德课教学内容呈现方式、教师教学方式、学生学习方式和师生互动方式的变革。利用信息技术能提高学生学习思想品德的兴趣;有利于培养学生的…

计算机网络的资源共享功能包,计算机网络的资源共享功能包括

资源共享是现代计算机网络的最主要的作用,它包括软件共享、硬件共享及数据共享。在网络中,多台计算机或同一计算机中的多个用户,同时使用硬件和软件资源。通常多用户同时需要的资源总是超过系统实际物理资源的数量,但采用逻辑(或虚…

《计算机应用基础》期末试卷.,《计算机应用基础》期末试卷(A卷)《计算机应用基础》期末试卷(A卷).doc...

广东外语艺术职业学院成人高等教育2012学年第 一 学期 三年 制2012级 初等教育专业计算机应用基础课程 期末 考试试题试卷类型:A 考试形式:闭卷本试题共 五 大题, 4 页,满分 100 分,考试时间为 120 分钟,答…

计算机学院嘉年华标题,“芯动盛夏 AI创南航” 计算机学院举办第八届计算机嘉年华...

当前,我们正迎来一个科技主导的全智能时代,为激发大家学习探索人工智能的兴趣,切身感受AI科技的魅力所在,计算机科学与技术学院/人工智能学院于6月20日在体育馆广场举办了“芯动盛夏 AI创南航”第八届计算机嘉年华活动。活动中&am…

计算机网络与通信02339,4月全国高等教育自学考试计算机网络与通信试题及答案解析.docx...

4月全国高等教育自学考试计算机网络与通信试题及答案解析.docx精品自学考试资料推荐全国 2018 年 4 月高等教育自学考试计算机网络与通信试题课程代码 02339一、单项选择题本大题共 15 小题,每小题1 分,共 15 分 在每小题列出的四个备选项中只有一个是符…

计算机考研百天,2015考研计算机专业复习百天周计划

计算机百天冲刺周计划学习目标篇百天计划第一周(9月26日—10月6日)1.完成数据结构中线性表的复习;并配以习题巩固练习。2.完成强化课程数据结构第一章的学习,重难点针对复习。3.完成数据结构中栈,队列和数组的复习; 并配以习题巩固练习。4.完成强化课程数…

爱尔兰都柏林圣三一大学计算机排名,2021年爱尔兰都柏林圣三一大学世界及专业排名 不愧是最古老的学府!...

它是参照牛津和剑桥大学模式兴建的欧索世界顶级研究型大学,其商学院也是欧洲培养企业家最多的商学院之一,这所名校就是爱尔兰都柏林圣三一大学,该校的科研实力雄厚,因此,每年都会吸引一大批的学子前往该校留学&#xf…

计算机系统的四种启动方式是,电脑启动方式有几种你知道吗?

关于电脑启动方式有几种,可能你会说,电脑启动不就是按电源按钮启动吗?实际上,电脑有三种启动方式,而且三种启动方式会对应不一样情况,虽然有些概念对现在的电脑略微有一点点落后,但是对于玩电脑…

安装杀毒软件是保障计算机安全,安装杀毒软件是保障计算机安全的唯一措施

摘要:脉搏8次/分,安装安全合的最适此时方式手术是,血压病人术时。软件综合征在最常见的青春前期表现临床是。障计糖病粘多目前据是确诊的依。...脉搏8次/分,安装安全合的最适此时方式手术是,血压病人术时。杀毒保算机施…

畅想未来计算机的绘画作品小学生,畅想未来儿童画绘画作品大全

畅想未来儿童画绘画作品大全导语:未来的科技在不断发展,未来的世界每天充满了新奇。下面是小编为您整理的儿童画,希望对您有所帮助。未来的世界是个先进的地方。我们的交通工具不再是飞机、轮船和汽车,而是宇宙飞船。家里的设备是…