資料加密在解密在軟體開發過程中舉足輕重的作用,可能有的公司在加密的時候有自己公司內部一套設計的演算法,而在這方面不想浪費太大精力就可以去考慮使用第三方提供的密碼編譯演算法,如AES密碼編譯演算法,本篇內容介紹開源中國iOS用戶端使用ASE演算法加密密碼;
AES GitHub https://github.com/Gurpartap/AESCrypt-ObjC
對一個比較大的工程我們可能都不知道某個類庫或者方法在哪被使用,但是智能的Xcode給我們提供了一個全域搜尋的功能,我們可以在真箇工程中來搜尋這個方法。 比如我不知道AES這個類庫用在哪了,但是如果使用這個類庫肯定會引用它的標頭檔,我們搜尋AESCrypt
然後除了類庫本身只有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來解密加密後的資料;
+ (NSString *)encrypt:(NSString *)message password:(NSString *)password;+ (NSString *)decrypt:(NSString *)base64EncodedString password:(NSString *)password;
原創部落格歡迎轉載分享,請註明出處http://blog.csdn.net/duxinfeng2010