程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP連接MSSQL顯示中文時為亂碼

PHP連接MSSQL顯示中文時為亂碼

編輯:關於PHP編程

      PHP連接MSSQL顯示中文時為亂碼主要是因為編碼問題了,我們只要懂得一對於數據庫與頁面的編碼統一處理就可以解決了,下面一起來看看下文。

      因為一直在使用 windows 下的 PHP 開發,用的是 mysql 數據庫,偶爾也會遇到查詢記錄的亂碼,那是因為 php 編碼不支持中文進行導致的,直接將其進行編碼解碼即可解決,所以在 windows 平台下還是比較容易解決的。

      今天在幫一個客戶進行 liunx 下維護 mssql 數據庫的操作,因站點被攻擊的原因,一直無法進行打開站點,折騰了很久,終於連接上mssql了,今天來了嘗試下查詢,麼問題!

      可是出來的記錄 中文 顯示是?號或者就是一堆黑框框,這是典型的編碼不對,於是查看了下php.ini關於mssql的這一塊配置,發現有一項配置”mssql.charset”這一項,我配置成 “utf8”,成功解決亂碼。

      因為我的程序頁面用的是utf8所以配置成這樣,如果是GBK/GB2312 就配置長相應的編碼就應該能解決,當然遇到這樣的問題還是要看相應情況的,這裡還是建議如果能修改配置文件盡可能的去修改配置文件,因為這樣才能一勞永逸的解決掉問題。

      例子

     代碼如下  

    $serverName = "127.0.0.1,1433";
    $connectionInfo = array( "UID"=>"sa",
    "PWD"=>"123456",
    "Database"=>"NopCommerce",
    "CharacterSet"=>"UTF-8"); // 這一行是重點
    $conn = sqlsrv_connect($serverName, $connectionInfo);

      注意事項:

      編碼常用的是utf8-general-ci

      不只是表要統一,要統一的總共有四處

      一是:數據庫類型,其中包括,數據庫,表,字段三處都要統一,可以檢查一下

      二是:文件的編碼類型,你若用dw或editplus可以查看頁面編碼,不同需修改

      三是:訪問數據庫時的設置既set NAMES utf8;

      四是:浏覽器顯示方式,添加meta屬性

      不管用GBK,GB2312,這四處必須統一,看你缺少了哪一步

      用PHP操作MSSQL比在ASP連接MYSQL要簡單,所以,當需要MSSQL與MYSQL並存時,用PHP連接MSSQL來操作MYSQL與MSSQL並存比較簡單好用.如果是ASP連接MYSQL,需要安裝一個MYSQL驅動,默認windows的ODBC沒有安裝,很遺憾...

      1.在web服務器上至少安裝了mssql的客戶端

      2.打開php.ini把;extension=php_mssql.dll前面的分號去掉

      有必要話:需要制定extension_dir

      3.推薦使用php<=4.0.9<=5.0.3目前我還沒有連接成功過4.010和5.0.3

      4.數據庫的連接分頁可以到phpe.net上獲取到相應的class

    1. 上一頁:
    2. 下一頁:
    Copyright © 程式師世界 All Rights Reserved