php oracle 문자 깨짐은 문자 세트 정보의 잘못된 구성으로 인해 발생합니다. 해결 방법은 PLSQL을 통해 "select * from V$NLS_PARAMETERS;"를 실행하여 oracle 문자 세트를 가져오고 올바른 문자 세트를 재설정하는 것입니다.
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!