關于SecureCRT連接到linux服務器之后出現亂碼問題我們通常是設置編輯所導致了,具體解決辦法小編就為各位介紹一下吧.
問題:中文字符顯示出來成了亂碼,當前系統編碼為UTF-8,CRT編碼為UTF-8.
原則:保持文件、系統、CRT三者的編碼格式一致即可.
處理過程:
方法1:a、查看文件的編碼格式,在Vim中可以直接查看文件編碼.
:set fileencoding
fileencoding=latin1
使用命令查看文件編碼:
# file Mysql2.txt
Mysql2.txt: ISO-8859 text, with CRLF line terminators
ISO-8859 又稱 Latin或“西歐語言”
b、查看Linux系統使用的編碼是什么格式,將系統的編輯修改成en_US(如果看到文件編輯為UTF-8或GBK等其他的,這里改成UTF-8或GBK等即可).
- # LANG=en_US
- # echo $LANG
- en_US
c、修改并修改Secure CRT的設置,如果看到文件編輯為UTF-8或GBK等其他的,這里改成UTF-8或GBK等即可,右擊–選擇session的屬性進行查看,修改成default.
方法2:a、查看文件的編碼格式,在Vim中可以直接查看文件編碼.
- :set fileencoding
- fileencoding=latin1
使用命令查看文件編碼.
- # file Mysql2.txt
- Mysql2.txt: ISO-8859 text, with CRLF line terminators
ISO-8859 又稱 Latin或“西歐語言”,由于latin1 是一種非常寬松的編碼方式,任何一種編碼方式得到的文本,用 latin1 進行解碼,都不會發生解碼失敗——當然,解碼得到的結果自然也就是理所當然的“亂碼”.
讓系統能盡量識別文件正確的編碼(編輯~/.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
設置完畢后,就可以讓vim自動識別文件編碼,可以自動識別UTF-8或者GBK編碼的文件,其實就是依照 fileencodings提供的編碼列表嘗試,如果沒有找到合適的編碼,就用latin-1(ASCII)編碼打開,再次查看編碼:
- :set fileencoding
- fileencoding=cp936
這時,應該可以看到vim的時候能正常顯示中文了,但是cat的時候還是不行.
b、給文件轉碼,將cp938格式轉化為UTF-8,直接從latin1轉的時候不會報錯,但轉出來會還是亂的.
- # iconv -f cp936 -t UTF-8 Mysql2.txt -o Mysql8.txt
- -f : from --Vevb.com
- -t : to
- -o: output
c、查看Linux系統使用的編碼是什么格式,將系統的編輯修改成en_US.UTF-8.
- # LANG=en_US.UTF-8
- # echo $LANG
- en_US.UTF-8
d、修改并修改Secure CRT的設置,右擊–選擇session的屬性進行查看,修改成UTF-8.
新聞熱點
疑難解答