摘要:常常会遇到这种情况,线上发现一个严重可能是某一个地方也可能是一个功能无法使用,这时能做的只有赶紧修复然后提交等待漫长的审核。
IOS App常常会遇到这种情况,线上发现一个严重bug,可能是某一个地方Crash,也可能是一个功能无法使用,这时能做的只有赶紧修复Bug然后提交app store等待漫长的审核。
即使申请加急审核但是审核速度仍然不会快到那里去,即使审核完了之后,还要盼望着用户快点升级,用户不升级同样的漏洞一直存在,这种情况让开发者付出了很大的成本才能完成对于Bug的修复,有可能还需要出现强制升级的情况。
这样情况现在有办法改善,JSPatch就是为了解决这样的问题而出现的,只需要在项目中引入极小的一个JSPatch引擎,就可以使用JavaScript语言调用Objective-C的原生API,动态更新App,修复BUG。
JSPatch是一个开源的项目,项目网站:http://jspatch.com/,Github地址: https://github.com/bang590/JSPatch
在JSPatch的官网上面给出了一个例子:
@implementation JPTableViewController ... - (void)tableView:(UITableView *)tableView didSelectRowAtIndexPath:(NSIndexPath *)indexPath { NSString *content = self.dataSource[[indexPath row]]; //可能会超出数组范围导致crash JPViewController *ctrl = [[JPViewController alloc] initWithContent:content]; [self.navigationController pushViewController:ctrl]; } ... @end
这里会出现一个数组越界的Crash可以通过下发下面的JavaScript代码修复这个Bug:
//JS defineClass("JPTableViewController", { //instance method definitions tableView_didSelectRowAtIndexPath: function(tableView, indexPath) { var row = indexPath.row() if (self.dataSource().length > row) { //加上判断越界的逻辑 var content = self.dataArr()[row]; var ctrl = JPViewController.alloc().initWithContent(content); self.navigationController().pushViewController(ctrl); } } }, {})
JSPtch需要一个后台服务用来下发和管理脚本,并需要处理传输安全等JSPatch平台提供了对应的服务。
注册获取AppKey在JSPatch平台上面注册一个账户,新建一个App就可以拿到对应的AppKey。
导入SDK到项目中SDK地址:http://jspatch.com/Index/sdk
当前下载下的SDK版本名称是:JSPatch 2.framework,需要去掉中间的空格,不然导入项目的时候会报错。
导入项目的时候要选择Copy items if needed。
还需要添加对于的依赖框架JavaScriptCore.framework和libz.tbd.
在AppDelegate.m中添加代码:
#import "AppDelegate.h" #import在平台中上传JavaScript修复文件@implementation AppDelegate - (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions { [JSPatch startWithAppKey:@"f78378d77e5783e8"]; [JSPatch sync]; return YES; } @end
为了简单我们只上传一个简单的UIAlertView,弹出一个提示框:
ar alertView = require("UIAlertView").alloc().init(); alertView.setTitle("Alert"); alertView.setMessage("AlertView from js"); alertView.addButtonWithTitle("OK"); alertView.show();
这段代码用JavaScript实例化了UIAlertView,文件名需要命名为main.js。
从服务器下发到客户端把main.js上传到服务器上,下发到版本为1.0的客户端上面。
在请求服务加载脚本的时候出现了一个错误:The resource could not be loaded because the App Transport Security policy requires the use of a secure connection.
这个错误出现的原因是ios9引入了新特性App Transport Security(ATS),简单来说就是App内部的请求必须使用HTTPS协议。
很明显这里的url并没有使用https,我们可以通过设置先规避掉这个问题:
1. 在info.plist中添加NSAppTransportSecurity类型为Dictionary. 2. 在NSAppTransportSecurity中添加NSAllowsArbitraryLoads类型为Boolean,值为YES
运行效果如下:
这样就可以直接修复掉线上bug了,不需要等待App Store的审核。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/16205.html
摘要:作为程序员,修复终究是绕不开的话题,本期移动开发精英俱乐部讨论的主题便是修复中的,即热修复。王威威对已发布进行修复。王伟我们会在本地测试好,通过验证后才正式发送修复脚本。海不是简单的性能问题,如果要同时修复两个线程的方法就悲剧了。 作为程序员,Bug 修复终究是绕不开的话题,本期移动开发精英俱乐部讨论的主题便是 Bug 修复中的 Hotfix,即热修复。接下来让我们跟随大牛的脚步来了解...
摘要:本期整理了滴滴打车团队动态化方案的作者动态化分享,以及空间微信微信读书美团点评技术团队的热修复热更新方案,还有一些其他的技术分享。微信文章传送门滴滴动态化方案的诞生与起航,同时,滴滴客户端架构团队考虑于年初开源。 动态化更新是 App 开发必然面对的问题。在 iOS 环境下,Apple 开发者们像是 带着手铐脚镣跳舞 ,相比之下 Android 开发者会轻松一点,有很多相关的开源框架帮...
摘要:本期整理了滴滴打车团队动态化方案的作者动态化分享,以及空间微信微信读书美团点评技术团队的热修复热更新方案,还有一些其他的技术分享。微信文章传送门滴滴动态化方案的诞生与起航,同时,滴滴客户端架构团队考虑于年初开源。 动态化更新是 App 开发必然面对的问题。在 iOS 环境下,Apple 开发者们像是 带着手铐脚镣跳舞 ,相比之下 Android 开发者会轻松一点,有很多相关的开源框架帮...
摘要:本文来自于腾讯开发者社区,非经作者同意,请勿转载,原文地址是一个交流移动开发技术,结交朋友,扩展人脉的社群,成员都是经过审核的移动开发工程师。每周都会举行嘉宾分享,话题讨论等活动。本期,我们邀请了腾讯开发工程师陈振焯,为大家分享成长之路。 本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/579ef... Dev Cl...
阅读 1231·2021-09-28 09:44
阅读 2291·2021-09-28 09:36
阅读 726·2021-09-08 09:35
阅读 1820·2019-08-29 13:50
阅读 674·2019-08-29 13:29
阅读 989·2019-08-29 13:15
阅读 1595·2019-08-29 13:00
阅读 2684·2019-08-26 16:16