标签:core asp basedir nlog appbasepath var appBasePath config
$ {basedir}指向的是 AppDomain.CurrentDomain.BaseDirectory,
Asp.Net.Core的解决方法可能如下(在Program.cs中添加两行):
var appBasePath = System.IO.Directory.GetCurrentDirectory(); NLog.GlobalDiagnosticsContext.Set("appbasepath", appBasePath); var logger = LogManager.LoadConfiguration("nlog.config").GetCurrentClassLogger();
然后,您可以${gdc:item=appbasepath}
在nlog.config
:
<?xml version="1.0"?> <nlog xmlns="http://www.nlog-project.org/schemas/NLog.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" autoReload="true" internalLogLevel="Warn" internalLogFile="${gdc:item=appbasepath}\log\internal-nlog.txt"> <extensions> <add assembly="NLog.Web.AspNetCore"/> </extensions> <targets async="true"> <target name="ownfile" xsi:type="File" concurrentWrites="true" keepFileOpen="true" fileName="${gdc:item=appbasepath}\log\nlog-${shortdate}.log" encoding="utf-8" layout="${longdate}|${machinename}|${uppercase:${level}}|${logger}|${message}|${exception:format=tostring}|${aspnet-request-method}|${aspnet-traceidentifier}|${aspnet-request-ip}|${aspnet-request-url}|${aspnet-mvc-action}" /> </targets> <rules> <!--Skip non-critical Microsoft logs and so log only own logs--> <logger name="Microsoft.*" maxLevel="Info" final="true" /> <logger name="*" minlevel="Info" writeTo="ownfile" /> </rules> </nlog>
标签:core,asp,basedir,nlog,appbasepath,var,appBasePath,config 来源: https://www.cnblogs.com/tianfengcc/p/12619025.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。