> 데이터 베이스 > MySQL 튜토리얼 > 손상된 직렬화 문자열의 'unserialize(): Error at offset' 오류를 어떻게 수정할 수 있습니까?

손상된 직렬화 문자열의 'unserialize(): Error at offset' 오류를 어떻게 수정할 수 있습니까?

Patricia Arquette
풀어 주다: 2024-12-14 06:28:14
원래의
776명이 탐색했습니다.

How Can I Fix

손상된 직렬화된 문자열 복구: 잘못된 바이트 수 오류 해결

문제:

"unserialize( ) [function.unserialize]: 직렬화 해제를 시도할 때 오프셋 오류 발생" 손상된 직렬화된 문자열. 이 오류는 문자열에 잘못된 바이트 수 길이가 포함되어 있어 데이터가 잘림을 나타냅니다.

원인:

요소 길이 계산이 잘못되어 직렬화 데이터가 잘못되었습니다.

빠르게 수정:

요소 길이 다시 계산: 직렬화된 각 요소의 실제 길이를 계산하고 해당 바이트 수 값을 업데이트합니다.

예를 들어 직렬화된 다음을 고려하세요. 문자열:

$data = 'a:10:{s:16:"submit_editorial";b:0;s:15:"submit_orig_url";s:13:"www.bbc.co.uk";s:12:"submit_title";s:14:"No title found";s:14:"submit_content";s:12:"dnfsdkfjdfdf";s:15:"submit_category";i:2;s:11:"submit_tags";s:3:"bbc";s:9:"submit_id";b:0;s:16:"submit_subscribe";i:0;s:15:"submit_comments";s:4:"open";s:5:"image";s:19:"C:fakepath100.jpg";}';
로그인 후 복사

다음 코드를 사용하여 요소를 다시 계산하고 수정합니다. 길이:

$data = preg_replace('!s:(\d+):"(.*?)";!e', "'s:'.strlen('').':\"\";'", $data);
로그인 후 복사

적절한 인용 확인: 직렬화된 요소에 값을 할당할 때 큰따옴표(") 대신 작은따옴표(')를 사용하세요. 후자는 예상치 못한 잘림을 유발할 수 있습니다.

추가 주의 사항:

  • SQL 주입 공격을 방지하려면 직렬화하기 전에 addlashes()를 사용하여 값에 슬래시를 추가하세요.
  • 플랫폼 간 호환성을 위해 utf8_encode()를 사용하여 UTF-8 문자를 인코딩하세요. .
  • base64_encode() 및 보다 안전한 데이터베이스 저장 및 직렬화된 데이터 검색을 위한 base64_decode().

향후 직렬화 오류 감지:

다음 함수를 사용하여 요소를 식별할 수 있습니다. 길이 차이를 확인하고 손상 원인을 찾는 데 도움을 줍니다.

function findSerializeError($data1) {
    // ... (code omitted for brevity)
}
로그인 후 복사

이 기능을 사용하면 다음을 수행할 수 있습니다. 손상된 데이터를 분석하여 문제가 되는 요소를 파악하고 그에 따라 수정합니다.

위 내용은 손상된 직렬화 문자열의 'unserialize(): Error at offset' 오류를 어떻게 수정할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿