美文网首页
iOS DES加解密

iOS DES加解密

作者: 可乐小子 | 来源:发表于2023-01-27 11:16 被阅读0次

define kASDESKEY @"0123456789ABCDEF"

const Byte s_iv[] = {0x63,0x75};

const Byte s_key[] = {0x58,0x78};

/// 使用DES加密方法

  • (NSString *)encodeDesWithString2:(NSString *)string {
    NSString *ciphertext = nil;
    const char *textBytes = [string UTF8String];
    size_t dataLength = [string length];
    //==================

    uint8_t *bufferPtr = NULL;
    size_t bufferPtrSize = 0;
    size_t movedBytes = 0;

    bufferPtrSize = (dataLength + kCCBlockSizeDES) & ~(kCCBlockSizeDES - 1);
    bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t));
    memset((void *)bufferPtr, 0x0, bufferPtrSize);

    CCCryptorStatus cryptStatus = CCCrypt(kCCEncrypt, kCCAlgorithmDES,
    kCCOptionPKCS7Padding,
    s_key, kCCKeySizeDES,
    s_iv,
    textBytes, dataLength,
    (void *)bufferPtr, bufferPtrSize,
    &movedBytes);
    if (cryptStatus == kCCSuccess) {

     ciphertext= [ASKDESTools parseByte2HexString:bufferPtr :(int)movedBytes];
    

    }
    ciphertext=[ciphertext uppercaseString];//字符变大写

    return ciphertext;
    }

/// 使用DES进行解密计算

  • (NSString *)decodeDesWithString2:(NSString *)string {

    NSData* cipherData = [ASKDESTools convertHexStrToData:[string lowercaseString]];

    unsigned char buffer[1024];
    memset(buffer, 0, sizeof(char));
    size_t numBytesDecrypted = 0;
    // NSString *testString = kASDESKEY;
    // NSData *testData = [testString dataUsingEncoding: NSUTF8StringEncoding];
    // Byte iv = (Byte )[testData bytes];
    CCCryptorStatus cryptStatus = CCCrypt(kCCDecrypt,
    kCCAlgorithmDES,
    kCCOptionPKCS7Padding,
    s_key,
    kCCKeySizeDES,
    s_iv,
    [cipherData bytes],
    [cipherData length],
    buffer,
    1024,
    &numBytesDecrypted);
    NSString
    plainText = nil;
    if (cryptStatus == kCCSuccess) {
    NSData
    data = [NSData dataWithBytes:buffer length:(NSUInteger)numBytesDecrypted];
    plainText = [[NSString alloc] initWithData:data encoding:NSUTF8StringEncoding];
    }
    return plainText;

}

/*
加密解密中有两个方法调用,其实是为了16进制与data之间的转换。有些公司并未转换成16进制,而是需要跟base64共同加解密。方法适用,只需要将得出的plainText 的值转成base64即可。
*/

/// 加密时转成16进制

  • (NSString *) parseByte2HexString:(Byte *) bytes :(int)len {

    NSLog(@"bytes ==== %s",bytes);
    NSString *hexStr = @"";
    NSMutableString *hexString = @"";
    if(bytes)
    {
    for(int i = 0; i < len ; i++)
    {
    NSString *newHexStr = [NSString stringWithFormat:@"%x",bytes[i]&0xff]; ///16进制数
    if([newHexStr length]==1){
    hexStr = [NSString stringWithFormat:@"%@0%@",hexStr,newHexStr];
    }
    else
    {
    hexStr = [NSString stringWithFormat:@"%@%@",hexStr,newHexStr];
    }
    }
    }

    return hexStr;
    }

/// 解密时转回data

  • (NSData *)convertHexStrToData:(NSString *)str {
    if (!str || [str length] == 0) {
    return nil;
    }

    NSMutableData *hexData = [[NSMutableData alloc] initWithCapacity:8];
    NSRange range;
    if ([str length] % 2 == 0) {
    range = NSMakeRange(0, 2);
    } else {
    range = NSMakeRange(0, 1);
    }
    for (NSInteger i = range.location; i < [str length]; i += 2) {
    unsigned int anInt;
    NSString *hexCharStr = [str substringWithRange:range];
    NSScanner *scanner = [[NSScanner alloc] initWithString:hexCharStr];

      [scanner scanHexInt:&anInt];
      NSData *entity = [[NSData alloc] initWithBytes:&anInt length:1];
      [hexData appendData:entity];
      
      range.location += range.length;
      range.length = 2;
    

    }

    return hexData;
    }

相关文章

  • iOS Android DES加解密一致性问题

    iOS Android DES加解密一致性问题 iOS DES 加解密 Android DES加解密 iOS中支持...

  • iOS DES加解密

    define kASDESKEY @"0123456789ABCDEF" const Byte s_iv[...

  • iOS常用加密算法

    本篇主要介绍笔者在iOS开发工作中用到的加解密算法的使用,主要包括:1)对称加密算法:AES、DES、3DES2)...

  • iOS OC DES-hex加密

    加解密流程:content -> hex -> des -> hex -> content 引入头文件: DES加...

  • 【Android 应用安全】数据加解密系列

    Android DES加解密的两种实现方式 - Java DES与Android DES不兼容问题 Android...

  • Android Des/3DES加解密

    1、3DES加解密 DES加密分为 单DES和 3DES加密 单DES加密是8个字节长度加密 3DES加密分为:双...

  • iOS签名机制

    安全方案 对称密码:DES,3DES,AES 加解密用同一个密钥 加解密速度快 无法解决密钥配送问题 非对称加密:...

  • iOS 对称算法DES加解密

    // // NSString+DES.m // test // // Created by 范云飞 on 2018...

  • 3DES加解密-iOS

    最近公司需要对url明文加密,经过讨论后使用了3DES加密 1.首先需要导入GTMBase64开源框架库 2.KC...

  • DES加解密

    以下是Kotlin 实现的DES的加解密算法: Base64工具

网友评论

      本文标题:iOS DES加解密

      本文链接:https://www.haomeiwen.com/subject/bmkehdtx.html