目錄
oci8
首頁 後端開發 PHP問題 如何解決php 連線oracle亂碼問題

如何解決php 連線oracle亂碼問題

Oct 27, 2021 am 10:43 AM
oracle php

php連接oracle亂碼的解決方法:1、設定環境變數;2、取得oracle的字元集;3、透過「iconv('GBK','utf-8',$vo["USERNAME" ]);”方法轉換編碼即可。

如何解決php 連線oracle亂碼問題

本文操作環境:Windows7系統、PHP7.1版、DELL G3電腦

如何解決php 連線oracle亂碼問題?

PHP 連線Oracle及亂碼問題筆記

#1. PHP連線Oracle

步驟1. 擷取Oracle Instant Client核心DLL 

 從OTN 的Instant Client 頁面下載用於Windows 的Instant Client Basic(11g) 套件。此壓縮檔案的大小約為 48MB。建立子目錄(例如,c:\instantclient11_2),然後從壓縮檔案複製以下函式庫到apache\bin目錄下:

oraociei11.dll 
orannzsbb11.dll 
oci.dll
登入後複製

這三個檔案的總大小大約是 126MB。
要使用 PHP 舊版的「oracle」擴充(在 php.ini 中使用「extension=php_oracle.dll」啟用),則複製 ociw32.dll 而非 oci.dll。

步驟2:編輯環境變量,將 c:\instantclient11_2 加入 PATH 中(系統環境變數位於其他 Oracle 目錄之前)。

例如,在Win7 上,依序點選“電腦”->右鍵“屬性”->“進階系統設定”->“進階”->“環境變數”,編輯系統變量清單中的PATH。
如果使用了 tnsnames.ora 檔案定義 Oracle Net 服務名稱,則將 tnsnames.ora 複製到 c:\instantclient11_2,並將使用者環境變數 TNS_ADMIN 設為 c:\instantclient11_2。

步驟3:開啟php的oci8擴充 編輯 php.ini,把 OCI8 擴充打開,也就是去掉註解符號‘;’:extension=php_oci8.dll

#重新啟動 Apache。重啟伺服器(伺服器必須重啟,不然環境變數不起效)

重啟後透過phpinfo() 看到以下內容則表示設定成功: 

oci8

##Collections support enabled
#OCI8 Supportenabled
#Version1.4.7
Revision$Id: bf2eaf558b050b6d2e6d098bed6345af7e842ea4 $
Active Persistent Connections0
Active Connections0
Oracle Run-time Client Library Version11.2.0.3.0
Oracle Instant Client Version11.2
Temporary Lob supportenabled
DirectiveLocal Valueoci8.connection_classno valueno value##oci8.default_prefetch 100100#oci8.eventsOffOff#oci8.max_persistent-1-1oci8.old_oci_close_semanticsOffOffoci8.persistent_timeout#-1-1oci8.ping_interval6060oci8.privileged_connectOffOff#oci8.statement_cache_size2020

2. PHP Oracle 中文乱码问题

通常缺省配置连接Oracle在处理中文时都会遇到乱码问题,其实绝大部分人都知道在客户端连接Oracle服务端前首先要在客户端正确的设置服务端的字符集信息,通过PLSQL运行“select * from V$NLS_PARAMETERS;” 即可获取oracle的字符集,变量NLS_CHARACTERSET对应的就是我们需要的字符集,比如我这里就是“WE8ISO8859P1”

设置字符集的方法如下:

方法一: 连接前设置环境变量

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

方法二:连接时设置环境变量

 $conn=oci_new_connect($config['username'], $config['password'],$config['database'],'we8iso8859p1');
登入後複製

但是很快你会发现通过上述设置读取的中文数据在不设置编码的情况下可以正常显示,而一旦在页面(假如页面的字符集为UTF8)中使用则仍为乱码,

并且即便做转换 从 we8iso8859p1 -> utf-8 依旧为乱码。

其实仔细研究后发现oci8 以数据库编码WE8ISO8859P1获取数据后 自动转换为操作系统缺省的编码格式,假如我使用的操作系统缺省编码为GBK,则实际上通过OCI8读取后,字符的编码即为GBK, 因此在页面使用的时候编码转换应该为 从 GBK -> utf-8 :

 echo iconv('GBK','utf-8',$vo["USERNAME"]);
登入後複製

推荐学习:《PHP视频教程

以上是如何解決php 連線oracle亂碼問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南 Dec 24, 2024 pm 04:42 PM

適用於 Ubuntu 和 Debian 的 PHP 8.4 安裝和升級指南

CakePHP 日期和時間 CakePHP 日期和時間 Sep 10, 2024 pm 05:27 PM

CakePHP 日期和時間

CakePHP 檔案上傳 CakePHP 檔案上傳 Sep 10, 2024 pm 05:27 PM

CakePHP 檔案上傳

CakePHP 路由 CakePHP 路由 Sep 10, 2024 pm 05:25 PM

CakePHP 路由

CakePHP 專案配置 CakePHP 專案配置 Sep 10, 2024 pm 05:25 PM

CakePHP 專案配置

討論 CakePHP 討論 CakePHP Sep 10, 2024 pm 05:28 PM

討論 CakePHP

CakePHP 快速指南 CakePHP 快速指南 Sep 10, 2024 pm 05:27 PM

CakePHP 快速指南

如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 如何設定 Visual Studio Code (VS Code) 進行 PHP 開發 Dec 20, 2024 am 11:31 AM

如何設定 Visual Studio Code (VS Code) 進行 PHP 開發

See all articles
##Master Value