UTF8轉(zhuǎn)成GB2312亂碼問題解決方案
最近做了一個(gè)小項(xiàng)目,遇到此類問題,記錄一下,也算是一個(gè)總結(jié)。
此項(xiàng)目分為兩部分,一個(gè)是新聞數(shù)據(jù)采集,一個(gè)是采集信息的審核,最后生成XML文件。
數(shù)據(jù)采集后的數(shù)據(jù)經(jīng)過用戶編輯完之后,要導(dǎo)出一個(gè)ACCESS文件,然后把這個(gè)文件導(dǎo)入到信息審核系統(tǒng)。在ACCESS庫中存儲(chǔ)新聞信息的字段類型是ntext類型,而審核系統(tǒng)庫中對(duì)應(yīng)的是varchar(max)類型的字段,導(dǎo)入之后,發(fā)現(xiàn)有的空白字符會(huì)出現(xiàn)亂碼,表現(xiàn)為問號(hào)(?),其實(shí)經(jīng)過后面的測(cè)試,這不是空白(空格)字符,而一個(gè)特殊字符,怎么辦?經(jīng)過幾番測(cè)試后發(fā)現(xiàn),varchar(max)類型要改成nvarchar(max)類型,這樣導(dǎo)入的數(shù)據(jù)就不會(huì)再有此類問題了。
但后面的測(cè)試過程中,又會(huì)發(fā)現(xiàn)對(duì)導(dǎo)入后的采集信息更改(通過.net程序編輯功能)后,數(shù)據(jù)庫中此條信息又出現(xiàn)了亂碼問題,研究后發(fā)現(xiàn)在插入語句中這樣寫就不會(huì)出現(xiàn)此類問題了,如insert into 表名 (news)values(N'"+更新后的值+""),為什么加N?去百度一下就明白了。
到此,心中總算得到安慰,但后面的問題又讓人陷入郁悶之中。。。。。。
審核完的信息要生成XML類型的文件,并且XML要采用GB2312編碼,因?yàn)椴杉男侣劸W(wǎng)站,有很多網(wǎng)站采用的是UTF8編碼,這樣在轉(zhuǎn)化的過程中又出現(xiàn)亂碼(還是那個(gè)“空白”特殊字符搞的),怎么辦?網(wǎng)上介紹的把UTF8轉(zhuǎn)化成GB2312就可以了,但實(shí)際發(fā)現(xiàn),還是解決不了問題,這下弄的一上午為了解決這個(gè)問題,最后還是沒有辦法,正郁悶之時(shí),突然想到通過VS的調(diào)試功能來看看這個(gè)特殊字符究竟是什么玩意,最后通過把數(shù)據(jù)庫的此字段值讀取出來之后,然后轉(zhuǎn)化成字符數(shù)組,content.ToCharArray(); 一個(gè)一個(gè)的看,發(fā)現(xiàn),導(dǎo)致亂碼的這個(gè)字符是' '注意引號(hào)中的空白,這不是一個(gè)空格,而是一個(gè)在GB2312中無法識(shí)別的特殊字符,此時(shí)突然想到,能不能把這個(gè)字符的值直接用空格替換呢?馬上行動(dòng),果然,解決了亂碼問題。真求郁悶,這一個(gè)毛玩意浪費(fèi)了一半天時(shí)間。
注意,必須要用調(diào)試出來的這個(gè)值(因?yàn)檫@才是真正的導(dǎo)致亂碼的那個(gè)特殊字符),調(diào)試的時(shí)候在即使窗體中粘貼。
content = content.Replace(" ", " ");
上一篇:存儲(chǔ)于xml中需要的HTML轉(zhuǎn)義代碼
欄 目:XML/RSS
下一篇:powerbuilder(pb)中 xml的應(yīng)用一例
本文標(biāo)題:UTF8轉(zhuǎn)成GB2312亂碼問題解決方案
本文地址:http://mengdiqiu.com.cn/a1/XML_RSS/11706.html
您可能感興趣的文章


閱讀排行
- 1C語言 while語句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹的示例代碼(圣誕
- 3利用C語言實(shí)現(xiàn)“百馬百擔(dān)”問題方法
- 4C語言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-11關(guān)于XSL - XSL教程
- 01-11WMLScript的語法基礎(chǔ)
- 01-11選擇模式 - XSL教程 - 2
- 01-11WML學(xué)習(xí)之五 顯示表單
- 01-11WML學(xué)習(xí)之三 顯示文本
- 01-11匹配模式 - XSL教程 - 4
- 01-11WML語法大全與相關(guān)介紹第1/3頁
- 01-11XPath入門 - XSL教程 - 3
- 01-11測(cè)試模式 - XSL教程 - 5
- 01-11WAP建站W(wǎng)ML語言語法基礎(chǔ)教程第1/6頁
隨機(jī)閱讀
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-11Mac OSX 打開原生自帶讀寫NTFS功能(圖文
- 01-11ajax實(shí)現(xiàn)頁面的局部加載
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10使用C語言求解撲克牌的順子及n個(gè)骰子
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10delphi制作wav文件的方法
- 04-02jquery與jsp,用jquery
- 01-10SublimeText編譯C開發(fā)環(huán)境設(shè)置