iOS客户端学习之AES加密

数据加密在解密在软件开发过程中举足轻重的作用,可能有的公司在加密的时候有自己公司内部一套设计的算法,而在这方面不想浪费太大精力就可以去考虑使用第三方提供的加密算法,如AES加密算法,本篇内容介绍开源中国iOS客户端使用ASE算法加密密码;

AES   GitHub 下载地址  https://github.com/Gurpartap/AESCrypt-ObjC

对一个比较大的工程我们可能都不知道某个类库或者方法在哪被使用,但是智能的Xcode给我们提供了一个全局搜索的功能,我们可以在真个工程中来搜索这个方法。 比如我不知道AES这个类库用在哪了,但是如果使用这个类库肯定会引用它的头文件,我们搜索AESCrypt

  

然后除了类库本身只有Config类里面包含AESCrpt.h,只有两个方法用到了,跳转到Config.m中的两个方法

view sourceprint?

01.-(void)saveUserNameAndPwd:(NSString *)userName andPwd:(NSString *)pwd

02.{

03.NSUserDefaults * settings = [NSUserDefaults standardUserDefaults];

04.[settings removeObjectForKey:@"UserName"];

05.[settings removeObjectForKey:@"Pass<a href="http://www.it165.net/edu/ebg/" target="_blank" class="keylink">word</a>"];

06.[settings setObject:userName forKey:@"UserName"];

07.

08.pwd = [AESCrypt encrypt:pwd pass<a href="http://www.it165.net/edu/ebg/" target="_blank" class="keylink">word</a>:@"pwd"];

09.

10.[settings setObject:pwd forKey:@"Password"];

11.[settings synchronize];

12.}

从上面两个方法的方法名知道方法作用,一个是保存用户名和密码,密码使用了AES加密,另一个是解密密码后再返回这个密码;保存用户名和密码是将用户名和密码放到了本地的一个沙盒只之中,获取的时候直接从本地读取加密后的文件,经过解密和服务器上用户数据进行比较(想了解开源中国iOS客户端用户登陆处理过程; www.it165.net

正如官方给出示例用法一样,AES的使用非常简单,首先要添加头文件 #import "AESCrypt.h",使用示例

view sourceprint?

1.NSString *pwdKey = @"新风作浪";

2.NSString *password = @"duxinfeng123456";

3.NSString *encryptedPWD = [AESCrypt encrypt:password password:pwdKey];

4.NSString *decryptedPWD = [AESCrypt decrypt:encryptedPWD password:pwdKey];

5.NSLog(@"加密后密码:%@  解密后密码: %@",encryptedPWD,decryptedPWD);

打印结果 : 加密后密码:/OtTRA5Qz5+xjHB809APLA==  解密后密码: duxinfeng123456

加密 解密方法函数原型,传入的两个参数第一个是加密的数据,第二个是加密数据的key,解密的时候也需要这个key来解密加密后的数据

view sourceprint?

1.+ (NSString *)encrypt:(NSString *)message password:(NSString *)password;

2.+ (NSString *)decrypt:(NSString *)base64EncodedString password:(NSString *)password;

http://www.it165.net/pro/html/201305/5894.html

时间: 2024-08-15 17:40:59

iOS客户端学习之AES加密的相关文章

开源中国iOS客户端学习

开源中国iOS客户端学习 续写前言 <开源中国iOS客户端学习>续写前系列博客    http://blog.csdn.net/column/details/xfzl-kykhd.html 开源中国iOS客户端学习——序 说到这款开源软件就得提到她的娘家了--开源中国社区: 开源中国社区简介:开源中国 www.oschina.net 成立于2008年8月,是目前中国最大的开源技术社区.传播开源的理念,推广开源项目,为 IT 开发者提供了一个发现.使用.并交流开源技术的平台.目前开源中国社区已收

iOS客户端学习 AES加密和解密

数据加密在解密在软件开发过程中举足轻重的作用,可能有的公司在加密的时候有自己公司内部一套设计的算法,而在这方面不想浪费太大精力就可以去考虑使用第三方提供的加密算法,如AES加密算法,本篇内容介绍开源中国iOS客户端使用ASE算法加密密码: AES   GitHub 下载地址  https://github.com/Gurpartap/AESCrypt-ObjC 对一个比较大的工程我们可能都不知道某个类库或者方法在哪被使用,但是智能的Xcode给我们提供了一个全局搜索的功能,我们可以在真个工程中来

开源中国iOS客户端学习——(一)Prefix.pch文件

转载自 http://blog.csdn.net/duxinfeng2010/article/details/8287550 当我们新建一个工程的时候,在Supporting FIles文件下会看到一个以  -Prefix.pch结尾文件的文件,pch全称是“precompiled header”,也就是预编译头文件,该文件里存放的工程中一些不常被修改的代码,比如常用的框架头文件,这样做的目的提高编译器编译速度.我们知道当我 们修改一个工程中某个文件代码时候,编译器并不是重新编译所有所有文件,而

iOS,Android,Jave后台AES加密解密

AES256 在iOS和Android上的相关代码: http://www.tuicool.com/articles/RVFbmmU 里面可以下载相关的代码. 我们遇到的问题是: 把Android的代码移动到Java 后台出现无法加密. 遇到如下的2个问题 1. no cipher getinstance support for AES/CBC/PKCS7Padding 解决方案: http://www.codeweblog.com/java-%E4%BD%BF%E7%94%A8aes-cbc-

iOS客户端ssl签名认证加密双向加密建议使用双向加密更好维护--修改

一个app是否做到强大的加密方式,需要一个好的后台支撑,我有幸我们公司后台哥是珍爱网出来的大神,第一次知道用到除了以前md5 base64 等等单向加密还有ssl认证加密,一般来讲如果app用了web service , 我们需要防止数据嗅探来保证数据安全.通常的做法是用ssl来连接以防止数据抓包和嗅探,其实但心的黑客用伪造的ssl认证链接伪造的服务器上. 1.话不多说,首先你得要你后台给提供他的证书 2.拖到你的项目管理里面,这是你要做的,记住的项目是.cer结尾的证书. 3.我用到的是AFN

开源中国iOS客户端学习(1)

项目目录简单解析: 1.AFNetwork --- 通用网络库2.GCDiscreetNotificationView --- 顶部弹出并会自动消失的通知栏3.Thread --- 后台线程对象,处理后台发送带图片的动弹4.SoftwareGroup --- 所有软件索引页以及软件分组页5.Friends --- 好友列表页,包括粉丝与关注者6.Search --- 搜索页7.Favorite --- 收藏页8.MBHUD --- 载入提示控件9.FTColor --- 富文本显示控件10.EG

ios安全性---AES加密

数据加密在解密在软件开发过程中举足轻重的作用,可能有的公司在加密的时候有自己公司内部一套设计的算法,而在这方面不想浪费太大精力就可以去考虑使用第三方提供的加密算法,如AES加密算法,本篇内容介绍开源中国iOS客户端使用ASE算法加密密码: AES   GitHub 下载地址  https://github.com/Gurpartap/AESCrypt-ObjC 对一个比较大的工程我们可能都不知道某个类库或者方法在哪被使用,但是智能的Xcode给我们提供了一个全局搜索的功能,我们可以在真个工程中来

IOS AES加密 第三方库

数据加密在解密在软件开发过程中举足轻重的作用,可能有的公司在加密的时候有自己公司内部一套设计的算法,而在这方面不想浪费太大精力就可以去考虑使用第三方提供的加密算法,如AES加密算法,本篇内容介绍开源中国iOS客户端使用ASE算法加密密码: AES   GitHub 下载地址  https://github.com/Gurpartap/AESCrypt-ObjC 对一个比较大的工程我们可能都不知道某个类库或者方法在哪被使用,但是智能的Xcode给我们提供了一个全局搜索的功能,我们可以在真个工程中来

AES加密CBC模式 IOS - Java 互通共用

AES加密模式和填充方式 算法/模式/填充                16字节加密后数据长度        不满16字节加密后长度AES/CBC/NoPadding             16                          不支持AES/CBC/PKCS5Padding          32                          16AES/CBC/ISO10126Padding       32                          16AE