數據加密在解密在軟件開發過程當中舉足輕重的做用,可能有的公司在加密的時候有本身公司內部一套設計的算法,而在這方面不想浪費太大精力就能夠去考慮使用第三方提供的加密算法,如AES加密算法,本篇內容介紹開源中國iOS客戶端使用ASE算法加密密碼;ios
AES GitHub 下載地址 https://github.com/Gurpartap/AESCrypt-ObjCgit
對一個比較大的工程咱們可能都不知道某個類庫或者方法在哪被使用,可是智能的Xcode給咱們提供了一個全局搜索的功能,咱們能夠在真個工程中來搜索這個方法。 好比我不知道AES這個類庫用在哪了,可是若是使用這個類庫確定會引用它的頭文件,咱們搜索AESCryptgithub
![](http://static.javashuo.com/static/loading.gif)
而後除了類庫自己只有Config類裏面包含AESCrpt.h,只有兩個方法用到了,跳轉到Config.m中的兩個方法算法
- -(void)saveUserNameAndPwd:(NSString *)userName andPwd:(NSString *)pwd
- {
- NSUserDefaults * settings = [NSUserDefaults standardUserDefaults];
- [settings removeObjectForKey:@"UserName"];
- [settings removeObjectForKey:@"Password"];
- [settings setObject:userName forKey:@"UserName"];
-
- pwd = [AESCrypt encrypt:pwd password:@"pwd"];
-
- [settings setObject:pwd forKey:@"Password"];
- [settings synchronize];
- }
- -(NSString *)getPwd
- {
- NSUserDefaults * settings = [NSUserDefaults standardUserDefaults];
- NSString * temp = [settings objectForKey:@"Password"];
- return [AESCrypt decrypt:temp password:@"pwd"];
- }
從上面兩個方法的方法名知道方法做用,一個是保存用戶名和密碼,密碼使用了AES加密,另外一個是解密密碼後再返回這個密碼;保存用戶名和密碼是將用戶名和密碼放到了本地的一個沙盒只之中,獲取的時候直接從本地讀取加密後的文件,通過解密和服務器上用戶數據進行比較(想了解開源中國iOS客戶端用戶登錄處理過程,敬請關注下一篇博客 《
開源中國iOS客戶端學習——(十二)用戶登錄》,即將推出);
正如官方給出示例用法同樣,AES的使用很是簡單,首先要添加頭文件 #import "AESCrypt.h",使用示例數據庫
- NSString *pwdKey = @"新風做浪";
- NSString *password = @"duxinfeng123456";
-
- NSString *encryptedPWD = [AESCrypt encrypt:password password:pwdKey];
- NSString *decryptedPWD = [AESCrypt decrypt:encryptedPWD password:pwdKey];
-
- NSLog(@"加密後密碼:%@ 解密後密碼: %@",encryptedPWD,decryptedPWD);
打印結果 : 加密後密碼:/OtTRA5Qz5+xjHB809APLA== 解密後密碼: duxinfeng123456服務器
加密 解密方法函數原型,傳入的兩個參數第一個是加密的數據,第二個是加密數據的key,解密的時候也須要這個key來解密加密後的數據;app
- + (NSString *)encrypt:(NSString *)message password:(NSString *)password;
- + (NSString *)decrypt:(NSString *)base64EncodedString password:(NSString *)password;
原創博客歡迎轉載分享,請註明出處http://blog.csdn.net/duxinfeng2010函數
版權聲明:本文爲博主原創文章,未經博主容許不得轉載。oop