zoukankan      html  css  js  c++  java
  • ios安全性---AES加密

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

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

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

       

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

    1. -(void)saveUserNameAndPwd:(NSString *)userName andPwd:(NSString *)pwd  
    2. {  
    3.     NSUserDefaults * settings = [NSUserDefaults standardUserDefaults];  
    4.     [settings removeObjectForKey:@"UserName"];  
    5.     [settings removeObjectForKey:@"Password"];  
    6.     [settings setObject:userName forKey:@"UserName"];  
    7.       
    8.     pwd = [AESCrypt encrypt:pwd password:@"pwd"];  
    9.       
    10.     [settings setObject:pwd forKey:@"Password"];  
    11.     [settings synchronize];  
    12. }  
    -(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];
    }
    1. -(NSString *)getPwd  
    2. {  
    3.     NSUserDefaults * settings = [NSUserDefaults standardUserDefaults];  
    4.     NSString * temp = [settings objectForKey:@"Password"];  
    5.     return [AESCrypt decrypt:temp password:@"pwd"];  
    6. }  
    -(NSString *)getPwd
    {
        NSUserDefaults * settings = [NSUserDefaults standardUserDefaults];
        NSString * temp = [settings objectForKey:@"Password"];
        return [AESCrypt decrypt:temp password:@"pwd"];
    }

    从上面两个方法的方法名知道方法作用,一个是保存用户名和密码,密码使用了AES加密,另一个是解密密码后再返回这个密码;保存用户名和密码是将用户名和密码放到了本地的一个沙盒只之中,获取的时候直接从本地读取加密后的文件,经过解密和服务器上用户数据进行比较(想了解开源中国iOS客户端用户登陆处理过程,敬请关注下一篇博客 《开源中国iOS客户端学习——(十二)用户登陆》,即将推出);

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

    1. NSString *pwdKey = @"新风作浪";  
    2. NSString *password = @"duxinfeng123456";  
    3.   
    4. NSString *encryptedPWD = [AESCrypt encrypt:password password:pwdKey];  
    5. NSString *decryptedPWD = [AESCrypt decrypt:encryptedPWD password:pwdKey];  
    6.   
    7. NSLog(@"加密后密码:%@  解密后密码: %@",encryptedPWD,decryptedPWD);  
        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来解密加密后的数据;

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

    转载注明出处:http://blog.csdn.net/duxinfeng2010

  • 相关阅读:
    centos6 python 安装 sqlite 解决 No module named ‘_sqlite3′
    Python--Virtualenv简明教程
    【centos】 error: command 'gcc' failed with exit status 1
    python3.5学习笔记:linux6.4 安装python3 pip setuptools
    Python的虚拟环境virtualenv
    hdu Robberies
    转载:hdu 动态规划题集
    在Eclipse中配置Tomcat 创建和运行Servlet/JSP
    opengl中层次建模的实现
    shiyan2
  • 原文地址:https://www.cnblogs.com/iOSWinner/p/4491020.html
Copyright © 2011-2022 走看看