System.NotSupportedException: No data is available for encoding 1252

C#

C# Problem Overview


I'm working with a Trust Commerce Tutorial on how to generate a payment token that will allow customers to use the TC Trustee Host payment form. I was given an example on how to retrieve this token by their dev team.

using System;
using System.Net;
using System.IO;
using System.Text;
using System.Collections;
using System.Web;

/** @class TCToken
 * An example class for generating a TrustCommerce Trustee Token
 */
public class TCToken
{

    public static void Main(string [] args)
    {
        string custid = "123456";
        string password = "XXXXXX";
        try {
            // Adapted from http://www.west-wind.com/presentations/dotnetWebRequest/dotnetWebRequest.htm
            string gateway_post_address = "https://vault.trustcommerce.com/trustee/token.php";
            HttpWebRequest req = (HttpWebRequest) WebRequest.Create(gateway_post_address);

            // A sixty second timeout.
            req.Timeout = 60000;

            string post_data = "custid=" + HttpUtility.UrlEncode(custid) +
                                "&password=" + HttpUtility.UrlEncode(password);
            
            req.Method = "POST";
            byte [] buf = System.Text.Encoding.GetEncoding(1252).GetBytes(post_data);
            req.ContentLength = buf.Length;
            req.ContentType = "application/x-www-form-urlencoded";

            Stream s = req.GetRequestStream();
            s.Write(buf, 0, buf.Length);
            s.Close();

            HttpWebResponse rep = (HttpWebResponse) req.GetResponse();
            Encoding enc = System.Text.Encoding.GetEncoding(1252);
            StreamReader rs = new StreamReader(rep.GetResponseStream(), enc);

            string token = rs.ReadToEnd();

            Console.WriteLine(token);

            rep.Close();
            rs.Close();
        } catch (Exception e) {
            Console.WriteLine(e);
        }
    }
}

I made a new console application in visual studio, copied this code, and replaced the username and password with the correct credentials. When I try to run this, I get the following error in the console.

> System.NotSupportedException: No data is available for encoding 1252. > For information on defining a custom encoding, see the documentation > for the Encoding.RegisterProvider method. at > System.Text.Encoding.GetEncoding(Int32 codepage) at > TCToken.Program.Main(String[] args) in > C:\Users\xxxx\source\repos\TCToken\TCToken\Program.cs:line 29

I've tried to google this error and most of the responses are a little above my understanding. I'm certainly not a C# expert.

C# Solutions


Solution 1 - C#

.NET Core supports only ASCII, ISO-8859-1 and Unicode encodings, whereas .NET Framework supports much more.

However, .NET Core can be extended to support additional encodings like Windows-1252, Shift-JIS, GB2312 by registering the CodePagesEncodingProvider from the System.Text.Encoding.CodePages NuGet package.

After the NuGet package is installed the following steps as described in the documentation for the CodePagesEncodingProvider class must be done to register the provider:

> 1. Add a reference to the System.Text.Encoding.CodePages.dll assembly to your project. > 2. Retrieve a CodePagesEncodingProvider object from the static Instance property. > 3. Pass the CodePagesEncodingProvider object to the Encoding.RegisterProvider method.

Solution 2 - C#

What ckuri said. Just to be clear, you need the following line of code before opening the stream (steps 2,3):

System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);

ExcelDataReader - Important note on .NET Core

> By default, ExcelDataReader throws a NotSupportedException "No data is > available for encoding 1252." on .NET Core. > > To fix, add a dependency to the package System.Text.Encoding.CodePages > and then add code to register the code page provider during > application initialization (f.ex in Startup.cs): > > System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance); > > This is required to parse strings in binary BIFF2-5 Excel documents > encoded with DOS-era code pages. These encodings are registered by > default in the full .NET Framework, but not on .NET Core.

Solution 3 - C#

nuget:
Install-Package System.Text.Encoding.CodePages -Version 5.0.0

code:
Encoding.RegisterProvider(CodePagesEncodingProvider.Instance);

Solution 4 - C#

I was experiencing similar issue when I was trying to read and convert xlsx file to DataTable. I found out that encoding 1252 are not default in .NET Core therefore I had to separately add NuGet package for the same.

Below is the method where I convert the data from memory stream.

private static DataTableCollection ExcelToDataTable(MemoryStream stream)
{
    System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);

    using (var reader = ExcelReaderFactory.CreateReader(stream))
    {
        var result = reader.AsDataSet(new ExcelDataSetConfiguration()
        {
            ConfigureDataTable = (data) => new ExcelDataTableConfiguration()
            {
                UseHeaderRow = true
            }
        });
        
        return result.Tables;
    }
}

I referenced the Encoder from nuGet Package at the start of the method and it worked fine for me. This answer is late but might help people who are reading data from streams.

System.Text.Encoding.RegisterProvider(System.Text.CodePagesEncodingProvider.Instance);

Solution 5 - C#

I've installed the library System.Text.Encoding.CodePages like other posts said and this code worked for me:

System.Text.Encoding.RegisterProvider(
    System.Text.CodePagesEncodingProvider.Instance);
Encoding srcEncoding = Encoding.GetEncoding(1251);
using (var reader = new StreamReader(@"D:\someFile.csv", encoding: srcEncoding))
{
    List<string> listA = new List<string>();                
    while (!reader.EndOfStream)
    {
         var line = reader.ReadLine();
         var values = line.Split(';');
         listA.Add(values[0]);                    
    }
}

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
QuestiononTheInternetView Question on Stackoverflow
Solution 1 - C#ckuriView Answer on Stackoverflow
Solution 2 - C#dawidgView Answer on Stackoverflow
Solution 3 - C#Ivan ZakharovView Answer on Stackoverflow
Solution 4 - C#user273181View Answer on Stackoverflow
Solution 5 - C#StepUpView Answer on Stackoverflow