Leo*_*ett 2 c# asp.net file-permissions unauthorized
我正在完成我的Web项目并添加了一些错误日志功能.它在App_Data文件夹中的日期文件中写入异常的详细信息.
当我在我的开发机器上执行此操作时,它可以工作.但当我切换到我的IIS机器时,它停止工作,我得到一个UnauthorizedAccessException.
堆栈跟踪:
[UnauthorizedAccessException: Der Zugriff auf den Pfad "c:\inetpub\wwwroot\App_Data\Error_Logs\" wurde verweigert.]
System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath) +9726526
System.IO.Directory.InternalCreateDirectory(String fullPath, String path, Object dirSecurityObj) +9431442
System.IO.Directory.CreateDirectory(String path) +146
WerIstWo.Logger.writeToLog(String text) in c:\Users\Teichler\Dropbox\Praktikum\IHK-Projekt\WerIstWo\WerIstWo\Logger.cs:18
WerIstWo.NeuerBenutzer.btnSpeichern_Click(Object sender, EventArgs e) in c:\Users\Teichler\Dropbox\Praktikum\IHK-Projekt\WerIstWo\WerIstWo\NeuerBenutzer.aspx.cs:325
System.Web.UI.WebControls.Button.OnClick(EventArgs e) +118
System.Web.UI.WebControls.Button.RaisePostBackEvent(String eventArgument) +112
System.Web.UI.WebControls.Button.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument) +10
System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument) +13
System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData) +36
System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +5563
Run Code Online (Sandbox Code Playgroud)
码:
public static void writeToLog( string text )
{
string date = DateTime.Today.ToShortDateString().ToString();
string path = AppDomain.CurrentDomain.GetData( "DataDirectory" ).ToString() + "\\Error_Logs\\";
if (!Directory.Exists( path ))
{
Directory.CreateDirectory( path );
}
string fullPath = path + date + ".txt";
if (!File.Exists( path + date ))
{
File.Create( fullPath ).Close();
}
using (StreamWriter writer = new StreamWriter( fullPath, true ))
{
writer.Write( text );
}
}
Run Code Online (Sandbox Code Playgroud)
在错误详细信息中,它告诉我我需要将IUSR_MachineName的权限设置为此文件夹,但我不确定这是一个好主意还是如何在IIS 5.1(我正在使用)中执行此操作.
这确实是你需要做的.在您的开发计算机上,IIS(或IIS express)可执行文件具有您的App_Data目录的写入权限.在生产计算机上,通常不会默认使用.只有一个解决方案,即授予IUSR_MachineName用户对目录的写权限.这没有任何根本性的错误,只要您知道这意味着在同一IIS实例中运行的其他网站也可能写入该目录.
| 归档时间: |
|
| 查看次数: |
5547 次 |
| 最近记录: |