ios常见加密解密方法

在其他平台中经常会计算MD5值,在iOS平台中也提供了该方法,首先需要导入头文件

[cpp] view plain copy

  1. #import <CommonCrypto/CommonDigest.h>

方法CC_MD5可以获取MD5的16个字符的数组,再通过%02X的形式输出即可获取32位MD5值。

[cpp] view plain copy

  1. @implementation NSString (CCCryptUtil)
  2. -(NSString*) md5 {
  3. const char * cStrValue = [self UTF8String];
  4. unsigned char theResult[CC_MD5_DIGEST_LENGTH];
  5. CC_MD5(cStrValue, strlen(cStrValue), theResult);
  6. return [NSString stringWithFormat:@"%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X%02X",
  7. theResult[0], theResult[1], theResult[2], theResult[3],
  8. theResult[4], theResult[5], theResult[6], theResult[7],
  9. theResult[8], theResult[9], theResult[10], theResult[11],
  10. theResult[12], theResult[13], theResult[14], theResult[15]];
  11. }
  12. @end

MD5只能称为一种不可逆的加密算法,只能用作一些检验过程,不能恢复其原文。

apple还提供了RSA、DES、AES等加密算法,见到国外的网站关于AES加密的算法,在此经过加工可以用于字符串加密机密,可用于安全性要求较高的应用。

首先需要导入头文件

[cpp] view plain copy

  1. #import <CommonCrypto/CommonCryptor.h>

将NSData分类,添加NSData加密解密方法

[cpp] view plain copy

  1. @implementation NSData (CCCryptUtil)
  2. - (NSData*)AES256EncryptWithKey:(NSString*)key {
  3. char keyPtr[kCCKeySizeAES256 + 1]; // room for terminator (unused)
  4. bzero(keyPtr, sizeof(keyPtr)); // fill with zeroes (for padding)
  5. [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
  6. NSUInteger dataLength = [self length];
  7. size_t bufferSize           = dataLength + kCCBlockSizeAES128;
  8. void* buffer                = malloc(bufferSize);
  9. size_t numBytesEncrypted    = 0;
  10. CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmAES128, kCCOptionPKCS7Padding,
  11. keyPtr, kCCKeySizeAES256,
  12. NULL /* initialization vector (optional) */,
  13. [self bytes], dataLength, /* input */
  14. buffer, bufferSize, /* output */
  15. &numBytesEncrypted);
  16. if (cryptStatus == kCCSuccess) {
  17. return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];
  18. }
  19. free(buffer);
  20. return nil;
  21. }
  22. - (NSData*)AES256DecryptWithKey:(NSString*)key {
  23. char keyPtr[kCCKeySizeAES256 + 1]; // room for terminator (unused)
  24. bzero(keyPtr, sizeof(keyPtr)); // fill with zeroes (for padding)
  25. // fetch key data
  26. [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];
  27. NSUInteger dataLength = [self length];
  28. size_t bufferSize           = dataLength + kCCBlockSizeAES128;
  29. void* buffer                = malloc(bufferSize);
  30. size_t numBytesDecrypted    = 0;
  31. CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt, kCCAlgorithmAES128, kCCOptionPKCS7Padding,
  32. keyPtr, kCCKeySizeAES256,
  33. NULL /* initialization vector (optional) */,
  34. [self bytes], dataLength, /* input */
  35. buffer, bufferSize, /* output */
  36. &numBytesDecrypted);
  37. if (cryptStatus == kCCSuccess) {
  38. return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];
  39. }
  40. free(buffer); //free the buffer;
  41. return nil;
  42. }
  43. @end

上述代码AES256EncryptWithKey方法为加密函数,AES256DecryptWithKey为解密函数,加密和解密方法使用的参数密钥均为32位长度的字符串,所以可以将任意的字符串经过md5计算32位字符串作为密钥,这样可以允许客户输入任何长度的密钥,并且不同密钥的MD5值也不会重复。

结合上述代码,加工NSString类,提供字符串的AES加密解密方法。代码如下:

[cpp] view plain copy

  1. @implementation NSString (CCCryptUtil)
  2. // md5方法此处省略
  3. + (NSData*)AES256Encrypt:(NSString*)strSource withKey:(NSString*)key {
  4. NSData *dataSource = [strSource dataUsingEncoding:NSUTF8StringEncoding];
  5. return [dataSource AES256EncryptWithKey:[key md5]];
  6. }
  7. + (NSString*)AES256Decrypt:(NSData*)dataSource withKey:(NSString*)key {
  8. NSData *decryptData = [dataSource AES256DecryptWithKey:[key md5]];
  9. return [[NSString alloc] initWithData:decryptData encoding:NSUTF8StringEncoding];
  10. }
  11. @end
时间: 2024-10-24 18:53:15

ios常见加密解密方法的相关文章

C#/IOS/Android通用加密解密方法

原文:C#/IOS/Android通用加密解密方法 公司在做移动端ios/android,服务器提供接口使用的.net,用到加密解密这一块,也在网上找了一些方法,有些是.net加密了android解密不了,或者反之.下面的是三个平台都可以加密解密的方法.加密解密中用到的key="1234578";在调取方法时传值即可. C#代码 #region 跨平台加解密(c#) /// <summary> /// 对字符串进行DES加密 /// </summary> ///

常见加解密方法_转

转自:常用加密解密方法 一.数据加密/编码算法列表 常见用于保证安全的加密或编码算法如下: 1.常用密钥算法 密钥算法用来对敏感数据.摘要.签名等信息进行加密,常用的密钥算法包括:DES(Data Encryption Standard):数据加密标准,速度较快,适用于加密大量数据的场合: 3DES(Triple DES):是基于DES,对一块数据用三个不同的密钥进行三次加密,强度更高: RC2和 RC4:用变长密钥对大量数据进行加密,比 DES 快: IDEA(International Da

ios RSA加密解密一些相关问题

前言: 最近在做一个类似支付宝的理财项目,涉及到了RSA加解密方面的知识,在这里也遇到了不少的问题.写出来与大家分享心得. 1.什么是RSA加密解密(ios RSA加密解密过程) 这些网上都说的很清楚,大家可以从网上查找一下. 理论上是可以用公钥加密,私钥解密,或者是私钥加密,公钥解密. 我的理解是:A向B请求数据:A把自己的信息用私钥签名,并且把自己的公钥传送给B, B受到A的数据:B将A的公钥取出,并且用A的公钥确认签名, B向A发送数据:B将自己的数据用A公钥加密,再将自己的公钥暴露给A,

iOS base64加密解密

本文转载至 http://jingyan.baidu.com/article/93f9803fff45c9e0e46f5596.html 从参考资料的地址中下载GTMBase64.zip库文件包,并解压,获得GTMBase64.h,GTMBase64.m和GTMDefines.h三个文件. 将解压得到的三个文件,添加到项目中. 新建一个base64的类,在base64.h中天假四个函数: + (NSString*)encodeBase64String:(NSString*)input; + (N

mcrypt本身就提供了强大的加密解密方法

由于项目的需要,要写一个能生成“授权码”的类(授权码主要包含项目使用的到期时间),生成的授权码将会写入到一个文件当中,每当项目运行的时候,会自动读取出文件中的密文,然后使用唯一的“密钥”来调用某个函数,对密文进行解密,从中解读出大都会娱乐城项目的使用到期时间. 之前,自己有先试着写了下,主要是base64+md5+反转字符串.算法太过简单,很容易被破解,而且也没有能过做到“密钥”在加解密中的重要性,故而舍之. 后来,查找了相关资料,发现,原来PHP中内置了一个功能强大的函数库,即Mcrypt.

iOS AES加密解密实现方法

使用方法 先导入头文件 #import "NSData+AES.h" //AES测试 //用来密钥 NSString *key = @"123456"; //用来发送的原始数据 NSString *secret = @"I Love You"; //数据转码 NSData *plain = [secret dataUsingEncoding:NSUTF8StringEncoding]; //用密钥加密 NSData *cipher = [plai

iOS 3DES加密解密(一行代码搞定)

3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称.它相当于是对每个数据块应用三次DES加密算法.由于计算机运算能力的增强,原版DES密码的密钥长度变得容易被暴力破解:3DES即是设计用来提供一种相对简单的方法,即通过增加DES的密钥长度来避免类似的攻击,而不是设计一种全新的块密码算法. 3DES又称Triple DES,是DES加密算法的一种模式,它使用3条56位的密钥对数据进行三次加密.数据加密标

简进祥==iOS 3DES加密解密

3DES(或称为Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称.它相当于是对每个数据块应用三次DES加密算法.由于计算机运算能力的增强,原版DES密码的密钥长度变得容易被暴力破解:3DES即是设计用来提供一种相对简单的方法,即通过增加DES的密钥长度来避免类似的攻击,而不是设计一种全新的块密码算法. 3DES又称Triple DES,是DES加密算法的一种模式,它使用3条56位的密钥对数据进行三次加密.数据加密标

C#常用的加密解密方法

开篇 C#内置很多加密解密的方法,有MD5,SHA1,base64等.这里会简单介绍下这几个方法以及用法,不过不会深入研究每种加密方法的原理,高手请绕行. 这几个加密解密会分为两类说,一类是只有加密,没有解密类型的MD5,SHA1.此类加密常用在数据校验.一类是有加密,有解密类型的base64,DES,RSA.此类加密常用在数据传输. 数据校验型 MD5 Message Digest Algorithm MD5(中文名为消息摘要算法第五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完