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

  1. #import <CommonCrypto/CommonDigest.h>

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

  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加密的算法,在此经过加工可以用于字符串加密机密,可用于安全性要求较高的应用。

首先需要导入头文件

  1. #import <CommonCrypto/CommonCryptor.h>

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

  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加密解密方法。代码如下:

  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

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

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

    原文:C#/IOS/Android通用加密解密方法 公司在做移动端ios/android,服务器提供接口使用的.net,用到加密解密这一块,也在网上找了一些方法,有些是.net加密了android解密 ...

  2. C#开发中常用的加密解密方法

    转载自:https://www.cnblogs.com/bj981/p/11203711.html C#开发中常用的加密解密方法 相信很多人在开发过程中经常会遇到需要对一些重要的信息进行加密处理,今天 ...

  3. vb.net加密解密方法

    1.vb.net加密解密方法 Private Function getLicenseDate() As String Dim b() As Byte Dim path As String = Serv ...

  4. ASP.NET常用加密解密方法

    ASP.NET常用加密解密方法 一.MD5加密解密 1.加密 C# 代码           public static string ToMd5(string clearString)        ...

  5. 2019-2-20C#开发中常用加密解密方法解析

    C#开发中常用加密解密方法解析 一.MD5加密算法 我想这是大家都常听过的算法,可能也用的比较多.那么什么是MD5算法呢?MD5全称是 message-digest algorithm 5[|ˈmes ...

  6. Java实现一个简单的加密解密方法

    Crypto是Java语言写的一个简单的加密解密方法. 使用方法: 加密方法 String cipherte=Enande.encrypt(content, pass): 解密方法 Enande.de ...

  7. PHP加密解密方法

    加密解密方法 //字符串解密加密 function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) { $ckey_l ...

  8. Javascript实现base64的加密解密方法

    1 function Base64() { 2 // private property 3 _keyStr = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijkl ...

  9. iOS AES加密解密实现方法

    使用方法 先导入头文件 #import "NSData+AES.h" //AES测试 //用来密钥 NSString *key = "; //用来发送的原始数据 NSSt ...

随机推荐

  1. HDU3535-AreYouBusy

    描述: As having become a junior, xiaoA recognizes that there is not much time for her to AC problems, ...

  2. 5.6.3.8 fromCharCode()方法

    String构造函数本身还有一个静态方法:fromCharCode().这个方法的任务是接收一或多个字符编码,然后将它们转换成一个字符.从本质上来看,这个方法与实例方法charCodeAt()执行的是 ...

  3. codeforces 522D. Closest Equals 线段树+离线

    题目链接 n个数m个询问, 每次询问输出给定区间中任意两个相同的数的最近距离. 先将询问读进来, 然后按r从小到大排序, 将n个数按顺序插入, 并用map统计之前是否出现过, 如果出现过, 就更新线段 ...

  4. python 以面向对象的方式创建线程 实现售票系统

    ---恢复内容开始--- 转载或借鉴请注明转自http://www.cnblogs.com/FG123/p/5068556.html   谢谢! 通过面向对象的方法实现多线程,其核心是继承thread ...

  5. Push segues can only be used when the.....

    刚刚遇到的两个错误,. 1, Terminating app due to uncaught exception'NSGenericException', reason: 'Push segues c ...

  6. 嵌入式C开发人员的最好的0x10道笔试题

    嵌入式C开发人员的最好的0x10道笔试题 2006-11-22 15:53 约定: 1) 下面的测试题中,认为所有必须的头文件都已经正确的包含了 2)数据类型 char 一个字节 1 byte int ...

  7. MySQL DBA成长之路

    http://blog.51cto.com/zt/579 :GRANT ALL PRIVILEGES ON *.* TO 'myuser'@'192.168.1.3' IDENTIFIED BY 'm ...

  8. 定位CPU高的方法

    CPU占用高,最常见的原因是死循环或者类死循环的操作,如果要逐一排查代码,费时费力,可以先用工具 工具1.windbg,windows出品的牛刀一枚以管理员运行windbg,File->Atta ...

  9. 我的第一个REST客户端程序!

    Delphi:XE8 看了好几天的资料了,也没有弄出来一个REST程序,尝试了XE8中带的例子,也都没有搞懂.我在网上不断搜索,看是否能够找到适合自己的文章,希望能够做出来一个REST的小例子,万幸, ...

  10. perl lwp 超时问题

    lwp 超时问题: jrhmpt01:/root/async# cat a1.pl use LWP::UserAgent; use utf8; use DBI; use POSIX; use Data ...