iOS--算法--DES篇

       DES作为一种重要的对称加密算法,即使是iOS上也同样受到很大欢迎。这里介绍一下DES的CBC模式的iOS实现。至于ECB模式,这里有一篇文章来介绍,传送门->


       如果想了解更多模式,请看这里,传送门->


不多说了,贴代码!


#import <Foundation/Foundation.h>
#import <CommonCrypto/CommonCryptor.h>

@interface NSString (DES)

+ (NSString *)DES_EncryptWithText:(NSString *)sText;

+ (NSString *)DES_DecryptWithText:(NSString *)sText;

+ (NSString *)DES_WithText:(NSString *)sText encryptOrDecrypt:(CCOperation)operation key:(NSString *)key;

@end

#import "NSString+DES.h"

@implementation NSString (DES)

+ (NSString *)DES_EncryptWithText:(NSString *)sText
{
    //kCCEncrypt 加密
    return [self DES_WithText:sText encryptOrDecrypt:kCCEncrypt key:@"des"];
}

+ (NSString *)DES_DecryptWithText:(NSString *)sText
{
    //kCCDecrypt 解密
    return [self DES_WithText:sText encryptOrDecrypt:kCCDecrypt key:@"des"];
}

+ (NSString *)DES_WithText:(NSString *)sText encryptOrDecrypt:(CCOperation)operation key:(NSString *)key
{
    const void *dataIn;
    size_t dataInLength;
    
    if (operation == kCCDecrypt)// 解码
    {
        //解码 base64
        NSData *decryptData = [[NSData alloc]initWithBase64EncodedString:sText options:NSDataBase64DecodingIgnoreUnknownCharacters];;//转成utf-8并decode
        dataInLength = [decryptData length];
        dataIn = [decryptData bytes];
    }
    else  //encrypt
    {
        NSData* encryptData = [sText dataUsingEncoding:NSUTF8StringEncoding];
        dataInLength = [encryptData length];
        dataIn = (const void *)[encryptData bytes];
    }
    
    /*
     DES加密 :用CCCrypt函数加密一下,然后用base64编码下,传过去
     DES解密 :把收到的数据根据base64,decode一下,然后再用CCCrypt函数解密,得到原本的数据
     */
    CCCryptorStatus ccStatus;
    uint8_t *dataOut = NULL;
    size_t dataOutAvailable = 0; //size_t  是操作符sizeof返回的结果类型
    size_t dataOutMoved = 0;
    
    dataOutAvailable = (dataInLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);
    dataOut = malloc( dataOutAvailable * sizeof(uint8_t));
    memset((void *)dataOut, 0x0, dataOutAvailable);//将已开辟内存空间buffer的首 1 个字节的值设为值 0
    
    const void *vkey = (const void *) [key UTF8String];
    
    static Byte iv[] = {1,2,3,4,5,6,7,8}; //初始向量会影响最后加密出来的密文!
    
    //CCCrypt函数 加密/解密
    ccStatus = CCCrypt(operation,//  加密/解密
                       kCCAlgorithmDES,//  加密根据哪个标准(des,3des,aes。。。。)
                       kCCOptionPKCS7Padding,//  选项分组密码算法 默认是cbc模式
                       vkey,  //密钥    加密和解密的密钥必须一致
                       kCCKeySizeDES,//   DES 密钥的大小(kCCKeySizeDES=8)
                       iv, //  可选的初始矢量
                       dataIn, // 数据的存储单元
                       dataInLength,// 数据的大小
                       (void *)dataOut,// 用于返回数据
                       dataOutAvailable,
                       &dataOutMoved);
    
    NSString *result = nil;
    
    if (ccStatus == kCCSuccess) {
        
        if (operation == kCCDecrypt)//encryptOperation==1  解码
        {
            //得到解密出来的data数据,改变为utf-8的字符串
            result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved] encoding:NSUTF8StringEncoding];
        }
        else
        {
            //加密 最后输出base64文本
            NSData *data = [NSData dataWithBytes:(const void *)dataOut length:(NSUInteger)dataOutMoved];
            result = [data base64EncodedStringWithOptions:NSDataBase64Encoding64CharacterLineLength];
        }
    }else
    {
        NSLog(@"加密or解密失败");
    }
    
    return result;
}

@end

文中关于初始向量iv的解释请看这里,传送门->

另外,如果你想和java服务器一通协调工作,可以看看这里~传送门->


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

TheLittleBoy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值