1

我已经实现了一个winform应用程序。我使用配置类将应用程序的用户设置存储在配置文件中。我将 exe 与配置文件一起存储在文件夹下

C:\Users\\AppData\Local

这在正常情况下工作正常,但在用户将 Appdata 文件夹重定向到某个服务器地址的情况下我会遇到问题。在这种情况下,我会遇到异常:

试图执行未经授权的操作。

我在这里发现了一些类似的问题,但没有一个有任何令人满意的答案。我尝试在运行 Configuration.Save 命令之前删除配置文件,但这给出了异常:

配置文件已被另一个程序更改。

那么,我该如何解决这个问题。这是我更新配置文件的代码:

string exePath = Path.Combine(Path.GetDirectoryName(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData)), @"Local\<folder name>\<exe file name>");
Configuration configFile = ConfigurationManager.OpenExeConfiguration(exePath);
if (configFile.AppSettings.Settings[key] != null)
{
    configFile.AppSettings.Settings.Remove(key);
}
if (param)
{
    configFile.AppSettings.Settings.Add(key, value);
}
configFile.Save(ConfigurationSaveMode.Modified);

这是异常的堆栈跟踪:

at System.Security.AccessControl.Win32.SetSecurityInfo(ResourceType
 type, String name, SafeHandle handle, SecurityInfos securityInformation, SecurityIdentifier owner, SecurityIdentifier group, GenericAcl sacl, GenericAcl dacl)    
at System.Security.AccessControl.NativeObjectSecurity.Persist(String
 name, SafeHandle handle, AccessControlSections includeSections, Object
 exceptionContext)    
at System.Security.AccessControl.NativeObjectSecurity.Persist(String
 name, AccessControlSections includeSections, Object exceptionContext) 
at System.Security.AccessControl.NativeObjectSecurity.Persist(String
 name, AccessControlSections includeSections)    
at System.Security.AccessControl.FileSystemSecurity.Persist(String
 fullPath)    
at System.IO.File.SetAccessControl(String path, FileSecurity fileSecurity)    
at System.Configuration.Internal.WriteFileContext.DuplicateTemplateAttributes(String source, String destination)    
at System.Configuration.Internal.WriteFileContext.DuplicateFileAttributes(String source, String destination)    
at System.Configuration.Internal.WriteFileContext.Complete(String
filename, Boolean success)    
at  System.Configuration.Internal.InternalConfigHost.StaticWriteCompleted(String
streamName, Boolean success, Object writeContext, Boolean assertPermissions)    at System.Configuration.Internal.InternalConfigHost.System.Configuration.Internal.IInternalConfigHost.WriteCompleted(String streamName, Boolean success, Object writeContext, Boolean assertPermissions)    
at System.Configuration.Internal.InternalConfigHost.System.Configuration.Internal.IInternalConfigHost.WriteCompleted(String streamName, Boolean success, Object writeContext)    
at
 System.Configuration.Internal.DelegatingConfigHost.WriteCompleted(String streamName, Boolean success, Object writeContext)    
at System.Configuration.UpdateConfigHost.WriteCompleted(String
streamName, Boolean success, Object writeContext)    
at System.Configuration.MgmtConfigurationRecord.SaveAs(String filename,
ConfigurationSaveMode saveMode, Boolean forceUpdateAll)    
at System.Configuration.Configuration.SaveAsImpl(String filename, ConfigurationSaveMode saveMode, Boolean forceSaveAll)    
at UtilityClasses.ConfigurationHandler.UpdateConfigFile(String key, String value, Boolean param)
4

3 回答 3

1

我有一个非常相似的经验,使用ConfigurationManager.

事实证明,Configuration.Save最初在同一位置创建了一个临时文件,并将所需的访问权限设置为写入 DAC(写入目录访问控制)。

在此处输入图像描述

它甚至在文档中这样说:

当 'Creator Owner' 列在包含配置文件的目录的 ACL(访问控制列表)中时,Save 的当前用户将成为文件的新所有者并继承授予 'Creator Owner' 的权限。这会导致当前用户的权限提升和前所有者的权限被删除。

我可以在我的环境中找到的唯一解决方法是将配置复制到本地目录,在本地更改文件,然后将其复制回来。

于 2018-09-21T12:33:48.793 回答
0

解决方法

  1. 检查共享文件夹上特定用户的属性。它可能缺少 WriteExtended 属性。

  2. 检查从创建者那里继承所有权限的共享文件夹的创建者。

  3. 检查您是否可以将共享文件夹的配置更改为非 c: 驱动器文件夹。

于 2020-05-11T05:13:27.920 回答
0

你有两种方法可以解决这个问题:
1. 共享网络文件夹,这样它就不会为同一网络的用户自动授权。
2. 使用用户凭据通过授权并连接到网络路径。

于 2017-05-15T16:19:04.293 回答