溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何解決php oracle亂碼的問題

發(fā)布時(shí)間:2020-07-28 09:24:02 來源:億速云 閱讀:248 作者:Leah 欄目:編程語言

如何解決php oracle亂碼的問題?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過這篇文章希望你能解決這個(gè)問題。

php oracle亂碼的解決辦法:首先通過PLSQL運(yùn)行“select * from V$NLS_PARAMETERS;”獲取oracle的字符集;然后在客戶端正確的設(shè)置服務(wù)端的字符集信息即可。

PHP Oracle 中文亂碼問題

通常缺省配置連接Oracle在處理中文時(shí)都會(huì)遇到亂碼問題,其實(shí)絕大部分人都知道在客戶端連接Oracle服務(wù)端前首先要在客戶端正確的設(shè)置服務(wù)端的字符集信息,通過PLSQL運(yùn)行“select * from V$NLS_PARAMETERS;” 即可獲取oracle的字符集,變量NLS_CHARACTERSET對(duì)應(yīng)的就是我們需要的字符集,比如我這里就是“WE8ISO8859P1”

設(shè)置字符集的方法如下:

方法一: 連接前設(shè)置環(huán)境變量

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

相關(guān)介紹:

Oracle一般指甲骨文公司;

甲骨文公司,全稱甲骨文股份有限公司(甲骨文軟件系統(tǒng)有限公司),是全球最大的企業(yè)級(jí)軟件公司,總部位于美國加利福尼亞州的紅木灘。1989年正式進(jìn)入中國市場。2013年,甲骨文已超越 IBM ,成為繼 Microsoft 后全球第二大軟件公司。

方法二:連接時(shí)設(shè)置環(huán)境變量

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

但是很快你會(huì)發(fā)現(xiàn)通過上述設(shè)置讀取的中文數(shù)據(jù)在不設(shè)置編碼的情況下可以正常顯示,而一旦在頁面(假如頁面的字符集為UTF8)中使用則仍為亂碼,

并且即便做轉(zhuǎn)換 從 we8iso8859p1 -> utf-8  依舊為亂碼。

其實(shí)仔細(xì)研究后發(fā)現(xiàn)oci8 以數(shù)據(jù)庫編碼WE8ISO8859P1獲取數(shù)據(jù)后 自動(dòng)轉(zhuǎn)換為操作系統(tǒng)缺省的編碼格式,假如我使用的操作系統(tǒng)缺省編碼為GBK,則實(shí)際上通過OCI8讀取后,字符的編碼即為GBK, 因此在頁面使用的時(shí)候編碼轉(zhuǎn)換應(yīng)該為  從 GBK -> utf-8 :

echo iconv('GBK','utf-8',$vo["USERNAME"]);

看完上述內(nèi)容,你們掌握如何解決php oracle亂碼的問題的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI