博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
3DES 加密 解密
阅读量:6680 次
发布时间:2019-06-25

本文共 3259 字,大约阅读时间需要 10 分钟。

#import <Foundation/Foundation.h>

//3DES加密

@interface JKEncrypt : NSObject

 

-(NSString *)doEncrypt:(NSString *)plainText;

 

-(NSString*)doDecEncrypt:(NSString *)encryptText;

 

@end

//

//  main.m

//  3DES研究

//

//  Created by apple on 15/10/22.

//  Copyright © 2015 apple. All rights reserved.

//

 

#import "JKEncrypt.h"

#import <CommonCrypto/CommonDigest.h>  

#import <CommonCrypto/CommonCryptor.h>

#import <Security/Security.h>

 

//密匙 key

#define gkey            @"123456788765432112345678"  //24位的密钥

//偏移量

#define gIv             @"jukai"

 

@implementation JKEncrypt

 

-(NSString *)doEncrypt:plainText{

    

    //string NSData

    NSData* data = [plainText dataUsingEncoding:NSUTF8StringEncoding];

    

    //length

    size_t plainTextBufferSize = [data length];

    

    const void *vplainText = (const void *)[data bytes];

    

    CCCryptorStatus ccStatus;

    uint8_t *bufferPtr = NULL;

    size_t bufferPtrSize = 0;

    size_t movedBytes = 0;

    

    bufferPtrSize = (plainTextBufferSize + kCCBlockSize3DES) & ~(kCCBlockSize3DES - 1);

    bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t));

    memset((void *)bufferPtr, 0x0, bufferPtrSize);

    

    const void *vkey = (const void *) [gkey UTF8String];

    //偏移量

    const void *vinitVec = (const void *) [gIv UTF8String];

    

    //配置CCCrypt

    ccStatus = CCCrypt(kCCEncrypt,

                       kCCAlgorithm3DES, //3DES

                       kCCOptionECBMode|kCCOptionPKCS7Padding, //设置模式

                       vkey,    //key

                       kCCKeySize3DES,

//                       vinitVec,     //偏移量,这里不用,设置为nil;不用的话,必须为nil,不可以为@“” 解密算法里也应该为nil,也不可以为@“”

                       nil,     //偏移量,这里不用,设置为nil;不用的话,必须为nil,不可以为@“”

                       vplainText,

                       plainTextBufferSize,

                       (void *)bufferPtr,

                       bufferPtrSize,

                       &movedBytes);

    

    NSData *myData = [NSData dataWithBytes:(const char *)bufferPtr length:(NSUInteger)movedBytes];

    

    NSUInteger          len = [myData length];

    char *              chars = (char *)[myData bytes];

    NSMutableString *   hexString = [[NSMutableString alloc] init];

    

    for(NSUInteger i = 0; i < len; i++ )

        [hexString appendString:[NSString stringWithFormat:@"%0.2hhx", chars[i]]];

    

    return hexString;

    

}

 

 

 

-(NSString*)doDecEncrypt:(NSString *)hexString{

    

    //十六进制转NSData

    long len = [hexString length] / 2;

    unsigned char *buf = malloc(len);

    unsigned char *whole_byte = buf;

    char byte_chars[3] = {

'\0','\0','\0'};

    

    int i;

    for (i=0; i < [hexString length] / 2; i++) {

        byte_chars[0] = [hexString characterAtIndex:i*2];

        byte_chars[1] = [hexString characterAtIndex:i*2+1];

        *whole_byte = strtol(byte_chars, NULL, 16);

        whole_byte++;

    }

    

    NSData *encryptData = [NSData dataWithBytes:buf length:len];

    

    size_t plainTextBufferSize = [encryptData length];

    const void *vplainText = [encryptData bytes];

    

    CCCryptorStatus ccStatus;

    uint8_t *bufferPtr = NULL;

    size_t bufferPtrSize = 0;

    size_t movedBytes = 0;

    

    bufferPtrSize = (plainTextBufferSize + kCCBlockSize3DES) & ~(kCCBlockSize3DES - 1);

    bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t));

    memset((void *)bufferPtr, 0x0, bufferPtrSize);

    

    const void *vkey = (const void *) [gkey UTF8String];

    

    const void *vinitVec = (const void *) [gIv UTF8String];

    

    ccStatus = CCCrypt(kCCDecrypt,

                       kCCAlgorithm3DES,

                       kCCOptionPKCS7Padding|kCCOptionECBMode,

                       vkey,

                       kCCKeySize3DES,

                       nil,

                       vplainText,

                       plainTextBufferSize,

                       (void *)bufferPtr,

                       bufferPtrSize,

                       &movedBytes);

    

    NSString *result = [[NSString alloc] initWithData:[NSData dataWithBytes:(const void *)bufferPtr

                                                                      length:(NSUInteger)movedBytes] encoding:NSUTF8StringEncoding];

    

    

    return result;

}

 

 

 

@end

转载于:https://www.cnblogs.com/daxueshan/p/6296818.html

你可能感兴趣的文章
bootstap-table 只显示列名和表格不显示数据
查看>>
pycharm 5注册
查看>>
java-buildpack源码分析之Release
查看>>
iptables实现网络防火墙及地址转换
查看>>
如何将sql 2000数据库 移植到 mysql 数据库中
查看>>
离线安装gcc(CentOS7)
查看>>
客运车辆监管及运营平台
查看>>
eclipse添加注释
查看>>
贝叶斯估计和最大后验估计
查看>>
COBBLER无人值守安装
查看>>
基础知识--JAVA注解ElementType
查看>>
kickstart部署centos6.2 x86_64
查看>>
salt 的用户管理
查看>>
我封装的全文检索之solr篇
查看>>
NFC的第一次接触
查看>>
RHEL7 Connection closed by foreign host.
查看>>
Nodejs开发框架之Loopback介绍
查看>>
微信小程序下拉刷新使用整理
查看>>
ubuntu12.04禁用客人会话
查看>>
我的友情链接
查看>>