Linux系統(tǒng)中有時會用戶們會遇到SecureCRT連接到linux服務(wù)器之后出現(xiàn)亂碼,那么我們要怎么解決這個問題呢?其實方法并不難,現(xiàn)在就和小編一起來看看吧。
問題:中文字符顯示出來成了亂碼(當前系統(tǒng)編碼為UTF-8,CRT編碼為UTF-8)
原則:保持文件、系統(tǒng)、CRT三者的編碼格式一致即可
解決方法:
方法1:
a、查看文件的編碼格式
在Vim中可以直接查看文件編碼
?。簊et fileencoding
fileencoding=latin1
使用命令查看文件編碼
# file Mysql2.txt
Mysql2.txt: ISO-8859 text, with CRLF line terminators
ISO-8859 又稱 Latin或“西歐語言”
b、查看Linux系統(tǒng)使用的編碼是什么格式,將系統(tǒng)的編輯修改成en_US(如果看到文件編輯為UTF-8或GBK等其他的,這里改成UTF-8或GBK等即可)
# LANG=en_US
# echo $LANG
en_US
c、 修改并修改Secure CRT的設(shè)置(如果看到文件編輯為UTF-8或GBK等其他的,這里改成UTF-8或GBK等即可)
右擊–選擇session的屬性進行查看,修改成default
方法2:
a、查看文件的編碼格式
在Vim中可以直接查看文件編碼
?。簊et fileencoding
fileencoding=latin1
使用命令查看文件編碼
# file Mysql2.txt
Mysql2.txt: ISO-8859 text, with CRLF line terminators
ISO-8859 又稱 Latin或“西歐語言”
由于latin1 是一種非常寬松的編碼方式,任何一種編碼方式得到的文本,用 latin1 進行解碼,都不會發(fā)生解碼失敗——當然,解碼得到的結(jié)果自然也就是理所當然的“亂碼”。
讓系統(tǒng)能盡量識別文件正確的編碼(編輯~/.vimrc文件):
# vim ~/.vimrc
set encoding=utf-8 fileencodings=ucs-bom,utf-8,cp936
set fileencodings=ucs-bom,utf-8,cp936,gb18030,big5,euc-jp,euc-kr,latin1
設(shè)置完畢后,就可以讓vim自動識別文件編碼(可以自動識別UTF-8或者GBK編碼的文件),其實就是依照 fileencodings提供的編碼列表嘗試,如果沒有找到合適的編碼,就用latin-1(ASCII)編碼打開。
再次查看編碼
:set fileencoding
fileencoding=cp936
這時,應該可以看到vim的時候能正常顯示中文了,但是cat的時候還是不行
b、給文件轉(zhuǎn)碼,將cp938格式轉(zhuǎn)化為UTF-8(直接從latin1轉(zhuǎn)的時候不會報錯,但轉(zhuǎn)出來會還是亂的)
# iconv -f cp936 -t UTF-8 Mysql2.txt -o Mysql8.txt
-f : from
-t : to
-o: output
c、查看Linux系統(tǒng)使用的編碼是什么格式,將系統(tǒng)的編輯修改成en_US.UTF-8
# LANG=en_US.UTF-8
# echo $LANG
en_US.UTF-8
d、 修改并修改Secure CRT的設(shè)置
右擊–選擇session的屬性進行查看,修改成UTF-8
如果你在使用Linux電腦時,也遇到了這個問題,那么就用這種方法讓你的SecureCRT順利連接到linux服務(wù)器吧。