iOS图片瘦身总结

前言

最近在公司写了个小程序来为iOS应用中的图片瘦身,进而减小APP大小,减少用户下载时的流量。

瘦身是在一个专门为图片瘦身的网站进行的。

地址:https://tinypng.com

这个网站提供的接口是基于https协议的,之前没有怎么用过https协议,现在一并总结一下。

关于HTTPS

https协议基础请参考参考:

HTTPS的七个误解

其实HTTPS就是安全版本的http协议,

他采用了RSA非对称加密公私钥对,使用SSL证书验证保证了用户数据在传输时的安全行。

下面简单看一下http和https请求过程的异同

我们按个看下流程

1.客户端向服务端发送基于https的请求。

2.服务端创建公私钥对。

3.服务端把共钥绑定在证书上面返回给客户端。

4.客户端验证证书是否可靠(验证方式有两种,分别针对CA机构办法的证书和自己创建的证书:1.是向颁发证书的CA机构发送请求来验证。2.是在客户端保存一个证书副本,来对比两个证书,同时还会验证是否被中间人进行了攻击,验证方式就是用证书的pubkey去解证书的上密文,如果和证书上的明文一直就可以确定没有被攻击)。

5.客户端生成一个随机数并用公钥加密传递给服务器。

6.服务器用私钥解密得到随机数,根据随机数产生对称加密秘钥并用私钥对秘钥进行加密。

7.传递对称秘钥给客户端。

8.客户端用公钥解密得到对称加密秘钥。

以后的通信就会使用对称加密的秘钥来进行了,所以https其实也就第一次请求会比较慢,因为要生成通信对称秘钥,以后再进行通信就和http不会差很多了。

iOS对于HTTPS的支持

在说这点之前,先说说tinypng这个网站的接口。

注册新用户后会返回给你一串key,我们要针对这串key做https请求

该站采用的是HTTP Basic Auth认证方式(关于Basic Auth认证方式详情参看维基百科)。

所以我们做请求的时候就需要使用添加headerfield。

返回的时候会把我们上传图片处理后的下载路径传回来,比较奇葩的是,路径并不在响应体而是在响应头中的Location字段内...(难道图片就不需要保密了么...)。

下面说说iOS该怎么做,

iOS的NSURLConnection和NSURLSession的API都提供了很方便的API来支持https请求。

我在实际操作的时候使用的是NSURLConnection。

首先创建请求:

 1 NSURL *url = [NSURL URLWithString:REQUEST_URL];
 2
 3 NSMutableURLRequest *request = [[NSMutableURLRequest alloc] initWithURL:url];
 4
 5 NSString *basicAuthUsername = BASIC_AUTH_USERNAME;
 6 NSString *basicAuthPassword = BASIC_AUTH_PASSWORD;
 7 NSData *authorizationData = [[NSString stringWithFormat:@"%@:%@",basicAuthUsername,basicAuthPassword] dataUsingEncoding:NSASCIIStringEncoding];
 8 NSString *authorizationStr = [NSString stringWithFormat:@"Basic %@",[authorizationData base64EncodedStringWithOptions:0]];
 9 NSLog(@"%@",authorizationStr);
10 [request setHTTPMethod:@"POST"];
11 [request addValue:authorizationStr forHTTPHeaderField:@"Authorization"];
12 [request addValue:@"*/*" forHTTPHeaderField:@"Accept"];

URL在API中提供的有,只是协议我们写为HTTPS,然后进行Authorization头字段的拼接,实际上就是Basic base64(用户名:密码)。

Accept这里设置为了*/*,其实如果知道服务器返回类型可以直接指定application/json或者text/json之类的就行。

下面看看连接:

1 -(BOOL)connection:(NSURLConnection*)connection canAuthenticateAgainstProtectionSpace:(NSURLProtectionSpace*)protectionSpace
2 {
3     return[protectionSpace.authenticationMethod isEqualToString:NSURLAuthenticationMethodServerTrust];
4 }
5
6 -(void)connection:(NSURLConnection*)connection didReceiveAuthenticationChallenge:(NSURLAuthenticationChallenge*)challenge
7 {
8     [challenge.sender continueWithoutCredentialForAuthenticationChallenge:challenge];
9 }

我们需要实现NSURLConnectionDelegate,然后实现上面的两个方法。

第一个方法是判断需要响应哪一类的安全问题,

  NSString *NSURLAuthenticationMethodDefault;

  NSString*NSURLAuthenticationMethodHTTPBasic;

  NSString*NSURLAuthenticationMethodHTTPDigest;

  NSString*NSURLAuthenticationMethodHTMLForm;

  NSString*NSURLAuthenticationMethodNegotiate;

  NSString*NSURLAuthenticationMethodNTLM;

  NSString*NSURLAuthenticationMethodClientCertificate;

  NSString*NSURLAuthenticationMethodServerTrust;

可以响应的安全问题有很多,这里我们只响应HTTPS相关的就行,因此选择NSURLAuthenticationMethodServerTrust。

第二个方法是处理验证结果的,这里我这样写会直接忽略证书验证,这里我们可以处理证书的验证策略逻辑。

我们start connection后就会发现可以成功的调用接口了。

关于一些其他细节

写这个小玩意还是用到了一些没有接触过的东西的。

下面总结一下。

1.文件实例类NSFileHandle,这个类可以拿到文件实例,比如我们想去控制文件读写细节就需要用到这个类,这里使用是为了保存没有成功请求的图片名称。

2.connection的异步请求做的非常好了,使用多线程请求,具体的请求线程个数由系统来判断。

3.多线程读写文件使用dispatch_barrier_async方法避免资源竞争。

不足

1.写的时候是所有上传请求全部结束后才开始下载的,这样效率很低,可以修改为成功上传后就直接下载不用等待其他的文件上传,不过这样多线程处理会稍微麻烦一些。

时间: 2024-08-26 20:38:19

iOS图片瘦身总结的相关文章

Python在七牛云平台的应用(二)图片瘦身

(一)七牛云平台的图片瘦身功能简介:(引用自官网) 针对jpeg.png格式图片 瘦身后分辨率不变,格式不变. 肉眼画质不变. 图片体积大幅减少,节省 CDN 流量 官网给的图片压缩率很高,官网给的「葡萄」图片瘦身在不改变分辨率和格式的情况下压缩率为65.49%,我自己测试了一张小图在后文中会有,原来的大小在「22kb」压缩后为「18kb」,据一般情况来看,压缩率虽然没有官网给的那么夸张,但是也能基本达到80%左右,所以这个压缩率还是很不错的. (二)需求分析 我们可以设想几个场景 『1:当你在

iOS可执行文件瘦身方法

缩减iOS安装包大小是很多中大型APP都要做的事,一般首先会对资源文件下手,压缩图片/音频,去除不必要的资源.这些资源优化做完后,我们还可以尝试对可执行文件进行瘦身,项目越大,可执行文件占用的体积越大,又因为AppStore会对可执行文件加密,导致可执行文件的压缩率低,压缩后可执行文件占整个APP安装包的体积比例大约有80%~90%,还是挺值得优化的.下面介绍一下在研究可执行文件过程中发现的可以优化的点.研究的过程使用了linkmap,linkmap的介绍跟生成可以参考另一篇文章—iOS可执行文

iOS App 瘦身方案

缩减iOS安装包大小是很多中大型APP都要做的事,一般首先会对资源文件下手,压缩图片/音频,去除不必要的资源.这些资源优化做完后,我们还可以尝试对可执行文件进行瘦身,项目越大,可执行文件占用的体积越大,又因为AppStore会对可执行文件加密,导致可执行文件的压缩率低,压缩后可执行文件占整个APP安装包的体积比例大约有80%~90%,还是挺值得优化的.下面介绍一下在研究可执行文件过程中发现的可以优化的点.研究的过程使用了linkmap,linkmap的介绍跟生成可以参考另一篇文章—iOS可执行文

iOS控制器瘦身-面向超类编程

点击查看作者简书地址 今天写这篇文章的目的,是提供一种思路,来帮助大家解决控制器非常臃肿的问题,对控制器瘦身. 如果手边有项目,不妨打开工程看一下你的控制器代码有多少行,是不是非常多?再看一下tableView的代理方法cellForRow和heightForRow的代码是不是也是非常多?里面夹杂着switch和大量if esle的判断逻辑的代码.后期维护看着这些if else是不是特别烦躁?特别是自己在维护前人写的代码,并且还没有注释 一团糟,是不是有更想骂人的冲动?别怕,这里给您提供一种解决

Android APK瘦身大法——SVG图片瘦身

前两天和上家公司的上司无意聊了聊工作的事,也就顺便扯到了apk瘦身上.主要是通过SVG进行图片压缩来减少app的大小.下面我就详细介绍一下如何实现SVG的图片压缩. SVG的优点 SVG 可被非常多的工具读取和修改(比如记事本),由于使用xml格式定义,所以可以直接被当作文本文件打开,看里面的数据: SVG 与 JPEG 和 GIF 图像比起来,尺寸更小,且可压缩性更强,SVG 图就相当于保存了关键的数据点,比如要显示一个圆,需要知道圆心和半径,那么SVG 就只保存圆心坐标和半径数据,而平常我们

[转]基于clang插件的一种iOS包大小瘦身方案

转自:http://mp.weixin.qq.com/s?__biz=MzA3ODg4MDk0Ng==&mid=2651112856&idx=1&sn=b2c74c62a10b4c9a4e7538d1ad7eb739 iOS包瘦身,对于一般团队来说并不是优化的首要目标,但是对于一些安装包已经超限的团队来说非常关键.微信和阿里移动安全都分享过相关的内容,后者采用的是去除无用代码的思路,感兴趣的同学可以阅读: iOS瘦身之删除无用的mach-O文件 而本文则将这个思路发挥到了极致,欢迎

iOS App 瘦身法之图片

1.纯色图 颜色不同 用一张图 瘦身代码 - (UIImage *)imageColorDraw:(UIColor *)color { CGSize size = self.size; CGFloat scale = [OSConfigService sharedInstance].screenScale; CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB(); CGContextRef context = CGBitmapCont

Android APK瘦身全面总结——如何从32.6M到13.6M

前言 之前我简单介绍了关于svg图片瘦身的问题,在公司,瘦身这个问题是我提出来的,所以这锅我背了.公司项目是32.6M,我给自己的要求就是低于20M.上周花了一个星期瘦身,至于为什么花了一周,主要是svg适配问题我被搞蒙蔽了.然后发现还要改大量代码,想想也就算了,又换了另一种瘦身方法. 很多人是因为这标题而来的,怎么可能,32.6M的居然可以变成13.6M.下面容我慢慢道来. APK结构介绍 classes.dex classes.dex是Java源码编译后生成的java字节码文件.但由于And

清理iOS工程里无用的图片,可瘦身ipa

工程在经过多人后,往往会出现较多的垃圾,导致打包出来的ipa文件偏大,有时候我们会通过清理代码来给程序瘦身,而瘦身ipa效果明显的,主要通过清理程序里的无用图片. 推荐一个清理图片的应用 https://github.com/tinymind/LSUnusedResources 直接打开运行,点击Browse..选择工程目录,再点击Search 搜索出该搜索工具认为工程里没有用到的图片,当然那些没搜出来的就都是有使用的图片了,不用理会 注意:这里所说没有用到的图片不是真的没有用到,因为这个工具他