首页 > 解决方案 > 如何在 Swift 中使用重音字符加密字符串

问题描述

我有一个字符串,其中包含一些特殊字符、空格和重音字符。

示例:j'aime trop ma série

我正在使用 Commoncypto 加密字符串。它在字符串包含纯文本时起作用。但是,当字符串如上例所示时,它不起作用。

我正在使用以下代码:

+ (NSString *) EncryptString:(NSString *)plainSourceStringToEncrypt {
StringEncryption *crypto = [[StringEncryption alloc] init];
    
NSData *_secretData = [plainSourceStringToEncrypt dataUsingEncoding:NSASCIIStringEncoding];
    
NSData *encryptedData = [crypto encrypt:_secretData key:[_key dataUsingEncoding:NSUTF8StringEncoding] padding:&padding];
    
return [encryptedData base64EncodingWithLineLength:0];  }


- (NSData *)encrypt:(NSData *)plainText key:(NSData *)aSymmetricKey padding:(CCOptions *)pkcs7 {
return [self doCipher:plainText key:aSymmetricKey context:kCCEncrypt padding:pkcs7]; }

- (NSData *)doCipher:(NSData *)plainText key:(NSData *)aSymmetricKey
         context:(CCOperation)encryptOrDecrypt padding:(CCOptions *)pkcs7 {
CCCryptorStatus ccStatus = kCCSuccess;
// Symmetric crypto reference.
CCCryptorRef thisEncipher = NULL;
// Cipher Text container.
NSData * cipherOrPlainText = nil;
// Pointer to output buffer.
uint8_t * bufferPtr = NULL;
// Total size of the buffer.
size_t bufferPtrSize = 0;
// Remaining bytes to be performed on.
size_t remainingBytes = 0;
// Number of bytes moved to buffer.
size_t movedBytes = 0;
// Length of plainText buffer.
size_t plainTextBufferSize = 0;
// Placeholder for total written.
size_t totalBytesWritten = 0;
// A friendly helper pointer.
uint8_t * ptr;

// Initialization vector; dummy in this case 0's.
uint8_t iv[kChosenCipherBlockSize];
memset((void *) iv, 0x0, (size_t) sizeof(iv));

NSLog(@"doCipher: plaintext: %@", plainText);
NSLog(@"doCipher: key length: %lu", (unsigned long)[aSymmetricKey length]);

plainTextBufferSize = [plainText length];

//LOGGING_FACILITY(plainTextBufferSize > 0, @"Empty plaintext passed in." );

NSLog(@"pkcs7: %d", *pkcs7);
// We don't want to toss padding on if we don't need to
if(encryptOrDecrypt == kCCEncrypt) {
    if(*pkcs7 != kCCOptionECBMode) {
        
        if((plainTextBufferSize % kChosenCipherBlockSize) == 0) {
            *pkcs7 = 0x0000;
        } else {
            *pkcs7 = kCCOptionPKCS7Padding;
        }
    }
} else if(encryptOrDecrypt != kCCDecrypt) {
    NSLog(@"Invalid CCOperation parameter [%d] for cipher context.", *pkcs7 );
} 

// Create and Initialize the crypto reference.
ccStatus = CCCryptorCreate(encryptOrDecrypt,
                           kCCAlgorithmAES128,
                           *pkcs7,
                           (const void *)[aSymmetricKey bytes],
                           kChosenCipherKeySize,
                           (const void *)iv,
                           &thisEncipher
                           );

// Calculate byte block alignment for all calls through to and including final.
bufferPtrSize = CCCryptorGetOutputLength(thisEncipher, plainTextBufferSize, true);

// Allocate buffer.
bufferPtr = malloc( bufferPtrSize * sizeof(uint8_t) );

// Zero out buffer.
memset((void *)bufferPtr, 0x0, bufferPtrSize);

// Initialize some necessary book keeping.

ptr = bufferPtr;

// Set up initial size.
remainingBytes = bufferPtrSize;

// Actually perform the encryption or decryption.
ccStatus = CCCryptorUpdate(thisEncipher,
                           (const void *) [plainText bytes],
                           plainTextBufferSize,
                           ptr,
                           remainingBytes,
                           &movedBytes
                           );

// Handle book keeping.
ptr += movedBytes;
remainingBytes -= movedBytes;
totalBytesWritten += movedBytes;

// Finalize everything to the output buffer.
ccStatus = CCCryptorFinal(thisEncipher,
                          ptr,
                          remainingBytes,
                          &movedBytes
                          );

totalBytesWritten += movedBytes;

if(thisEncipher) {
    (void) CCCryptorRelease(thisEncipher);
    thisEncipher = NULL;
}

if (ccStatus == kCCSuccess)
    cipherOrPlainText = [NSData dataWithBytes:(const void *)bufferPtr length:(NSUInteger)totalBytesWritten];
else
    cipherOrPlainText = nil;

if(bufferPtr) free(bufferPtr);

return cipherOrPlainText; }

在上面的代码中,我将纯文本(要加密)传递给方法

+ (NSString *) EncryptString:(NSString *)plainSourceStringToEncrypt

我如何使用 CommonCrypto 加密上面的示例字符串?

标签: iosobjective-cencryptioncommoncrypto

解决方案


推荐阅读