问题描述
我有一些好奇,我希望一个.net高手可以帮我。
I have something curious that I am hoping a .Net expert can help me with.
我有一个自定义配置节,并抓住它,我做到这一点:
I have a custom configuration section and to get hold of it I do this:
var s = (TestConfigurationSection)ConfigurationManager
.GetSection("testSection");
我运行在我的开发机器( Windows 7的
,64位的Windows完全是最新的),并能正常工作。
I run that on my development machine (Windows 7
, 64 bit, Windows completely up to date) and it works fine.
我需要与code。在我把它放在一个目录下的EXE C:\用户\公用
在视窗Server 2008 R2的
机上,打开一个命令提示符以管理员身份运行它,我得到的:
I take the exe with that code in and I put it in a directory inside c:\users\public
on a Windows Server 2008 R2
machine, open up a command prompt as administrator, run it and I get:
System.Configuration.ConfigurationErrorsException:出现创建配置节处理程序testSection错误:请求失败。 (C:\用户\公用\ configtest \ AppConfigTestConsoleApplication.exe.Config 10号线)---> System.Security.SecurityException:请求失败
现在我改变了code要做到这一点:
Now I changed that code to do this:
var config = ConfigurationManager.OpenExeConfiguration(
ConfigurationUserLevel.None);
var s = (TestConfigurationSection) config
.GetSection("testSection");
和它工作正常,在两台机器上。
and it works fine on both machines.
所以,我很高兴适中(在尽可能我的应用程序正在运行),但小精怪在我的脑海混乱,所以我在这里问:
So, I am moderately happy (in as much as my application is working) but that little Gremlin in my head is confused so I ask here:
为什么会出现这种情况?
在Visual Studio 2010中称为AppConfigTestConsoleApplication一个新的.NET 4控制台应用程序项目,并与下面的替换的Program.cs
的内容:
Create a new .net 4 Console application project called AppConfigTestConsoleApplication in visual studio 2010 and replace the contents of Program.cs
with the following:
using System;
using System.Configuration;
namespace AppConfigTestConsoleApplication
{
public class TestConfigurationSection : ConfigurationSection
{
[ConfigurationProperty("someSetting")]
public int SomeSetting
{
get { return (int) this["someSetting"]; }
set { this["someSetting"] = value; }
}
}
internal class Program
{
private static void Main()
{
try
{
var s = (TestConfigurationSection) ConfigurationManager
.GetSection("testSection");
Console.WriteLine("First Method worked: " + s.SomeSetting);
}
catch (Exception ex)
{
Console.WriteLine("First method failed");
Console.WriteLine(ex.ToString());
if (ex.InnerException != null)
{
var eex = ex.InnerException as SecurityException;
Console.WriteLine("Action: '{0}'", eex.Action.ToString());
Console.WriteLine("Demanded: '{0}'", eex.Demanded.ToString());
Console.WriteLine("RefusedSet: '{0}'", eex.RefusedSet);
Console.WriteLine("GrantedSet: '{0}'", eex.GrantedSet);
}
try
{
var config = ConfigurationManager.OpenExeConfiguration(
ConfigurationUserLevel.None);
var s = (TestConfigurationSection) config
.GetSection("testSection");
Console.WriteLine("Second Method worked: "
+ s.SomeSetting);
}
catch (Exception x)
{
Console.WriteLine("Even the second method failed!");
Console.WriteLine(ex.ToString());
}
}
}
}
}
然后用下面的添加应用程序配置文件,并替换的内容:
Then add an application configuration file and replace the contents with the following:
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<section
name="testSection"
type="AppConfigTestConsoleApplication.TestConfigurationSection, AppConfigTestConsoleApplication"
requirePermission="false"
allowDefinition="Everywhere" />
</configSections>
<testSection someSetting="10"></testSection>
</configuration>
编译并运行,这是我得到的输出:
Compile and run and this is the output I got:
C:\Users\Public\configtest>AppConfigTestConsoleApplication.exe
First method failed
System.Configuration.ConfigurationErrorsException: An error occurred creating the configuration section handler for testSection: Request failed. (C:\Users\Public\configtest\AppConfigTestConsoleApplication.exe.Config line 10) ---> System.Security.SecurityException: Request failed.
at System.RuntimeMethodHandle.PerformSecurityCheck(Object obj, RuntimeMethodHandleInternal method, RuntimeType parent, UInt32 invocationFlags)
at System.RuntimeMethodHandle.PerformSecurityCheck(Object obj, IRuntimeMethodInfo method, RuntimeType parent, UInt32 invocationFlags)
at System.Reflection.RuntimeConstructorInfo.Invoke(BindingFlags invokeAttr, Binder binder, Object[] parameters, CultureInfo culture)
at System.Reflection.ConstructorInfo.Invoke(Object[] parameters)
at System.Configuration.TypeUtil.InvokeCtorWithReflectionPermission(ConstructorInfo ctor)
at System.Configuration.RuntimeConfigurationRecord.RuntimeConfigurationFactory.CreateSectionImpl(RuntimeConfigurationRecord configRecord, FactoryRecord factoryRecord, SectionRecord sectionRecord, Object parentConfig, ConfigXmlReader reader)
at System.Configuration.RuntimeConfigurationRecord.RuntimeConfigurationFactory.CreateSectionWithRestrictedPermissions(RuntimeConfigurationRecord configRecord, FactoryRecord factoryRecord, SectionRecord sectionRecord, Object parentConfig, ConfigXmlReader reader)
at System.Configuration.RuntimeConfigurationRecord.CreateSection(Boolean inputIsTrusted, FactoryRecord factoryRecord, SectionRecord sectionRecord, Object parentConfig, ConfigXmlReader reader)
at System.Configuration.BaseConfigurationRecord.CallCreateSection(Boolean inputIsTrusted, FactoryRecord factoryRecord, SectionRecord sectionRecord, Object parentConfig, ConfigXmlReader reader, String filename, Int32 line)
--- End of inner exception stack trace ---
at System.Configuration.BaseConfigurationRecord.EvaluateOne(String[] keys, SectionInput input, Boolean isTrusted, FactoryRecord factoryRecord, SectionRecordsectionRecord, Object parentResult)
at System.Configuration.BaseConfigurationRecord.Evaluate(FactoryRecord factoryRecord, SectionRecord sectionRecord, Object parentResult, Boolean getLkg, Boolean getRuntimeObject, Object& result, Object& resultRuntimeObject)
at System.Configuration.BaseConfigurationRecord.GetSectionRecursive(String configKey, Boolean getLkg, Boolean checkPermission, Boolean getRuntimeObject, Boolean requestIsHere, Object& result, Object& resultRuntimeObject)
at System.Configuration.BaseConfigurationRecord.GetSectionRecursive(String configKey, Boolean getLkg, Boolean checkPermission, Boolean getRuntimeObject, Boolean requestIsHere, Object& result, Object& resultRuntimeObject)
at System.Configuration.BaseConfigurationRecord.GetSectionRecursive(String configKey, Boolean getLkg, Boolean checkPermission, Boolean getRuntimeObject, Boolean requestIsHere, Object& result, Object& resultRuntimeObject)
at System.Configuration.BaseConfigurationRecord.GetSection(String configKey)
at System.Configuration.ClientConfigurationSystem.System.Configuration.Internal.IInternalConfigSystem.GetSection(String sectionName)
at System.Configuration.ConfigurationManager.GetSection(String sectionName)
at AppConfigTestConsoleApplication.Program.Main()
Action: 'Demand'
Demanded: '<PermissionSet class="System.Security.PermissionSet"
version="1"
Unrestricted="true"/>
'
RefusedSet: ''
GrantedSet: ''
Second Method worked: 10
进程监视器
我跑进程监视器并设置过滤器,像这样:
Process Monitor
I ran Process Monitor and set the filter like so:
和留下508事件都是一个:
And that left 508 events that are all one of:
- 在找不到名称
- NO多个条目
- 找不到路径
- 在文件被锁定,只有读卡器
- 在没有这样的文件(只是一次C:\Windows\assembly\NativeImages_v4.0.30319_32\mscorlib\93e7df09dacd5fef442cc22d28efec83\mscorlib.ni.dll和 C:\用户\公用\ configtest \ AppConfigTestConsoleApplication.exe.config )
- 缓存溢出(对于 HKCU \控制面板\桌面\ MuiCached \机preferredUILanguages HKCU \软件\微软\的Windows \ CurrentVersion \ Explorer中\ User外壳文件夹\缓存
- NAME NOT FOUND
- NO MORE ENTRIES
- PATH NOT FOUND
- FILE LOCKED WITH ONLY READERS
- NO SUCH FILE (just once for C:\Windows\assembly\NativeImages_v4.0.30319_32\mscorlib\93e7df09dacd5fef442cc22d28efec83\mscorlib.ni.dll and C:\Users\Public\configtest\AppConfigTestConsoleApplication.exe.config)
- BUFFER OVERFLOW (for HKCU\Control Panel\Desktop\MuiCached\MachinePreferredUILanguages, HKCU\Software\Microsoft\Windows\CurrentVersion\Explorer\User Shell Folders\Cache,
有没有人有任何意见或者什么过滤器来设置去的根源在哪里?
Does anyone have any advice perhaps on what filter to set to get to the root cause?
推荐答案
我有这个当组件被封杀相同的行为(文件属性选项卡下)。该文件通过压缩到管理都通过电子邮件发送。当他救离附件,块位加入...只是当你从互联网上下载的文件等。之后,我们清除块,它工作得很好。
I had this same behavior when the assembly was "blocked" (under the file properties tab). The files were emailed via a zip to the admin. When he saved off the attachment, the block bit was added...just like when you download a file from the internet. After we clear the block, it worked fine.
这篇关于为什么使用ConfigurationManager.GetSection原因和QUOT; SecurityException异常:请求失败&QUOT;但ConfigurationManager.OpenExeConfiguration不?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!