草庐IT

c++ - Windows 文件权限作为字符串

给定一个特定的文件系统路径(文件夹或文件,无关紧要),我需要生成一个字符串来反射(reflect)每个主体对该路径的访问权限。我想要的结果与您在Windows的“高级安全设置”对话框的“权限”选项卡中看到的结果非常相似:我最终将以User1:[access]、User2:[access]等格式显示。实现此结果的直接方法是什么?具体来说,必须执行哪些Windows安全API函数,以什么顺序执行? 最佳答案 通过CreateFile打开文件具有FILE_FLAG_BACKUP_SEMANTICS和FILE_GENERIC_READ属性(

windows - 哪种类型的特定访问权限 (ACCESS_MASK) 对 SE_LMSHARE 有效?

使用SE_LMSHARE调用Get/Set[Named]SecurityInfo时,如何解释ACE中特定于类型的访问权限?我猜我应该使用FileAccessRightsConstants的目录版本但这在任何地方都有记录吗? 最佳答案 为了像我一样尝试设置Windows共享权限并偶然发现这个老问题的其他人的利益,我整理了以下内容:[Flags]publicenumACCESS_MASK:uint{READ_FILE=0x000001,//0b000000000000000000001,1请注意,这不是一个详尽的列表-它包含提供共享权限

windows - 安装程序以管理员权限运行后如何在非管理员窗口中打开应用程序

背景:我们的应用程序的安装需要管理员权限。安装程序完成后,我们从安装程序中调用新安装的程序,它会在管理窗口中打开。(这至少是它在Windows上的工作方式)然后当我们点击图标运行程序时,它会打开另一个窗口(因此应用程序的两个实例正在运行——这不是一件好事。)是否可以从批处理文件中同时运行安装程序和应用程序,以便只有在安装程序关闭后,应用程序才会在非管理窗口中打开?(在我们的应用程序中,安装程序要求管理员权限,因此批处理文件不应该这样做。)我尝试使用“Everything.exe”(一个需要管理员权限的出色应用)对此进行试验。REMTestbatchfileforopeningtwoap

Windows 权限,在不是管理员时获取 .dll 的句柄,不确定

好的,我正在学习WindowsAPI以及如何创建线程/进程和获得调试权限等。非常新,如果这是一个愚蠢的问题,我深表歉意。无论如何,我正在创建一个.dll注入(inject)器来玩,并且已经成功地能够注入(inject)32位和64位进程,包括通过注入(inject)我的.dll文件的explorer.exe。但是,我试图在标准用户模式下对此进行测试,但在弄清楚如何进行时遇到了问题。现在我正在为.dll和injector.exe编译为x64。我正在尝试注入(inject)x64进程,主要是explorer.exe(适用于管理员)。使用VisualStudio2012,进行了一些优化,没有

windows - 尝试授予 IIS 7.5 中特定应用程序池标识的权限 - "object cannot be found"

通常,我会根据应用程序池身份授予对文件夹的访问权限,格式为:IISAppPool\[app_pool_name]在这个特定的新服务器上,当我尝试编辑文件夹的安全设置并添加该特定用户条目时,我得到一个"objectIISAppPool\XXXXXXcannotbefound"知道这是为什么吗?我确认应用程序池设置为ApplicationPoolIdentity。我正在使用IIS7.5和WindowsServer2008R2。 最佳答案 默认情况下,每当您尝试在加入域的计算机上添加新帐户时,只会在您的域的域Controller上搜索帐户

c++ - 通过 Winapi 以编程方式编辑 Windows 审核策略时出现权限错误

简短版本:我正在尝试编写一个C++程序,以在Windows8上启用进程创建日志记录。我知道这可以使用auditpol.exe来完成,但我想以编程方式进行。我的研究表明,唯一的方法是通过WindowsAPI命令AuditSetSystemPolicy,所以我写了一个调用这个函数的C++程序(见下文)。但是,该程序因权限问题而失败(错误代码1314)。我以管理员身份运行VisualStudio,我尝试在以管理员身份运行的命令提示符下执行该程序,但我仍然遇到错误。长版:以下程序采用GUIDstringdescribingtheProcessCreationSubcategory我想开始审核并

c# - 似乎是 .dll 权限 C# 的问题

我在我的C#应用程序中遇到了一个奇怪的问题。我的应用程序使用一些外部.dll文件(用于外部数据库访问的MySQL和用于错误报告的NBug),这些文件存储在与主.exe相同的目录中。安装我的应用程序并从开始菜单运行它后,它加载并工作正常,这确认mysql.dll正在正常访问。但是,当应用程序崩溃时(由于未处理的异常),通常会弹出NBug错误处理程序,但它不会。而是显示Windows风格的错误报告程序。在执行进一步调查后,如果我从程序文件以外的位置运行该应用程序,例如在我的桌面上,NBug报告器加载正常。这让我相信这可能是一个权限问题。所以我尝试以管理员身份从ProgramFiles运行该

c++ - NetUserAdd - 权限问题,参数不正确

我正在使用NetUserAdd添加新管理员。但是我收到了一个我无法弄清楚的错误。失败方法返回的错误是:NET_API_STATUS:87PARAM_ERR:5NET_API_STATUS的值为87,即ERROR_INVALID_PARAMETER。我相信5是参数5。这是我感到困惑的地方。什么参数?我的结构与文档中的结构相同,那么这是哪里失败了?这是失败的方法。boolCreateAdminUser(wchar_t*username,wchar_t*password){_USER_INFO_1ui;DWORDdwLevel=1;DWORDdwError=0;NET_API_STATUS=

c# - 除了 LOCALMACHINE - 没有管理权限的注册表之外,我可以在哪里放置普通用户数据

在注册表-localmachine以外的Windows中,我可以在哪里放置所有用户都可以访问的公共(public)用户数据。我需要不请求提升管理员权限 最佳答案 您可以将其存储在应用程序数据文件夹中。您可以从Envorinment获得:varappDataFolder=Environment.GetFolderPath(Environment.SpecialFolder.CommonDocuments);要确定您是否可以在没有管理员权限的情况下访问该文件夹,请在没有管理员权限的情况下运行VisualStudio,然后查看此代码是否成

windows - AWS 配置导致权限错误

我有一个批处理文件(在Windows10中),可以像这样将文件备份到amazonS3:awsconfiguresetAWS_ACCESS_KEY_IDawsconfiguresetAWS_SECRET_ACCESS_KEYawsconfiguresetdefault.regioneu-west-1"C:\ProgramFiles\Amazon\AWSCLI\aws.exe"s3apiput-object--keyc:\myfile.rar--bucket--bodyc:\myfile.rar当我从命令行运行这个批处理文件时,它给出了这些错误:[Errno13]Permissionden