美文网首页iOS精选整理集合
iOS开发常用的加密技术

iOS开发常用的加密技术

作者: iOS开发之家 | 来源:发表于2019-03-04 16:22 被阅读5次

一些常用的加密介绍

在iOS开发中(应该说在所有的开发中),数据的安全性都是非常重要的。下面就简单的说一下数据加密的一些方式。

MD2 、MD3、 MD4 、MD5 (MD6) Message-Digest Algorithm(信息-摘要算法),现在主要是MD5,前面的由于存在缺陷就被淘汰啦,而MD6的话现在还处于测试阶段。 具体的算法的更深层次的介绍请移步Google。

SHA1 、SHA224 、SHA256 、SHA384 、SHA512 安全哈希算法 (安全散列算法)(Secure Hash Algorithm),散列是信息的提炼,通常其长度要比信息小得多,且为一个固定长度。加密性强的散列一定是不可逆的,这就意味着通过散列结果,无法推出任何部分的原始信息。任何输入信息的变化,哪怕仅一位,都将导致散列结果的明显变化,这称之为雪崩效应。散列还应该是防冲突的,即找不出具有相同散列结果的两条信息。具有这些特性的散列结果就可以用于验证信息是否被修改。 查看更多介绍

HmacMD5 、HmacSHA1 、HmacSHA224 、HmacSHA256 、HmacSHA384 、HmacSHA512 这些加密算法和上边的相比较的话,区别就在于这些需要一个秘钥去和消息输入,生成消息摘要作为输出。这些加密用在服务器验证客户端非常合适:

客户端发送请求之后,服务器收到返回一个随机数,同时在会话中保存该随机数,客户端将信息和返回的随机数用这些算法签名发送给服务器,服务器用刚才记录的随机数和去数据库读取相应信息(如用户名密码)采用同样的散列算法加密和客户端传过来的签名信息对比,从而验证客户端是否合法(被拦截篡改等)。 更多介绍

RSA 公钥加密算法,加密方使用公钥加密,解密方持有私钥解密,公钥和私钥是唯一匹配的,但是有公钥是无法计算出私钥的。该加密算法可以公开加密算法和公钥。用在服务器验证客户端也是非常的nice。

上面的加密算法除了 RSA都是不可逆加密,再看一下下面的可逆加密算法:

DES 、3DES 、AES 、RC2、RC4、RC2、CAST、Blowfish。通过秘钥和初始化向量采用一直加密模式进行加密。加密模式如下几种:

  • ECB模式,相对简单,易于实现,相同的明文产生相同密文,所以安全性相对没那么高,该模式下初始化向量会被忽略。
  • CBC模式,需要初始化向量,误差会传递,安全性高于ECB模式。
  • CFB模式,需要初始化向量,隐藏了明文模式,容易造成错误传播,加密的速率有所降低。
  • OFB模式,不利于并行化处理,克服了误差传递的问题。
  • 更多模式详细信息

以上算法在iOS中的实现

好在上面的算法Apple都是为我们实现了,我们只需要调用相应的接口即可。在这里我们自己写了一个接口,对加密算法进行一点封装,更利于项目中使用(主要是系统的C函数N个参数,看起来累啊!)。

首先我们枚举了加密方式

<pre class="prettyprint hljs elm" style="padding: 0.5em; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; color: rgb(68, 68, 68); border-radius: 4px; display: block; margin: 0px 0px 1.5em; font-size: 14px; line-height: 1.5em; word-break: break-all; word-wrap: break-word; white-space: pre; background-color: rgb(246, 246, 246); border: none; overflow-x: auto; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: 2; text-align: start; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px;">typedef NS_ENUM(NSInteger, HCDStringEncryptType) {

HCDStringEncryptTypeMD2 = 0,
HCDStringEncryptTypeMD4,
HCDStringEncryptTypeMD5,
HCDStringEncryptTypeSHA1,
HCDStringEncryptTypeSHA224,
HCDStringEncryptTypeSHA256,
HCDStringEncryptTypeSHA384,
HCDStringEncryptTypeSHA512,

HCDStringEncryptTypeHmacMD5,     //可以有密钥
HCDStringEncryptTypeHmacSHA1,    //可以有密钥
HCDStringEncryptTypeHmacSHA256,  //可以有密钥
HCDStringEncryptTypeHmacSHA384,  //可以有密钥
HCDStringEncryptTypeHmacSHA512,  //可以有密钥
HCDStringEncryptTypeHmacSHA224,  //可以有密钥

HCDStringEncryptTypeRC2 = 100,   //     /*****************************/
HCDStringEncryptTypeRC4,         //     /*****************************/
HCDStringEncryptTypeAES,         //     /*****************************/
HCDStringEncryptTypeAES128,      //     /*** using default ECB mode **/ //AES目前只支持AES、AES128
HCDStringEncryptTypeDES,         //     /***** 初始化向量iv会被忽略  ****/
HCDStringEncryptType3DES,        //     /*****************************/
HCDStringEncryptTypeCAST,        //     /*****************************/
HCDStringEncryptTypeBlowfish,    //     /*****************************/

};</pre>

然后定义了这么一个接口

<pre class="prettyprint hljs objectivec" style="padding: 0.5em; font-family: Menlo, Monaco, Consolas, "Courier New", monospace; color: rgb(68, 68, 68); border-radius: 4px; display: block; margin: 0px 0px 1.5em; font-size: 14px; line-height: 1.5em; word-break: break-all; word-wrap: break-word; white-space: pre; background-color: rgb(246, 246, 246); border: none; overflow-x: auto; font-style: normal; font-variant-ligatures: normal; font-variant-caps: normal; font-weight: normal; letter-spacing: normal; orphans: 2; text-align: start; text-indent: 0px; text-transform: none; widows: 2; word-spacing: 0px; -webkit-text-stroke-width: 0px;">@interface HCDStringEncryptObject : NSObject

  • (nullable HCDStringEncryptObject *)initWithOriginString:(nullable NSString *)originString keyString:(nullable NSString *)keyString encryptType:(HCDStringEncryptType)encryptType isBase64:(BOOL)base64;

  • (void)base64 NS_AVAILABLE(10_9, 7_0);

  • (void)base64Decode NS_AVAILABLE(10_9, 7_0);

/**

  • 针对可逆加密的解密方法
    */
  • (void)decode;

@property (nonatomic,readonly,getter=isBase64) BOOL base64;
@property (nonatomic,readonly) HCDStringEncryptType encryptType;
@property (strong, nonatomic, nullable,readonly) NSString *keyString;
@property (strong, nonatomic, nullable,readonly) NSString *originString;
@property (strong, nonatomic, nullable,readonly) NSString *encryptedString; //解密之后和originString 一样
@property (strong, nonatomic, nullable,readonly) NSData *encryptedData; //解密之后是originString的NSData
@end</pre>

这样的话我们就能得到加密的方式,加密之后的data以及加密之后的字符串,同时还可以选择是否进行base64编码等非常方便,至于实现的话,主要是调用系统的加密实现,然后再整。一定要记得导入#import <CommonCrypto/CommonCrypto.h>哦

文章来源于网络,如有侵权请联系小编删除

相关文章

  • iOS开发常用的加密技术

    一些常用的加密介绍 在iOS开发中(应该说在所有的开发中),数据的安全性都是非常重要的。下面就简单的说一下数据加密...

  • iOS开发常用的加密技术

    一些常用的加密介绍 在iOS开发中(应该说在所有的开发中),数据的安全性都是非常重要的。下面就简单的说一下数据加密...

  • iOS代码加密常用加密方式

    iOS代码加密常用加密方式,常见的iOS代码加密常用加密方式算法包括MD5加密、AES加密、BASE64加密,三大...

  • iOS常用加密方式

    iOS代码加密常用加密方式,常见的iOS代码加密常用加密方式算法包括MD5加密、AES加密、BASE64加密,三大...

  • iOS-15 加密

    1iOS 常用加密方式讲解 - 简书 2iOS加密方式(RSA签名、加密、AES) - 简书

  • iOS几种加密方式

    iOS 几种加密方法2017-06-19 [iOS开发] iOS常见的几种加密方法 普通加密方法是讲密码进行加密后...

  • 2019-08-07 iOS多线程开发

    iOS开发常常会碰到多线程开发技术,我们常用的集中多线程开发的技术有一下几点:(1)pThread进行开发,pth...

  • iOS开发 UITableView 常用细节

    iOS开发 UITableView 常用细节 iOS开发 UITableView 常用细节

  • 面试题总结

    1. iOS开发中的加密方式 iOS加密相关算法框架:CommonCrypto。 对称加密: DES、3DES、A...

  • iOS开发之Runtime常用示例总结

    iOS开发之Runtime常用示例总结 iOS开发之Runtime常用示例总结

网友评论

    本文标题:iOS开发常用的加密技术

    本文链接:https://www.haomeiwen.com/subject/hnpiuqtx.html