我试图保存一个图像到。net c#的文件夹,但我得到这个异常:

Access to the path 'C:\inetpub\wwwroot\mysite\images\savehere' is denied.The error occured at mscorlib because    at System.IO.__Error.WinIOError(Int32 errorCode, String maybeFullPath)
at System.IO.FileStream.Init(String path, FileMode mode, FileAccess access, Int32 rights, Boolean useRights, FileShare share, Int32 bufferSize, FileOptions options, SECURITY_ATTRIBUTES secAttrs, String msgPath, Boolean bFromProxy, Boolean useLongPath)
at System.IO.FileStream..ctor(String path, FileMode mode, FileAccess access, FileShare share, Int32 bufferSize, FileOptions options, String msgPath, Boolean bFromProxy)
at System.IO.FileStream..ctor(String path, FileMode mode)

我完全控制了这个文件夹(savehere)到网络服务和iis_iusrs,甚至完全控制了每个人,但仍然得到这个异常。 我尝试通过浏览器和IIS管理器访问,仍然没有运气

我是在Windows server 2008 R2和IIS 7.5上做的,我需要给谁访问权限?


当前回答

下面的技巧并不是这个帖子最初问题的答案,但可能会帮助其他一些用户在犯了和我一样的愚蠢错误后,最终进入这个网页……

我是想搞个ASP。Net FileUpload控件将文件上传到包含“隐藏共享”的网络地址,即:

\ MyNetworkServer \ \ SomeDirectoryOrOther加元

我不明白。如果我在Visual Studio的调试模式下运行网页,它会工作得很好。但是当项目被部署并通过应用程序池用户运行时,它拒绝找到这个网络目录。

我已经检查了我的IIS站点在哪个用户下运行,给了这个用户在“MyNetworkServer”服务器上的这个目录的完全权限,等等,但什么都不起作用。

原因(当然!)是只有管理员能够“看到”这些隐藏的驱动器共享。

我的解决方案是简单地创建一个“正常的”共享

MyNetworkServer \ SomeDirectoryOrOther

这样就摆脱了“访问路径…”被拒绝”的错误。日志含义FileUpload能够成功运行该命令

fileUpload.SaveAs(networkFilename);

希望这能帮助到其他和我犯同样错误的用户!

还要注意的是,如果你上传的是大文件(超过4Mb),那么IIS7要求你修改网页。配置文件在两个地方。点击此链接,阅读你需要做的事情: 在ASP中上传大文件。网

其他回答

请将IIS_IUSERS完全控制权限添加到您的文件夹。 您可以在文件夹属性中的安全选项卡中找到此选项。

我在本地工作站上开发时遇到了这个问题。

在几次不成功的iisreset调用之后,我通过重新启动我的机器来纠正这种情况。

回顾一下,打开的文件句柄可能会导致问题。

确保你的目标在System.IO中。Delete(string file)是一个已经存在的文件。 也许你的代码中有错误,比如你没有将正确的文件名传递给方法,或者你的目标是一个文件夹。在这些情况下,你会看到:"access to the path is denied错误"。

您可以尝试检查项目的web属性是否没有切换到IIS Express,并将其更改回IIS Local

如果您在子域上传文件时遇到此错误,并在您的本地主机中正常工作,那么请按照以下步骤执行:

解决方案:

Plesk面板

登录到Plesk面板。选择出错的子域。 点击主机设置。 选择“附加写/修改权限”和“应用”。

CPanel

我不确定CPanel中可用的选项。但如果你给目录权限(在CPanel中,它必须是十进制数字,如777,755)将解决这个错误。

详情请点击这里

错误原因:

假设FileUpload.SaveAs(服务器。MapPath("~/uploads/" + *YOUR_FILENAME*))将是您的代码移动您的文件上传路径。 服务器。MapPath将为您提供目录的物理路径(真实路径)。但是您的子域可能没有访问物理路径的权限。 因此,如果您赋予子域访问写/修改权限,就可以解决这个问题。