>백엔드 개발 >PHP 문제 >PHP 오라클이 깨졌을 때 문제를 해결하는 방법

PHP 오라클이 깨졌을 때 문제를 해결하는 방법

藏色散人
藏色散人원래의
2020-07-21 11:14:462487검색

php oracle 문자 깨짐은 문자 세트 정보의 잘못된 구성으로 인해 발생합니다. 해결 방법은 PLSQL을 통해 "select * from V$NLS_PARAMETERS;"를 실행하여 oracle 문자 세트를 가져오고 올바른 문자 세트를 재설정하는 것입니다.

PHP 오라클이 깨졌을 때 문제를 해결하는 방법

PHP Oracle 중국어 왜곡 문제

일반적으로 중국어를 처리할 때 Oracle에 연결할 때 기본 구성에서 잘못된 문제가 발생한다는 것을 대부분의 사람들은 알고 있습니다. 먼저 서버 측의 문자 세트 정보를 올바르게 설정하고 PLSQL을 통해 "select * from V$NLS_PARAMETERS;"를 실행하여 Oracle의 문자 세트를 가져옵니다. 예를 들어, 여기서는 " WE8ISO8859P1"

추천: "PHP Tutorial"

문자셋 설정 방법은 다음과 같습니다.

방법 1: 연결 전 환경 변수 설정

putenv("NLS_LANG=AMERICAN_AMERICA.WE8ISO8859P1");
$conn=oci_new_connect($config['username'], $config['password'],$config['database']);

방법 2: 연결 시 환경 변수 설정

$conn=oci_new_connect($config['username'], $config['password'],$config['database'],'we8iso8859p1');

하지만 곧 그럴 것입니다. 위 설정을 통해 읽은 중국어 데이터는 인코딩을 설정하지 않고도 정상적으로 표시될 수 있지만, 일단 페이지에서 사용되면(페이지의 문자 집합이 UTF8인 경우) 계속해서 표시되는 것으로 나타났습니다.

we8iso8859p1 -> 에서 변환이 완료되더라도 여전히 utf-8이 깨집니다.

사실, 주의 깊게 연구한 결과, oci8은 WE8ISO8859P1 데이터베이스 인코딩으로 데이터를 얻은 후 자동으로 데이터를 운영 체제의 기본 인코딩 형식으로 변환한다는 것을 발견했습니다. 사실 OCI8을 통해 읽은 후 문자 인코딩은 GBK이므로 페이지 사용 시 인코딩 변환은 From GBK -> utf-8:

 echo iconv('GBK','utf-8',$vo["USERNAME"]);
이어야 합니다.

위 내용은 PHP 오라클이 깨졌을 때 문제를 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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