>

코드 :

$result = mcrypt_ecb (MCRYPT_3DES, 'test', $string, MCRYPT_ENCRYPT);

$string 를 코드 인코딩 . 그러나 어떻게 $result 를 디코딩합니까? ?

$result 를 어떻게 해독하는지 알려주세요  ?


  • 답변 # 1

    복호화 :

    //Encryption
    $result = mcrypt_ecb (MCRYPT_3DES, 'test', $string, MCRYPT_ENCRYPT);
    //Decryption
    $decrypt_result = mcrypt_ecb (MCRYPT_3DES, 'test', $result, MCRYPT_DECRYPT);
    
    

    인수에서 모드를 변경하고 암호화 된 값을 전달해야합니다.

    참고 : mcrypt_generic ()도 PHP 7.1.0부터 더 이상 사용되지 않습니다.

    설명서 읽기 : http://www.php.net/manual/en/function.mcrypt-ecb.php.

    mcrypt_generic ()을 사용하는 것이 좋습니다.

    $cc = 'my secret text';
    $key = 'my secret key';
    $iv = '12345678';
    $cipher = mcrypt_module_open(MCRYPT_BLOWFISH,'','cbc','');
    mcrypt_generic_init($cipher, $key, $iv);
    $encrypted = mcrypt_generic($cipher,$cc);
    mcrypt_generic_deinit($cipher);
    mcrypt_generic_init($cipher, $key, $iv);
    $decrypted = mdecrypt_generic($cipher,$encrypted);
    mcrypt_generic_deinit($cipher);
    echo "encrypted : ".$encrypted;
    echo "<br>";
    echo "decrypted : ".$decrypted;
    
    

  • 답변 # 2

    https://gist.github.com/joashp/a1ae9cb30fa533f4ad94 참조

    음식을 위해 일하는 Joashp의 OpenSSL을 사용하여 간단한 PHP 암호화 및 해독

    /**
     * simple method to encrypt or decrypt a plain text string
     * initialization vector(IV) has to be the same when encrypting and decrypting
     * 
     * @param string $action: can be 'encrypt' or 'decrypt'
     * @param string $string: string to encrypt or decrypt
     *
     * @return string
     */
    function encrypt_decrypt($action, $string) {
        $output = false;
        $encrypt_method = "AES-256-CBC";
        $secret_key = 'This is my secret key';
        $secret_iv = 'This is my secret iv';
        // hash
        $key = hash('sha256', $secret_key);
        // iv - encrypt method AES-256-CBC expects 16 bytes - else you will get a warning
        $iv = substr(hash('sha256', $secret_iv), 0, 16);
        if ( $action == 'encrypt' ) {
            $output = openssl_encrypt($string, $encrypt_method, $key, 0, $iv);
            $output = base64_encode($output);
        } else if( $action == 'decrypt' ) {
            $output = openssl_decrypt(base64_decode($string), $encrypt_method, $key, 0, $iv);
        }
        return $output;
    }
    $plain_txt = "This is my plain text";
    echo "Plain Text =" .$plain_txt. "\n";
    $encrypted_txt = encrypt_decrypt('encrypt', $plain_txt);
    echo "Encrypted Text = " .$encrypted_txt. "\n";
    $decrypted_txt = encrypt_decrypt('decrypt', $encrypted_txt);
    echo "Decrypted Text =" .$decrypted_txt. "\n";
    if ( $plain_txt === $decrypted_txt ) echo "SUCCESS";
    else echo "FAILED";
    echo "\n";
    
    

  • 답변 # 3

    ecb 모드 isntead에서 mcrypt_encrypt를 사용해야합니다. mcrypr_ecb는 더 이상 사용되지 않습니다.

    암호 해독을 위해 다음을 사용할 수 있습니다 : mcrypt_decrypt

  • 답변 # 4

    참고 :이 기능은 PHP 7.1.0부터 더 이상 사용되지 않습니다. 이 기능에 의존하지 않는 것이 좋습니다.

    MCRYPT_DECRYPT를 사용해보십시오

    $result = mcrypt_ecb (MCRYPT_3DES, 'test', $string, MCRYPT_ENCRYPT);
    $decrypted_text = mcrypt_ecb(MCRYPT_DES, 'test', $result, MCRYPT_DECRYPT);
    echo rtrim($decrypted_text);
    
    

  • 이전 typescript - Ionic4 Angular에서 커패시터로 다운로드 한 파일을 어떻게 저장합니까?
  • 다음 c# - MDLC 및 NDLC를 사용하는 스레드에서 이상한 NLog 동작