백엔드 개발 PHP 문제 PHP AES CBC 암호 해독 잘못된 코드를 해결하는 방법

PHP AES CBC 암호 해독 잘못된 코드를 해결하는 방법

Apr 11, 2023 am 10:30 AM

PHP에서는 암호화 및 암호 해독을 위해 AES CBC 모드를 사용하는 것이 매우 일반적입니다. 그러나 AES CBC 모드를 사용하여 암호를 해독할 때 잘못된 문자가 나타날 수 있습니다. 이 문제는 매우 일반적이지만 해결하기 쉽습니다. 이 기사에서는 PHP를 통해 AES CBC 암호화된 데이터를 정상적으로 해독하고 문자 왜곡을 방지하는 방법을 소개합니다.

1. 문제 설명

PHP에서는 openssl_encrypt 및 openssl_decrypt 함수를 사용하여 각각 암호화 및 암호 해독 작업을 수행할 수 있습니다. 예를 들어 다음 코드는 AES CBC 모드를 사용하여 데이터를 암호화합니다.

$key = '1234567890123456';
$data = 'hello world';
$iv = '1234567890123456';

$encrypted = openssl_encrypt($data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
로그인 후 복사

여기서 $key는 키, $data는 암호화할 데이터, $iv는 초기 벡터입니다. 암호화 후 $encrypted 변수는 암호화된 데이터를 가져옵니다. 이제 암호를 해독해야 합니다.

$key = '1234567890123456';
$encrypted = 'soLPpFUpwJdVEaYpuu6zRg==';
$iv = '1234567890123456';

$decrypted = openssl_decrypt($encrypted, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
echo $decrypted;
로그인 후 복사

그러나 위 코드를 실행한 후 다음과 같은 결과가 나올 수 있습니다.

纭洏鍥?J    鍗虫槑涓?
로그인 후 복사

이것은 원래 데이터 "hello world"가 아닌 횡설수설한 내용입니다. 이는 복호화 기능이 입력 매개변수의 길이에 엄격한 제한을 두기 때문에, 복호화할 데이터의 길이가 올바르지 않으면 문자 깨짐이 발생하기 때문입니다.

2. Solution

이 문제를 해결하려면 AES CBC 모드에 대한 기본 지식이 필요합니다.

AES CBC 모드에서는 암호화와 암호 해독 모두 초기화 벡터(IV)가 필요합니다. 이 초기 벡터는 암호화 및 복호화 중에 동일한 값을 사용해야 합니다. 그렇지 않으면 복호화 중 데이터 오류가 발생합니다.

초기 벡터의 길이는 암호화 알고리즘에서 요구하는 블록 크기와 동일해야 합니다. 예를 들어 128비트 AES CBC 모드를 사용하는 경우 초기화 벡터의 길이는 16바이트(128비트/8비트)여야 합니다. 이 요구 사항이 충족되지 않으면 암호 해독 중에 문자가 깨지거나 기타 문제가 발생합니다.

따라서 입력 매개변수의 길이가 요구사항을 충족하는지 확인해야 합니다. 길이가 잘못된 경우 패딩 작업이 필요합니다. 입력 데이터의 길이가 암호화 시 사용된 길이와 동일하도록 복호화 전에 패딩을 수행할 수 있습니다.

위의 문제와 해결책을 고려하여 아래와 같이 원본 코드를 AES CBC 모드의 요구 사항에 맞게 수정할 수 있습니다.

$key = '1234567890123456';
$encrypted = 'soLPpFUpwJdVEaYpuu6zRg==';
$iv = '1234567890123456';

// 检查初始向量长度是否正确
if (strlen($iv) != 16) {
    echo 'Error: IV length is not valid!';
    exit;
}

// 检查输入参数长度是否正确
$decrypted = openssl_decrypt($encrypted, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
if ($decrypted === false) {
    // 进行填充操作
    $padded_data = $encrypted . str_repeat(chr(16), 16 - (strlen($encrypted) % 16));
    $decrypted = openssl_decrypt($padded_data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);
}

echo $decrypted;
로그인 후 복사

위 코드에서 먼저 초기 벡터 길이가 올바른지 확인하세요. 올바르지 않으면 오류가 출력되고 프로그램이 종료됩니다. 다음으로, 복호화 전 입력 데이터 길이를 확인합니다. 길이가 잘못된 경우 데이터 길이가 요구 사항을 충족하는지 확인하기 위해 패딩이 수행됩니다.

이렇게 하면 해독할 때 문자가 왜곡되는 것을 방지할 수 있습니다.

3. 요약

암호화 및 복호화에 AES CBC 모드를 사용할 때 입력 매개변수의 길이가 올바르지 않으면 복호화가 실패하고 문자가 깨질 수 있습니다. 이 문제를 방지하려면 입력 매개변수의 길이를 확인하고 필요한 패딩을 수행해야 합니다.

위 내용은 PHP AES CBC 모드에서 잘못된 문자를 해독하는 문제에 대한 나의 해결책입니다. 도움이 되길 바랍니다.

위 내용은 PHP AES CBC 암호 해독 잘못된 코드를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

PHP 8 JIT (정시) 편집 : 성능 향상 방법. PHP 8 JIT (정시) 편집 : 성능 향상 방법. Mar 25, 2025 am 10:37 AM

PHP 8의 JIT 컴파일은 자주 실행되는 코드를 컴퓨터 코드로 컴파일하여 성능을 향상시켜 계산이 많은 응용 프로그램에 도움이되고 실행 시간을 줄입니다.

PHP 보안 파일 업로드 : 파일 관련 취약점 방지. PHP 보안 파일 업로드 : 파일 관련 취약점 방지. Mar 26, 2025 pm 04:18 PM

이 기사는 코드 주입과 같은 취약점을 방지하기 위해 PHP 파일 업로드 보안에 대해 설명합니다. 파일 유형 유효성 검증, 보안 저장 및 오류 처리에 중점을 두어 응용 프로그램 보안을 향상시킵니다.

PHP 암호화 : 대칭 대 비대칭 암호화. PHP 암호화 : 대칭 대 비대칭 암호화. Mar 25, 2025 pm 03:12 PM

이 기사는 PHP의 대칭 및 비대칭 암호화에 대해 논의하여 적합성, 성능 및 보안 차이를 비교합니다. 대칭 암호화는 더 빠르고 벌크 데이터에 적합하지만 안전한 키 교환에는 비대칭이 사용됩니다.

OWASP Top 10 PHP : 일반적인 취약점을 설명하고 완화하십시오. OWASP Top 10 PHP : 일반적인 취약점을 설명하고 완화하십시오. Mar 26, 2025 pm 04:13 PM

이 기사는 PHP 및 완화 전략의 OWASP Top 10 취약점에 대해 설명합니다. 주요 문제에는 PHP 응용 프로그램을 모니터링하고 보호하기위한 권장 도구가 포함 된 주입, 인증 파손 및 XSS가 포함됩니다.

PHP 인증 & amp; 승인 : 보안 구현. PHP 인증 & amp; 승인 : 보안 구현. Mar 25, 2025 pm 03:06 PM

이 기사에서는 PHP에서 강력한 인증 및 승인을 구현하여 무단 액세스를 방지하고 모범 사례를 자세히 설명하고 보안 향상 도구를 권장합니다.

PHP를 사용하여 데이터베이스에서 데이터를 검색하는 방법은 무엇입니까? PHP를 사용하여 데이터베이스에서 데이터를 검색하는 방법은 무엇입니까? Mar 20, 2025 pm 04:57 PM

기사는 PHP, 커버 단계, 보안 측정, 최적화 기술 및 Solutions의 일반적인 오류를 사용하여 데이터베이스에서 데이터 검색에 대해 논의합니다. 문자 수 : 159

PHP API 요율 제한 : 구현 전략. PHP API 요율 제한 : 구현 전략. Mar 26, 2025 pm 04:16 PM

이 기사는 토큰 버킷 및 누출 된 버킷과 같은 알고리즘을 포함하여 PHP에서 API 요율 제한을 구현하고 Symfony/Rate-Limiter와 같은 라이브러리 사용 전략에 대해 설명합니다. 또한 모니터링, 동적 조정 요율 제한 및 손도 다룹니다.

PHP CSRF 보호 : CSRF 공격 방지 방법. PHP CSRF 보호 : CSRF 공격 방지 방법. Mar 25, 2025 pm 03:05 PM

이 기사는 CSRF 토큰, 동일한 사이트 쿠키 및 적절한 세션 관리를 포함하여 PHP의 CSRF 공격을 방지하는 전략에 대해 설명합니다.

See all articles