#import <Foundation/Foundation.h>

 #import <CommonCrypto/CommonDigest.h>

 #import <CommonCrypto/CommonCryptor.h>

 #import "NSData+AES.h"

 @interface NSString (AES)

 //加密字符串

 - (NSString*)aes128Encrypt:(NSString *)aKey;

 //解密字符串

 - (NSString*)aes128Decrypt:(NSString *)aKey;

 @end
 #define gIv             @"0102030405060708" //自行修改16位 -->偏移量

 @implementation NSString (AES256)

  - (NSString *)aes128Encrypt:(NSString *)aKey

 {

     char keyPtr[kCCKeySizeAES128+];

     memset(keyPtr, , sizeof(keyPtr));

     [aKey getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];

     char ivPtr[kCCBlockSizeAES128+];

     memset(ivPtr, , sizeof(ivPtr));

     [gIv getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSUTF8StringEncoding];

     NSData* data = [self dataUsingEncoding:NSUTF8StringEncoding];

     NSUInteger dataLength = [data length];

     int diff = kCCKeySizeAES128 - (dataLength % kCCKeySizeAES128);

     int newSize = ;

     if(diff > )

     {

         newSize = dataLength + diff;

     }

     char dataPtr[newSize];

     memcpy(dataPtr, [data bytes], [data length]);

     for(int i = ; i < diff; i++)

     {

         dataPtr[i + dataLength] = 0x00;

     }

     size_t bufferSize = newSize + kCCBlockSizeAES128;

     void *buffer = malloc(bufferSize);

     memset(buffer, , bufferSize);

     size_t numBytesCrypted = ;

     CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt,

                                           kCCAlgorithmAES128,

                                           kCCOptionPKCS7Padding,  // 补码方式

                                           keyPtr,

                                           kCCKeySizeAES128,

                                           ivPtr,

                                           dataPtr,

                                           sizeof(dataPtr),

                                           buffer,

                                           bufferSize,

                                           &numBytesCrypted);

     if (cryptStatus == kCCSuccess) {

         NSData *result = [NSData dataWithBytesNoCopy:buffer length:numBytesCrypted];

         if (result && result.length > ) {

             Byte *datas = (Byte*)[result bytes];

             NSMutableString *output = [NSMutableString stringWithCapacity:result.length * ];

             for(int i = ; i < result.length; i++){

                 [output appendFormat:@"%02x", datas[i]];

             }

             return output;

         }

     }

     free(buffer);

     return nil;

 }

 - (NSString *)aes128Decrypt:(NSString *)aKey

 {

     char keyPtr[kCCKeySizeAES128 + ];

     memset(keyPtr, , sizeof(keyPtr));

     [aKey getCString:keyPtr maxLength:sizeof(keyPtr) encoding:NSUTF8StringEncoding];

     char ivPtr[kCCBlockSizeAES128 + ];

     memset(ivPtr, , sizeof(ivPtr));

     [gIv getCString:ivPtr maxLength:sizeof(ivPtr) encoding:NSUTF8StringEncoding];

     NSMutableData *data = [NSMutableData dataWithCapacity:self.length / ];

     unsigned char whole_byte;

     char byte_chars[] = {'\0','\0','\0'};

     int i;

     for (i=; i < [self length] / ; i++) {

         byte_chars[] = [self characterAtIndex:i*];

         byte_chars[] = [self characterAtIndex:i*+];

         whole_byte = strtol(byte_chars, NULL, );

         [data appendBytes:&whole_byte length:];

     }

     NSUInteger dataLength = [data length];

     size_t bufferSize = dataLength + kCCBlockSizeAES128;

     void *buffer = malloc(bufferSize);

     size_t numBytesCrypted = ;

     CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,

                                           kCCAlgorithmAES128,

                                           kCCOptionPKCS7Padding,

                                           keyPtr,

                                           kCCBlockSizeAES128,

                                           ivPtr,

                                           [data bytes],

                                           dataLength,

                                           buffer,

                                           bufferSize,

                                           &numBytesCrypted);

     if (cryptStatus == kCCSuccess) {

         NSData *resultData = [NSData dataWithBytesNoCopy:buffer length:numBytesCrypted];

         return [[NSString alloc] initWithData:resultData encoding:NSUTF8StringEncoding];

     }

     free(buffer);

     return nil;

 }

 @end

iOS Objective c 16进制字符串转为二进制数组

原文:http://lizhuang.iteye.com/blog/2060143

 @implementation NSString (StringToHexData)

 //
// Decodes an NSString containing hex encoded bytes into an NSData object
//
- (NSData *) stringToHexData
{
int len = [self length] / ; // Target length
unsigned char *buf = malloc(len)
unsigned char *whole_byte = buf;
char byte_chars[] = {'\0','\0','\0'}; int i;
for (i=; i < [self length] / ; i++) {
byte_chars[] = [self characterAtIndex:i*];
byte_chars[] = [self characterAtIndex:i*+];
*whole_byte = strtol(byte_chars, NULL, );
whole_byte++;
} NSData *data = [NSData dataWithBytes:buf length:len];
free( buf );
return data;
}
@end
@implementation NSData (DataToHexString) - (NSString *) dataToHexString
{
NSUInteger len = [self length];
char * chars = (char *)[self bytes];
NSMutableString * hexString = [[NSMutableString alloc] init]; for(NSUInteger i = ; i < len; i++ )
[hexString appendString:[NSString stringWithFormat:@"%0.2hhx", chars[i]]]; return hexString;
}
@end

16进制-

iOS开发之Objective-c的AES128加密和解密算法的实现的更多相关文章

  1. iOS开发之 AES+Base64数据混合加密与解密

    2016-04-08 09:03 编辑: liubinqww 分类:iOS开发 来源:liubinqww 投稿 4 889     "APP的数据安全已经牵动着我们开发者的心,简单的MD5/ ...

  2. iOS开发之Objective-c的AES256加密和解密算法的实现

    原文:http://www.lidaren.com/archives/1470 高级加密标准(Advanced Encryption Standard,AES),又称Rijndael加密法. 以下实现 ...

  3. iOS开发之Socket通信实战--Request请求数据包编码模块

    实际上在iOS很多应用开发中,大部分用的网络通信都是http/https协议,除非有特殊的需求会用到Socket网络协议进行网络数 据传输,这时候在iOS客户端就需要很好的第三方CocoaAsyncS ...

  4. iOS开发之UISearchBar初探

    iOS开发之UISearchBar初探 UISearchBar也是iOS开发常用控件之一,点进去看看里面的属性barStyle.text.placeholder等等.但是这些属性显然不足矣满足我们的开 ...

  5. iOS开发之UIImage等比缩放

    iOS开发之UIImage等比缩放 评论功能真不错 评论开通后,果然有很多人吐槽.谢谢大家的支持和关爱,如果有做的不到的地方,还请海涵.毕竟我一个人的力量是有限的,我会尽自己最大的努力大家准备一些干货 ...

  6. iOS开发之 Xcode6 添加xib文件,去掉storyboard的hello world应用

    iOS开发之  Xcode6.1创建仅xib文件,无storyboard的hello world应用 由于Xcode6之后,默认创建storyboard而非xib文件,而作为初学,了解xib的加载原理 ...

  7. iOS开发之loadView、viewDidLoad及viewDidUnload的关系

    iOS开发之loadView.viewDidLoad及viewDidUnload的关系 iOS开发之loadView.viewDidLoad及viewDidUnload的关系    标题中所说的3个方 ...

  8. iOS开发之info.pist文件和.pch文件

    iOS开发之info.pist文件和.pch文件 如果你是iOS开发初学者,不用过多的关注项目中各个文件的作用.因为iOS开发的学习路线起点不在这里,这些文件只会给你学习带来困扰. 打开一个项目,我们 ...

  9. iOS开发之WKWebView简单使用

    iOS开发之WKWebView简单使用   iOS开发之 WKWebVeiw使用 想用UIWebVeiw做的,但是突然想起来在iOS8中出了一个新的WKWebView,算是UIWebVeiw的升级版. ...

随机推荐

  1. 在VS 2012或2013中使用WSE

    1,首先下载 WSE http://www.microsoft.com/en-us/download/confirmation.aspx?id=14089 2,安装的时候选上, 3,C:\Progra ...

  2. django form tips

    1.form将获取的参数传递到field 2.field中的函数 to_python 数据库到python中变量 get_prep_value python变量到数据库 validate 验证,也可以 ...

  3. Python中的if __name__ == '__main__'

    如何简单地理解Python中的if __name__ == '__main__'   1. 摘要 通俗的理解__name__ == '__main__':假如你叫小明.py,在朋友眼中,你是小明(__ ...

  4. requests库安装

    1.运行cmd输入pip install requests C:\Users\Administrator\AppData\Local\Programs\Python\Python37\Scripts ...

  5. day--43 HTML标签和CSS基本小结

    HTML标签和CSS基本小结一:常用标签 01:块标签 p,h1--h6 ,hr ,div 02:内联标签 b,i,u,s 小提示:块标签可以嵌套内置元素或者某些块级元素,但内联元素不能包含块级元素 ...

  6. .NET 海量数据并发处理

    .NET 海量数据并发处理 2013-02-19 10:27 提问者悬赏:10分 |XL码的小伙纸| 分类:C#/.NET| 浏览364次 百万级的数据并发处理,网站呈现数据..NET 开发,可能会使 ...

  7. 压缩感知(CS)

    总结一下最近看的压缩感知(Compressed Sensiong)的内容. 它是在采样过程中完成了数据压缩的过程. 一. 将模拟信号转换为计算机能够处理的数字信号,必然要经过采样的过程.问题在于,应该 ...

  8. [转] PuTTY + Xming 远程使用 Linux GUI

    [From] http://www.zw1840.com/blog/zw1840/2008/10/putty-xming-linux-gui.html By zw1840 on October 28, ...

  9. maven项目在eclipse中debug时看不到源码?

    就像图中一样,看不到源码,但是能step over,也可查看变量值,点击edit source lookup path,选定项目的一瞬间源码会出来,但马上又变回原样了,求大神指教~ 我也遇到这个问题了 ...

  10. 【中间件】IIS短文件名枚举漏洞

    1.1.1  漏洞描述 为了兼容16位MS-DOS程序,Windows为文件名较长的文件(和文件夹)生成了对应的windows 8.3 短文件名. 在Windows下查看对应的短文件名,可以使用命令 ...