我想加密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>
答案 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核心的其他更新。