请问下asp.net在 windows7+iis7环境中的权限问题。

ufo20020427 2014-06-13 10:38:16
系统为Windows7 旗舰版 + iis7
一直以来,以为asp.net网站的访问权限默认情况下只能访问部署所在目录。

例如某网站我部署在 f:\web

可下面的语句却都能正确执行
File.Copy("e:\\123.txt", "f:\\123.txt", true);
File.Delete("f:\\123.txt");

我想问一下,
1. asp.net网站执行时用的windows哪个账号的权限(windows2000好像是aspnet,Windows7,Windows2003呢?)
2.系统我没做过任何权限设置(NTFS),以f盘为例,权限为
Authenticated Users
System
Administrators
Users

可为什么会出现可以操作非站点目录。

谢谢!

...全文
274 13 打赏 收藏 转发到动态 举报
写回复
用AI写文章
13 条回复
切换为时间正序
请发表友善的回复…
发表回复
ufo20020427 2014-06-13
  • 打赏
  • 举报
回复
Authenticated Users 去掉就正常了。
md5e 2014-06-13
  • 打赏
  • 举报
回复
Guest的用户权限要比users的高
md5e 2014-06-13
  • 打赏
  • 举报
回复
只保留administrator
md5e 2014-06-13
  • 打赏
  • 举报
回复
Guest也没有留
ufo20020427 2014-06-13
  • 打赏
  • 举报
回复
我windows7中,用户只有administrator与Guest 而组只有IIS_IUSERS
ufo20020427 2014-06-13
  • 打赏
  • 举报
回复
@liuchaolin 不好意思,刚才我试验时弄错了一点。 现在 我把e:\ f:\ Users去掉,仍然 File.Copy("e:\\123.txt", "f:\\123.txt", true); File.Delete("f:\\123.txt"); 可以正常执行!
md5e 2014-06-13
  • 打赏
  • 举报
回复
再去掉Authenticated Users试试
md5e 2014-06-13
  • 打赏
  • 举报
回复
一般严格来说,.net 需要用到的权限为IUSER_xxxx(来宾帐号)和ASPNET这两个帐号,users是已经包含了这两者,所以懒人用Users,有严格要求的就就要分别添加IUSER_xxxx(来宾帐号)和ASPNET
ufo20020427 2014-06-13
  • 打赏
  • 举报
回复
f:\web现在为 Authenticated Users System Administrators
md5e 2014-06-13
  • 打赏
  • 举报
回复
你就再检查一下f:\web文件夹的权限咧
ufo20020427 2014-06-13
  • 打赏
  • 举报
回复
@liuchaolin 我把e:\ f:\ Users去掉就可以 ,f:\web不加users也正常。 .这是否意味着,asp.net在windows7下,使用的是users组的权限?(可是我现在f:\web没加users也能正常操作f:\web下的文件)
md5e 2014-06-13
  • 打赏
  • 举报
回复
设置完后你再测试一下
md5e 2014-06-13
  • 打赏
  • 举报
回复
e:和f:->属性->把users和everyone的帐号都给去掉 f:\web\www 只单独附给web 下方的www文件夹(也可以是其它文件)users的权限
ASP.NET ASP.NET 概述 ASP.NET 是一个统一的 Web 开发模型,它包括您使用尽可能少的代码生成企业级 Web 应用程序所必需的各种服务。ASP.NET 作为 .NET Framework 的一部分提供。当您编写 ASP.NET 应用程序的代码时,可以访问 .NET Framework 的类。您可以使用与公共语言运行库 (CLR) 兼容的任何语言来编写应用程序的代码,这些语言包括 Microsoft Visual Basic、C#、JScript .NET 和 J#。使用这些语言,可以开发利用公共语言运行库、类型安全、继承等方面的优点的 ASP.NET 应用程序。 ASP.NET 包括: 页和控件框架 ASP.NET 编译器 安全基础结构 状态管理功能 应用程序配置 运行状况监视和性能功能 调试支持 XML Web services 框架 可扩展的宿主环境和应用程序生命周期管理 可扩展的设计器环境 页和控件框架 ASP.NET 页和控件框架是一种编程框架,它在 Web 服务器上运行,可以动态地生成和呈现 ASP.NET 网页。可以从任何浏览器或客户端设备请求 ASP.NET 网页,ASP.NET 会向请求浏览器呈现标记(例如 HTML)。通常,您可以对多个浏览器使用相同的页,因为 ASP.NET 会为发出请求的浏览器呈现适当的标记。但是,您可以针对诸如 Microsoft Internet Explorer 6 的特定浏览器设计 ASP.NET 网页,并利用该浏览器的功能。ASP.NET 支持基于 Web 的设备(如移动电话、手持型计算机和个人数字助理 (PDA))的移动控件。 ASP.NET 网页是完全面向对象的。在 ASP.NET 网页,可以使用属性、方法和事件来处理 HTML 元素。ASP.NET 页框架为响应在服务器上运行的代码的客户端事件提供统一的模型,从而使您不必考虑基于 Web 的应用程序固有的客户端和服务器隔离的实现细节。该框架还会在页处理生命周期自动维护页及该页上控件的状态。有关更多信息,请参见 ASP.NET 网页概述。 使用 ASP.NET 页和控件框架还可以将常用的 UI 功能封装成易于使用且可重用的控件。控件只需编写一次,即可用于许多页并集成到 ASP.NET 网页。这些控件在呈现期间放入 ASP.NET 网页ASP.NET 页和控件框架还提供各种功能,以便可以通过主题和外观来控制网站的整体外观和感觉。可以先定义主题和外观,然后在页面级或控件级应用这些主题和外观。有关更多信息,请参见 ASP.NET 主题和外观概述。 除了主题外,还可以定义母版页,以使应用程序的页具有一致的布局。一个母版页可以定义您希望应用程序的所有页(或一组页)所具有的布局和标准行为。然后可以创建包含要显示的页特定内容的各个内容页。当用户请求内容页时,这些内容页与母版页合并,产生将母版页的布局与内容页的内容组合在一起的输出。有关更多信息,请参见 ASP.NET 母版页概述。 ASP.NET 编译器 所有 ASP.NET 代码都经过了编译,可提供强类型、性能优化和早期绑定以及其他优点。代码一经编译,公共语言运行库会进一步将 ASP.NET 编译为本机代码,从而提供增强的性能。 ASP.NET 包括一个编译器,该编译器将包括页和控件在内的所有应用程序组件编译成一个程序集,之后 ASP.NET 宿主环境可以使用该程序集来处理用户请求。有关更多信息,请参见 ASP.NET 编译概述。 安全基础结构 除了 .NET 的安全功能外,ASP.NET 还提供了高级的安全基础结构,以便对用户进行身份验证和授权,并执行其他与安全相关的功能。您可以使用由 IIS 提供的 Windows 身份验证对用户进行身份验证,也可以通过您自己的用户数据库使用 ASP.NET Forms 身份验证和 ASP.NET 成员资格来管理身份验证。此外,可以使用 Windows 组或您自己的自定义角色数据库(使用 ASP.NET 角色)来管理 Web 应用程序的功能和信息方面的授权。您可以根据应用程序的需要方便地移除、添加或替换这些方案。有关更多信息,请参见下列主题: ASP.NET 网站安全性 使用成员资格管理用户 使用角色管理授权 Forms 身份验证提供程序 ASP.NET 始终使用特定的 Windows 标识运行,因此,您可以通过使用 Windows 功能(例如 NTFS 访问控制列表 (ACL)、数据库权限等等)来保护应用程序的安全。有关 ASP.NET 标识的更多信息,请参见配置 ASP.NET 进程标识和 ASP.NET 模拟。 状态管理功能 ASP.NET

62,072

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧