.net core log4net:错误无法创建[log4net.Appender.ColoredConsoleAppender]类型的Appender[Console]。报告的错误

.net core log4net:错误无法创建[log4net.Appender.ColoredConsoleAppender]类型的Appender[Console]。报告的错误,.net-core,log4net,.net Core,Log4net,你好,朋友,在我的控制台应用程序中尝试使用NetCore中的log4net时,我遇到了以下问题 我的代码是: using log4net; using log4net.Config; using System; using System.Collections.Generic; using System.Configuration; using System.IO; using System.Linq; using System.Net; using System.Net.Sockets; us

你好,朋友,在我的控制台应用程序中尝试使用NetCore中的log4net时,我遇到了以下问题

我的代码是:

using log4net;
using log4net.Config;
using System;
using System.Collections.Generic;
using System.Configuration;
using System.IO;
using System.Linq;
using System.Net;
using System.Net.Sockets;
using System.Threading.Tasks;
using Teltonika.Codec;

namespace UdpListener
{
    class Program
    {
        private static readonly ILog Log = LogManager.GetLogger(typeof(Program));
        static void Main()
        {
            XmlConfigurator.Configure();
            IPAddress ip;
            if (!IPAddress.TryParse(ConfigurationManager.AppSettings["ipAddress"], out ip))
            {
                Log.Error("Ip is not valid.");
                throw new ArgumentException("Ip is not valid.");
            }

            int port;
            if (!int.TryParse(ConfigurationManager.AppSettings["port"], out port))
            {
                Log.Error("Port is not valid.");
                throw new ArgumentException("Port is not valid.");
            }

            Task.Run(async () =>
            {
                try
                {
                    using (var udpClient = new UdpClient(new IPEndPoint(ip, port)))
                    {
                        Log.Info("Listening...");

                        while (true)
                        {
                            //IPEndPoint object will allow us to read datagrams sent from any source.
                                var receivedResults = await udpClient.ReceiveAsync();

                            byte[] data = receivedResults.Buffer;


                            //tramaService.InsertTrama(new Entity.GpsPuntos()
                            //{
                            //    Fecha = DateTime.Now,
                            //    Trama = String.Join("", data.Select(x => x.ToString("X2")).ToArray())
                            //});


                            Log.Info(string.Format("Received connection from: {0}", receivedResults.RemoteEndPoint));
                            Log.Info(string.Format("{0} - received [{1}]", DateTime.Now, String.Join("", data.Select(x => x.ToString("X2")).ToArray())));

                            var reader = new ReverseBinaryReader(new MemoryStream(data));

                            // Decode data
                            var avlData = new DataDecoder(reader).DecodeUdpData();

                            // Create response
                            var bytes = new List<byte>();

                            const short packetLength = 2 /* Id */+ 1 /* Type */ + 1 /* Avl packet id */+ 1 /* num of accepted elems */;
                            bytes.AddRange(BitConverter.GetBytes(BytesSwapper.Swap(packetLength)));
                            bytes.AddRange(BitConverter.GetBytes(BytesSwapper.Swap(avlData.PacketId)));
                            bytes.Add(avlData.PacketType);
                            bytes.Add(avlData.AvlPacketId);
                            bytes.Add((byte)avlData.AvlData.DataCount);

                            var response = bytes.ToArray();

                            Log.Info(string.Format("{0} - response [{1}]", DateTime.Now, String.Join("", bytes.Select(x => x.ToString("X2")).ToArray())));

                            await udpClient.SendAsync(response, response.Length, receivedResults.RemoteEndPoint);
                        }
                    }
                }
                catch (Exception ex)
                {

                    throw new Exception(ex.Message);
                }

            });

            Console.ReadLine();
        }
    }
}
这是我的错误

log4net:错误无法创建[log4net.Appender.ColoredConsoleAppender]类型的Appender[Console]。报告的错误如下。 System.NotSupportedException:没有可用于编码的数据。有关定义自定义编码的信息,请参阅encoding.RegisterProvider方法的文档。 在System.Text.Encoding.GetEncodingInt32代码页 在log4net.Appender.ColoredConsoleAppender.ActivateOptions 在log4net.Repository.Hierarchy.XmlHierarchyConfigurator.ParseAppenderXmlElement appenderElement log4net:找不到名为[Console]的错误追加器

我的存档配置:

<?xml version="1.0" encoding="utf-8" ?>
<configuration>
    <configSections>
        <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net"/>
    </configSections>

    <appSettings>
        <add key="ipAddress" value="172.17.160.1"/>
        <add key="port" value="3316"/>
        <!--<add key="log4net.Internal.Debug" value="true"/>-->
    </appSettings>

    <log4net>
        <appender name="Console" type="log4net.Appender.ColoredConsoleAppender" Target="Console.Error">
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%logger - %message%newline"/>
            </layout>
        </appender>
        
        <appender name="RollingFileAppender" type="log4net.Appender.RollingFileAppender">
            <file value="log.txt"/>
            <appendToFile value="true"/>
            <rollingStyle value="Size"/>
            <maxSizeRollBackups value="10"/>
            <maximumFileSize value="500KB"/>
            <staticLogFileName value="true"/>
            <layout type="log4net.Layout.PatternLayout">
                <conversionPattern value="%d %-5p %c %m%n"/>
            </layout>
        </appender>

        <root>
            <level value="INFO"/>
            <appender-ref ref="Console"/>
            <appender-ref ref="RollingFileAppender"/>
        </root>
    </log4net>
</configuration>

我想让它在控制台应用程序中向我显示它正在工作。

在从.NET Framework升级到.NET 5后,今天我自己也遇到了同样的错误。我在我的程序开始时添加了以下行,成功地解决了这个问题:


System.Text.Encoding.RegisterProviderSystem.Text.CodePagesEncodingProvider.Instance

今天从.NET Framework升级到.NET 5后,我自己也犯了同样的错误。我在我的程序开始时添加了以下行,成功地解决了这个问题:


System.Text.Encoding.RegisterProviderSystem.Text.CodePagesEncodingProvider.Instance

在.NET Core 3.1上为我工作,顺便说一句-谢谢。在.NET Core 3.1上为我工作,顺便说一句-谢谢。