How to encode and decode Broken Chinese/Unicode characters?

27,132

Solution 1

What is happening when you save the "bad" string in a text file with a meta tag declaring the correct encoding is that your text editor is saving the file with Windows-1252 encoding, but the browser is reading the file and interpreting it as UTF-8. Since the "bad" string is incorrectly decoded UTF-8 bytes with the Windows-1252 encoding, you are reversing the process by encoding the file as Windows-1252 and decoding as UTF-8.

Here's an example:

using System.Text;
using System.Windows.Forms;

namespace Demo
{
    class Program
    {
        static void Main(string[] args)
        {
            string s = "具有靜電產生裝置之影像輸入裝置"; // Unicode
            Encoding Windows1252 = Encoding.GetEncoding("Windows-1252");
            Encoding Utf8 = Encoding.UTF8;
            byte[] utf8Bytes = Utf8.GetBytes(s); // Unicode -> UTF-8
            string badDecode = Windows1252.GetString(utf8Bytes); // Mis-decode as Latin1
            MessageBox.Show(badDecode,"Mis-decoded");  // Shows your garbage string.
            string goodDecode = Utf8.GetString(utf8Bytes); // Correctly decode as UTF-8
            MessageBox.Show(goodDecode, "Correctly decoded");

            // Recovering from bad decode...
            byte[] originalBytes = Windows1252.GetBytes(badDecode);
            goodDecode = Utf8.GetString(originalBytes);
            MessageBox.Show(goodDecode, "Re-decoded");
        }
    }
}

Even with correct decoding, you'll still need a font that supports the characters being displayed. If your default font doesn't support Chinese, you still might not see the correct characters.

The correct thing to do is figure out why the string you have was decoded as Windows-1252 in the first place. Sometimes, though, data in a database is stored incorrectly to begin with and you have to resort to these games to fix the problem.

Solution 2

string test = "敭畳灴獩楫n"; //incoming data. must be mesutpiskin 

byte[] bytes = Encoding.Unicode.GetBytes(test);

string s = string.Empty;

for (int i = 0; i < bytes.Length; i++)
{
    s += (char)bytes[i];
}

s = s.Trim((char)0);

MessageBox.Show(s);
//s=mesutpiskin 
Share:
27,132
Jeroen Bleijenberg
Author by

Jeroen Bleijenberg

programming like or hate it? i'm not sure. can't live with or without it. hope to learn more and find the true meaning of life through codes. why soo serious?

Updated on January 04, 2022

Comments

  • Jeroen Bleijenberg
    Jeroen Bleijenberg over 2 years

    I've tried googling around but wasn't able to find what charset that this text below belongs to:

    具有éœé›»ç”¢ç”Ÿè£ç½®ä¹‹å½±åƒè¼¸å…¥è£ç½®
    

    But putting <meta http-equiv="Content-Type" Content="text/html; charset=utf-8"> and keeping that string into an HTML file, I was able to view the Chinese characters properly:

    具有靜電產生裝置之影像輸入裝置 
    

    So my question is:

    1. What tools can I use to detect the character set of this text?

    2. And how do I convert/encode/decode them properly in C#?

    Updates: For completion sake, I've updated this test.

       [TestMethod]
        public void TestMethod1()
        {
            string encodedText = "具有éœé›»ç”¢ç”Ÿè£ç½®ä¹‹å½±åƒè¼¸å…¥è£ç½®";
            Encoding utf8 = new UTF8Encoding();
            Encoding window1252 = Encoding.GetEncoding("Windows-1252");
    
            byte[] postBytes = window1252.GetBytes(encodedText);
            
            string decodedText = utf8.GetString(postBytes);
            string actualText = "具有靜電產生裝置之影像輸入裝置";
            Assert.AreEqual(actualText, decodedText);
        }
    }