php openssl_encrypt AES-128-ECB iOS

function aesEncrypt(){
        $data = openssl_encrypt('5ddbf06d-adfd-10f4-de2b-f39b13e8eb8d_1604996361','AES-128-ECB',decbin(1604996361));
        echo 'encrypt='.$data.PHP_EOL;
        return $data;
}

function aesDecrypt($secretData){
        $data = openssl_decrypt($secretData,'AES-128-ECB',decbin(1604996361));
        echo 'decrypt='.$data.PHP_EOL;
        $arrU   = explode('_',$data);
        $uuid   = $arrU[0];
        echo 'decrypt11111='.$uuid.PHP_EOL;
}


加密 5ddbf06d-adfd-10f4-de2b-f39b13e8eb8d_1604996361


輸出aZkNWORB4zD095e/GLIj0EL2Q20r7tcICMwZ9rRigwjAqhaSNJs7EcMYuKxNE1JT


https://www.php.net/manual/zh/function.openssl-encrypt.php

可知keyphp里的decbin(1604996361),iv為空串。


php在線 https://tool.lu/coderunner/decbin(1604996361)為字符串1011111101010100100110100001001


使用 https://github.com/WelkinXie/AESCipher-iOS 并改其內(nèi)部kv為空串


新建項(xiàng)目mac commandline 驗(yàn)證通過


#import <Foundation/Foundation.h>
#import <CommonCrypto/CommonCryptor.h>
NSString const *kInitVector = @"";
size_t const kKeySize = kCCKeySizeAES128;
NSData * cipherOperation(NSData *contentData, NSData *keyData, CCOperation operation) {
    NSUInteger dataLength = contentData.length;
    void const *initVectorBytes = [kInitVector dataUsingEncoding:NSUTF8StringEncoding].bytes;
    void const *contentBytes = contentData.bytes;
    void const *keyBytes = keyData.bytes;
    size_t operationSize = dataLength + kCCBlockSizeAES128;
    void *operationBytes = malloc(operationSize);
    if (operationBytes == NULL) {
        return nil;
    }
    size_t actualOutSize = 0;
    CCCryptorStatus cryptStatus = CCCrypt(operation,
                                          kCCAlgorithmAES,
                                          kCCOptionECBMode | kCCOptionPKCS7Padding,
                                          keyBytes,
                                          kKeySize,
                                          initVectorBytes,
                                          contentBytes,
                                          dataLength,
                                          operationBytes,
                                          operationSize,
                                          &actualOutSize);
    if (cryptStatus == kCCSuccess) {
        return [NSData dataWithBytesNoCopy:operationBytes length:actualOutSize];
    }
    free(operationBytes);
    operationBytes = NULL;
    return nil;
}
NSString * aesEncryptString(NSString *content, NSString *key) {
    NSCParameterAssert(content);
    NSCParameterAssert(key);
    NSData *contentData = [content dataUsingEncoding:NSUTF8StringEncoding];
    NSData *keyData = [key dataUsingEncoding:NSUTF8StringEncoding];
    NSData *encrptedData = cipherOperation(contentData, keyData, kCCEncrypt);
    return [encrptedData base64EncodedStringWithOptions:NSDataBase64EncodingEndLineWithLineFeed];
}
int main(int argc, const char * argv[]) {
    @autoreleasepool {
        NSLog(@"---%@---", aesEncryptString(@"5ddbf06d-adfd-10f4-de2b-f39b13e8eb8d_1604996361", @"1011111101010100100110100001001"));
    }
    return 0;
}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容