【android系统】基于github上tinker-manager的腾讯Tinker 热修复初体验----客户端实现

本文主要是介绍【android系统】基于github上tinker-manager的腾讯Tinker 热修复初体验----客户端实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最近搞了一个下午应用升级的问题,突然想起热修复这个新技术还没有尝试过。就抱着要尝试下新技术的心态,来试了试腾讯Tinker 热修复。

Tinker是什么

Tinker是微信官方的Android热补丁解决方案,它支持动态下发代码、So库以及资源,让应用能够在不需要重新安装的情况下实现更新。当然,你也可以使用Tinker来更新你的插件。

它主要包括以下几个部分:

  1. gradle编译插件: tinker-patch-gradle-plugin
  2. 核心sdk库: tinker-android-lib
  3. 非gradle编译用户的命令行版本: tinker-patch-cli.jar

Tinker的github地址:https://github.com/Tencent/tinker

各家热修复对比

当前市面的热补丁方案有很多,其中比较出名的有阿里的AndFix、美团的Robust以及QZone的超级补丁方案。下面来看看他们各自的优缺。

集成patchsdk

正好看到github上有实现好了的tinker,并且一整套从后台到客户端的解决方案。本着不浪费时间精力的情况的下,我们对比选择了github中tinker-manager的解决方案。

1、下载

github下载地址:https://github.com/baidao/tinker-manager

2、目录说明

  • assets 资源文件夹
  • patchsdk 客户端接入的sdk
  • patchserver 后台代码

直接下载后的tinker-manager直接编译会缺少文件,可以在下面网址下载到缺失的文件。

飞机票:http://www.bvbcode.com/cn/36t8vp19

3、搭建补丁后台管理系统

这部分参考另一篇文章:

4、修改ApplicationLike对接后台管理系统

修改这个文件中的appId和appSecret,与后台管理系统中的对应上。还有服务器地址(http://xxx.xxx.xxx.xxx:xxxx/hotfix-apis/)也要对应上。

生成补丁包,并测试

1、编译调试说明

1.生成基准(oldApk)签名包。2.是用来生成补丁文件的。

编译完成后生成文件。

2、生成基础包和补丁包

1、执行./gradlew assembleRelease 生成apk

生成基础包位置

2、修改TinkerDemo中的若干代码。./gradlew tinkerPatchRelease 生成patch补丁apk(需要保证补丁包tinkerId跟基线版本tinkerId一致)

修改text,添加了tangtang。

修改工程中的gradle.properties文件,将基础包设置成补丁包基准,然后生成补丁包

生成基础包位置

3、热修复测试方式

1、如果搭建了补丁管理后台的话,使用后台上传补丁包,进行修复,根据log,可以观察到结果

2、如果没有搭建补丁管理后台的话,使用adb push app/build/outputs/tinkerPatch/release/patch_signed_7zip.apk /data/local/tmp/

3、无补丁管理后台测试

1、添加接口

    /*** 加载Tinker补丁** @param context*/public void Fix(Context context) {File patchFile = new File("/data/local/tmp/", "patch_signed.apk");if (patchFile.exists()) {//SampleTinkerManager. .addPatch(patchFile.getAbsolutePath());TinkerInstaller.onReceiveUpgradePatch(context, patchFile.getAbsolutePath());Toast.makeText(context, "File Exists,Please wait a moment ", Toast.LENGTH_SHORT).show();} else {Toast.makeText(context, "File No Exists", Toast.LENGTH_SHORT).show();}}

2、分别生成基础包和补丁包

按上面的方法分别生成基础包和补丁包。

3、安装基础包,运行

通过adb install 命令安装补丁包

通过命令monkey运行sample应用

4、将补丁包拷贝到指定位置

通过adb push命令上传到/data/local/tmp/位置

5、重启应用,这时就完成了热修复

4、补丁管理后台测试

1、分别生成基础包和补丁包

2、安装基础包,运行

3、将补丁包上传到补丁管理后台

这个版本要与后台管理的上传的版本号对应上

4、重启应用,这时就完成了热修复

结束语

以上就是关于腾讯Tinker 热修复初体验,希望对你有用。欢迎大家关注我们微信公众号,来交流程序员的技术。如果能留言或者点个赞,我也是很开心的,非常感谢!

å¨è¿éæå¥å¾çæè¿°

参考:https://www.jianshu.com/p/194c9d89b227

 

这篇关于【android系统】基于github上tinker-manager的腾讯Tinker 热修复初体验----客户端实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo

Java实现远程执行Shell指令

《Java实现远程执行Shell指令》文章介绍使用JSch在SpringBoot项目中实现远程Shell操作,涵盖环境配置、依赖引入及工具类编写,详解分号和双与号执行多指令的区别... 目录软硬件环境说明编写执行Shell指令的工具类总结jsch(Java Secure Channel)是SSH2的一个纯J

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方

深度解析Python中递归下降解析器的原理与实现

《深度解析Python中递归下降解析器的原理与实现》在编译器设计、配置文件处理和数据转换领域,递归下降解析器是最常用且最直观的解析技术,本文将详细介绍递归下降解析器的原理与实现,感兴趣的小伙伴可以跟随... 目录引言:解析器的核心价值一、递归下降解析器基础1.1 核心概念解析1.2 基本架构二、简单算术表达

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

MySQL中On duplicate key update的实现示例

《MySQL中Onduplicatekeyupdate的实现示例》ONDUPLICATEKEYUPDATE是一种MySQL的语法,它在插入新数据时,如果遇到唯一键冲突,则会执行更新操作,而不是抛... 目录1/ ON DUPLICATE KEY UPDATE的简介2/ ON DUPLICATE KEY UP

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

JWT + 拦截器实现无状态登录系统

《JWT+拦截器实现无状态登录系统》JWT(JSONWebToken)提供了一种无状态的解决方案:用户登录后,服务器返回一个Token,后续请求携带该Token即可完成身份验证,无需服务器存储会话... 目录✅ 引言 一、JWT 是什么? 二、技术选型 三、项目结构 四、核心代码实现4.1 添加依赖(pom

修复已被利用的高危漏洞! macOS Sequoia 15.6.1发布

《修复已被利用的高危漏洞!macOSSequoia15.6.1发布》苹果公司于今日发布了macOSSequoia15.6.1更新,这是去年9月推出的macOSSequoia操作... MACOS Sequoia 15.6.1 正式发布!此次更新修复了一个已被黑客利用的严重安全漏洞,并解决了部分中文用户反馈的