加密log4net AdoNetAppender使用的connectionString

时间:2009-05-06 03:47:44

标签: configuration log4net

我想加密log4net AdoNetAppender使用的连接字符串。

这可以在不加密整个appender的情况下完成吗?

Dion Olsthoorn发表了关于在代码中设置连接字符串的博客,但我更倾向于在专用于日志记录的配置文件中执行此操作,因为它将使用与应用程序其余部分不同的数据库。 / p>

以下是http://logging.apache.org/log4net/release/sdk/log4net.Appender.AdoNetAppender.html

的示例配置
<appender name="AdoNetAppender_SqlServer" type="log4net.Appender.AdoNetAppender">
  <connectionType value="System.Data.SqlClient.SqlConnection, System.Data, Version=1.0.3300.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
  <connectionString value="data source=SQLSVR;initial catalog=test_log4net;integrated security=false;persist security info=True;User ID=sa;Password=sa" />
  <commandText value="INSERT INTO Log ([Date],[Thread],[Level],[Logger],[Message]) VALUES (@log_date, @thread, @log_level, @logger, @message)" />
  <parameter>
    <parameterName value="@log_date" />
    <dbType value="DateTime" />
    <layout type="log4net.Layout.PatternLayout" value="%date{yyyy'-'MM'-'dd HH':'mm':'ss'.'fff}" />
  </parameter>
  <parameter>
    <parameterName value="@thread" />
    <dbType value="String" />
    <size value="255" />
    <layout type="log4net.Layout.PatternLayout" value="%thread" />
  </parameter>
  <parameter>
    <parameterName value="@log_level" />
    <dbType value="String" />
    <size value="50" />
    <layout type="log4net.Layout.PatternLayout" value="%level" />
  </parameter>
  <parameter>
    <parameterName value="@logger" />
    <dbType value="String" />
    <size value="255" />
    <layout type="log4net.Layout.PatternLayout" value="%logger" />
  </parameter>
  <parameter>
    <parameterName value="@message" />
    <dbType value="String" />
    <size value="4000" />
    <layout type="log4net.Layout.PatternLayout" value="%message" />
  </parameter>
</appender>

2 个答案:

答案 0 :(得分:2)

我已经能够通过继承log4net AdoNetAppender并添加一个名为ConnectionStringName的属性来解决这个问题。

如果设置了此项,它将从web.config连接字符串中读取连接字符串,并将其传递给基础AdoNetAppender。

我仍然热衷于一种解决方案,它将所有日志记录配置保存在一个文件中,并且仍然允许对连接字符串进行加密。

    public class ConfigAdoNetAppender : AdoNetAppender
    {
        public string ConnectionStringName
        {

            set
            {
                this.ConnectionString = System.Configuration.ConfigurationManager.ConnectionStrings[value].ToString();
            }
        }
    }

答案 1 :(得分:2)

当前源已经具有ConnectionStringName属性,该属性完全符合您的要求。

revision 607748中引入了ConnectionStringName属性。版本1.2.10是revision 395324,与此相比相当陈旧。

如果您对使用未发布的代码感到满意,可以获取最新的代码并自行编译。您可能还可以获得更新的AdoNetAppender类,尽管它可能依赖于log4net核心的其他更新。