iOS常用加密方法(aes、md5、base64)

iOS常用加密方法(aes、md5、base64)

1、AES加密

NSData+AES.h文件
[plain]  view plain copy
  1. //  
  2. //  NSData-AES.h  
  3. //  Smile  
  4. //  
  5. //  Created by 周 敏 on 12-11-24.  
  6. //  Copyright (c) 2012年 BOX. All rights reserved.  
  7. //  
  8.   
  9. #import   
  10.   
  11. @class NSString;  
  12.   
  13. @interface NSData (Encryption)  
  14.   
  15. (NSData *)AES256EncryptWithKey:(NSString *)key;   //加密  
  16. (NSData *)AES256DecryptWithKey:(NSString *)key;   //解密  
  17.   
  18. @end  

NSData+AES.m文件
[plain]  view plain copy
  1. //  
  2. //  NSData-AES.h  
  3. //  Smile  
  4. //  
  5. //  Created by 周 敏 on 12-11-24.  
  6. //  Copyright (c) 2012年 BOX. All rights reserved.  
  7. //  
  8.   
  9. #import "NSData+AES.h"  
  10. #import   
  11.   
  12. @implementation NSData (Encryption)  
  13.   
  14. (NSData *)AES256EncryptWithKey:(NSString *)key {//加密  
  15.     char keyPtr[kCCKeySizeAES256+1];  
  16.     bzero(keyPtr, sizeof(keyPtr));  
  17.     [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];  
  18.     NSUInteger dataLength [self length];  
  19.     size_t bufferSize dataLength kCCBlockSizeAES128;  
  20.     void *buffer malloc(bufferSize);  
  21.     size_t numBytesEncrypted 0;  
  22.     CCCryptorStatus cryptStatus CCCrypt(kCCEncrypt, kCCAlgorithmAES128,  
  23.                                           kCCOptionPKCS7Padding kCCOptionECBMode,  
  24.                                           keyPtr, kCCBlockSizeAES128,  
  25.                                           NULL,  
  26.                                           [self bytes], dataLength,  
  27.                                           buffer, bufferSize,  
  28.                                           &numBytesEncrypted);  
  29.     if (cryptStatus == kCCSuccess)  
  30.         return [NSData dataWithBytesNoCopy:buffer length:numBytesEncrypted];  
  31.      
  32.     free(buffer);  
  33.     return nil;  
  34.  
  35.   
  36.   
  37. (NSData *)AES256DecryptWithKey:(NSString *)key {//解密  
  38.     char keyPtr[kCCKeySizeAES256+1];  
  39.     bzero(keyPtr, sizeof(keyPtr));  
  40.     [key getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];  
  41.     NSUInteger dataLength [self length];  
  42.     size_t bufferSize dataLength kCCBlockSizeAES128;  
  43.     void *buffer malloc(bufferSize);  
  44.     size_t numBytesDecrypted 0;  
  45.     CCCryptorStatus cryptStatus CCCrypt(kCCDecrypt, kCCAlgorithmAES128,  
  46.                                           kCCOptionPKCS7Padding kCCOptionECBMode,  
  47.                                           keyPtr, kCCBlockSizeAES128,  
  48.                                           NULL,  
  49.                                           [self bytes], dataLength,  
  50.                                           buffer, bufferSize,  
  51.                                           &numBytesDecrypted);  
  52.     if (cryptStatus == kCCSuccess)  
  53.         return [NSData dataWithBytesNoCopy:buffer length:numBytesDecrypted];  
  54.      
  55.     free(buffer);  
  56.     return nil;  
  57.  
  58.   
  59. @end  
这里AES在iOS加过密以后以nsdata的形式存下来,如果想以nsstring形式存储,那么对nsdata进行base64位编码。

2、BASE64编码

首先下载GTMBase64文件,在工程中加入三个文件
GTMDefines.h
GTMBase64.h
GTMBase64.m
你可以在这里找到这三个文件
http://code.google.com/p/google-toolbox-for-mac/source/browse/trunk/Foundation/?r=87
你也可以在下面的demo里面找到这3个文件,demo会完整实现文章里面常用的3种编码方法。
我在此稍微封装一下:

.h文件
[plain]  view plain copy
  1. #pragma mark base64  
  2. (NSString*)encodeBase64String:(NSString *)input;  
  3. (NSString*)decodeBase64String:(NSString *)input;  
  4. (NSString*)encodeBase64Data:(NSData *)data;  
  5. (NSString*)decodeBase64Data:(NSData *)data;  

.m文件
[plain]  view plain copy
  1. #pragma mark base64  
  2. (NSString*)encodeBase64String:(NSString )input   
  3.     NSData *data [input dataUsingEncoding:NSUTF8StringEncoding allowLossyConversion:YES];   
  4.     data [GTMBase64 encodeData:data];   
  5.     NSString *base64String [[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding] autorelease];   
  6.     return base64String;  
  7.  
  8.   
  9. (NSString*)decodeBase64String:(NSString )input   
  10.     NSData *data [input dataUsingEncoding:NSUTF8StringEncoding allowLossyConversion:YES];   
  11.     data [GTMBase64 decodeData:data];   
  12.     NSString *base64String [[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding] autorelease];   
  13.     return base64String;  
  14.   
  15.   
  16. (NSString*)encodeBase64Data:(NSData *)data  
  17.     data [GTMBase64 encodeData:data];   
  18.     NSString *base64String [[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding] autorelease];  
  19.     return base64String;  
  20.  
  21.   
  22. (NSString*)decodeBase64Data:(NSData *)data  
  23.     data [GTMBase64 decodeData:data];   
  24.     NSString *base64String [[[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding] autorelease];  
  25.     return base64String;  
  26.  

3、MD5加密

NSString+MD5.h文件
[plain]  view plain copy
  1. //  
  2. //  NSString+MD5Encrypt.h  
  3. //  Smile  
  4. //  
  5. //  Created by 周 敏 on 12-11-24.  
  6. //  Copyright (c) 2012年 BOX. All rights reserved.  
  7. //  
  8.   
  9. #import   
  10.   
  11. @interface NSString (MD5)  
  12.   
  13. (NSString *)md5Encrypt;  
  14.   
  15. @end  


NSString+MD5.m文件
[plain]  view plain copy
  1. //  
  2. //  NSString+MD5Encrypt.h  
  3. //  Smile  
  4. //  
  5. //  Created by 周 敏 on 12-11-24.  
  6. //  Copyright (c) 2012年 BOX. All rights reserved.  
  7. //  
  8.   
  9. #import "NSString+MD5.h"  
  10.   
  11. @implementation NSString (MD5)  
  12.   
  13. (NSString *)md5Encrypt  
  14.     const char *original_str [self UTF8String];  
  15.     unsigned char result[CC_MD5_DIGEST_LENGTH];  
  16.     CC_MD5(original_str, strlen(original_str), result);  
  17.     NSMutableString *hash [NSMutableString string];  
  18.     for (int 0; 16; i++)  
  19.         [hash appendFormat:@"X", result[i]];  
  20.     return [hash lowercaseString];  
  21.  
  22.   
  23. @end  

将字符串进行MD5加密,返回加密后的字符串。

 

#import  <CommonCrypto/CommonDigest.h>  //  Need to import for CC_MD5 access

 

复制代码
(NSString  *)md5:(NSString  *)str
{
        const  char  *cStr  [str  UTF8String];
        unsigned  char  result[ 16];
        CC_MD5(cStr,  strlen(cStr),  result);  //  This is the md5 call
        return  [NSString  stringWithFormat:
                @" xxxxxxxxxxxxxxxx ",
                result[ 0],  result[ 1],  result[ 2],  result[ 3], 
                result[ 4],  result[ 5],  result[ 6],  result[ 7],
                result[ 8],  result[ 9],  result[ 10],  result[ 11],
                result[ 12],  result[ 13],  result[ 14],  result[ 15]
                ]; 
}

demo含有这3种的使用方式,在AppDelegate.m文件里面,不会使用的自己参考一下。
demo下载:http://download.csdn.net/detail/z251257144/4884004
http://blog.csdn.net/hsyj_0001/article/details/7607963

转自:http://blog.sina.com.cn/s/blog_a573f7990101b6gi.html
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值