应用程序需要访问文件,但不允许用户访问它们

应用程序需要访问文件,但不允许用户访问它们

我有一个要求,即我的 Windows GUI 应用程序写入日志文件。但出于审计目的,运行该应用程序的某些用户无权访问这些文件。有什么办法可以处理应用程序需要与运行它的用户不同的文件权限这一事实吗?有人向我提出了一些建议,即编写一个 Windows 服务来管理日志记录或写入 Windows 事件日志。这将是一个重大变化,因为我们已经在写入磁盘上的文件,所以我希望我可以通过以不同的用户身份运行该应用程序来实现这一点。

我知道我可以使用已保存凭据的 runas 来执行此操作,但这是一种安全风险。我考虑过使用任务计划程序,但似乎这不会显示已登录用户的 UI。

答案1

正如评论所说,事件日志将是实现此目的的理想方式。可以设置这些权限,但似乎很脆弱。如果您的用户需要提升应用程序的权限,这可能会取代您的日志用户的权限并带来风险或离开其沙盒并“失去连接”。它还存在创建大量日志的风险,而用户则无权清理这些日志。您需要另一个管理流程来执行此操作;滚雪球效应。

答案2

也许我没完全理解,所以我的回答可能有点愚蠢,但为什么不直接给所有用户写入该文件的权限呢?只有写入权限。他们将无法读取或删除它。更好的是,如果他们无权访问 LOG 所在的目录,只需给他们根文件夹上的“遍历”权限。这样,他们可以写入文件,但仍然无法访问目录。再次抱歉,如果我误解了什么。 在此处输入图片描述

相关内容