您现在的位置是:电脑教程 >>正文
实现安卓app自动更新功能实例方案
电脑教程93人已围观
简介一般的安卓应用都会提供自动更新的功能,让用户方便使用最新的版本,现在我们来讲讲如何实现安卓应用自动更新的功能实例方案,方便大家学习。 安卓应用实现自动更新比较简单,这里跟大家介绍下。1. ...
安卓应用实现自动更新比较简单,例方这里跟大家介绍下 。服务器租用实现
1. web接口
需要提供一个接口供客户端查询更新状态,安卓案并且在需要更新时 ,动更告知客户端新APK地址 。新功
接口参数如下 :
package 包名,例方因为有时候会出现同一个应用换包名打包的实现情况
version 版本号 ,即android清单文件里面的安卓案versionCode
channel 渠道号
os 操作系统 ,android/ios 。亿华云动更ios 这里仅作预留 。新功
之所以传入这些字段,例方是要在与服务器端的包匹配时 ,务必满足:
package, channel, os 相等 ,并且服务器端的version 大于 客户端传入的version
代码如下:
os = request.GET.get(os)
pkg_name = request.GET.get(package)
channel = request.GET.get(channel)
version = request.GET.get(version)
if not os or not pkg_name or not channel or not version:
return jsonify(**ret_dict)
pkg = Package.objects.filter(
os=os,
package=pkg_name,
channel=channel,
status__gt=config.PACKAGE_STATUS_NOT_UPDATE
).order_by(-version).first
if pkg and int(version) pkg.version:
ret_dict[pkg_status] = str(pkg.status)
ret_dict[pkg_url] = config.WEB_HOST + pkg.file.url
ret_dict[update_prompt] = pkg.info
return jsonify(**ret_dict)
2. 数据库设计
由于web端使用的源码下载是django ,所以可以很方便的给出运营同学可以操作的后台界面 ,如下:

注意红框内的元素 ,运营同学在上传时 ,是云计算不允许修改的,而是由程序自动解析APK文件得到后填入的 。
具体的解析方法,我们稍后给出。
而对应的香港云服务器models代码如下 :
class Package(models.Model):
file = models.FileField(u文件, upload_to=config.PACKAGE_UPLOAD_PATH)
package = models.CharField(u包名, max_length=255, blank=True, default=)
version = models.IntegerField(u"版本号", blank=True, default=0, null=True)
channel = models.CharField(u"渠道", max_length=128, blank=True, default=)
status = models.IntegerField(u更新状态, default=config.PACKAGE_STATUS_NOT_UPDATE,
choices=config.PACKAGE_UPDATE_STATUS)
info = models.TextField(u通知信息, blank=True, null=True)
os = models.CharField(u操作系统, max_length=64, default=config.PACKAGE_CLIENT_UNKNOW,
choices=config.PACKAGE_CLIENT_OS, blank=True, null=True)
def __unicode__(self):
_,name = os.path.split(self.file.name)
return name
class Meta:
unique_together = (package, version, channel, os)
def save(self, * args, ** kwargs):
# 文件上传成功后 ,文件名会加上PACKAGE_UPLOAD_PATH路径
path,_ = os.path.split(self.file.name)
if not path:
if self.file.name.endswith(.apk):
self.os = config.PACKAGE_CLIENT_ANDROID
path = os.path.join(/tmp, uuid.uuid4.hex + self.file.name)
# logger.error(path: %s, path)
with open(path, wb+) as destination:
for chunk in self.file.chunks:
destination.write(chunk)
info = parse_apk_info(path)
os.remove(path)
self.package = info.get(package, )
self.version = info.get(version, 0)
self.channel = info.get(channel, )
elif self.file.name.endswith(ipa):
self.os = config.PACKAGE_CLIENT_IOS
super(self.__class__, self).save(*args, ** kwargs)
def display_filename(self):
_,name = os.path.split(self.file.name)
return name
display_filename.short_description = u"文件"
3. APK文件解析
def parse_apk_info(apk_path, tmp_dir=/tmp):
"""
获取包名、版本、渠道:
{ version: 17, channel: CN_MAIN, package: ‘com.fff.xxx}
:param apk_path:
:return:
"""
from bs4 import BeautifulSoup
import os
import shutil
import uuid
abs_apk_path = os.path.abspath(apk_path)
dst_dir = os.path.join(tmp_dir, uuid.uuid4.hex)
jar_path = os.path.abspath(os.path.join(os.path.dirname(__file__), apktool.jar))
cmd = java -jar %s d %s %s % (jar_path, abs_apk_path, dst_dir)
if isinstance(cmd, unicode):
cmd = cmd.encode(utf8)
# 执行
os.system(cmd)
manifest_path = os.path.join(dst_dir, AndroidManifest.xml)
result = dict
with open(manifest_path, r) as f:
soup = BeautifulSoup(f.read)
result.update(
version=soup.manifest.attrs.get(android:versioncode),
package=soup.manifest.attrs.get(package),
)
channel_soup = soup.find(meta-data, attrs={ android:name: UMENG_CHANNEL})
if channel_soup:
result[channel] = channel_soup.attrs[android:value]
shutil.rmtree(dst_dir)
return result
当然 ,正如大家所看到的,我们需要依赖于 apktool.jar 这个文件 ,具体大家可以在网上下载。
高防服务器Tags:
转载:欢迎各位朋友分享到网络,但转载请说明文章出处“算法与编程”。http://www.bzli.cn/news/655d7799267.html
相关文章
恶意软件 Stealc “横空出世”,窃密能力一流
电脑教程Bleeping Computer 网站披露,暗网市场出现了一个名为 Stealc 的新恶意软件,由于大肆宣传窃取信息的能力,以及与 Vidar、Raccoon、Mars 和 Redline 等同类恶 ...
【电脑教程】
阅读更多你的车在监视你吗?汽车数据收集的惊人真相
电脑教程最近,消费者权益倡导者的调查揭示了一个令人担忧的趋势:许多汽车制造商不仅在跟踪驾驶者的行为,还将这些数据与第三方公司共享。这种广泛的数据收集引发了隐私方面的担忧,因为驾驶者可能并未充分意识到所收集的信 ...
【电脑教程】
阅读更多新供应链安全威胁,下载超四千万的 Python 库曝严重缺陷
电脑教程Ghsa-wm×h-p×cx-9w24漏洞概述近日,广泛使用的Python JSON Logger库中披露的一个漏洞通过依赖链缺陷,暴露了约4300万个安装面临潜在远程代码执行RCE)攻击的风险。该漏 ...
【电脑教程】
阅读更多
热门文章
最新文章
友情链接
- 小新15使用U盘装系统教程(轻松操作,系统安装无忧)
- 戴尔Precision 5770移动工作站 让设计师专注创作
- 戴尔Latitude 5530 业界首款使用生物基材料的PC
- 雨林木风装机教程(一步步教你如何选择雨林木风配件,组装一台性能出色的电脑)
- 利用最新大白菜U盘装系统教程,轻松完成系统安装(以大白菜U盘装系统为例,快速上手系统安装)
- 在 NVIDIA BlueField DPU 上运行 vSphere,构建现代化数据中心
- Z370Godlike(全球首款支持无线电竞的主板,带给您卓越的游戏体验)
- Kyndryl勤达睿获得思科全球金牌集成商认证
- 规划未来时要了解的数据中心统计数据
- 魅蓝2红米2电信版如何?(用一台手机满足所有需求,) 香港物理机b2b信息平台企业服务器网站建设云服务器源码库亿华云