ASP MVC Security Exception в среднем уровне доверия - PullRequest
1 голос
/ 27 октября 2011

Эта строка кода:

var user = users.SingleOrDefault(u => u.EmailAddress == form.EmailAddress);

, где пользователи - это коллекция

public class User
{
    [Key, Required]
    public string EmailAddress { get; set; }

    public string PasswordHash { get; set; }

    public string PasswordSalt { get; protected set; }
}

создает исключение при среднем уровне доверия.

Есть ли способ заставить его работать на этом уровне доверия?

Я попытался подписать свои сборки ключом, но проблема все еще существует.

Я использую Entity Framework и ASP.NET 4.0.

Я не могу изменить уровень доверия (код работает нормально при полном доверии).

Вот стек исключений:

SecurityException: Richiesta di autorizzazione di tipo 'System.Security.Permissions.ReflectionPermission, mscorlib, Version=4.0.0.0,    Culture=neutral, PublicKeyToken=b77a5c561934e089' non soddisfatta.]
System.Security.CodeAccessSecurityEngine.Check(Object demand, StackCrawlMark& stackMark, Boolean isPermSet) +0
System.Security.CodeAccessSecurityEngine.Check(CodeAccessPermission cap, StackCrawlMark& stackMark) +31
System.Security.CodeAccessPermission.Demand() +46
System.Data.Common.Internal.Materialization.Translator.DemandMemberAccess() +50
System.Data.Common.Internal.Materialization.Shaper`1..ctor(DbDataReader reader, ObjectContext context, MetadataWorkspace workspace, MergeOption mergeOption, Int32 stateCount, CoordinatorFactory`1 rootCoordinatorFactory, Action checkPermissions, Boolean readerOwned) +165
System.Data.Common.Internal.Materialization.ShaperFactory`1.Create(DbDataReader reader, ObjectContext context, MetadataWorkspace workspace, MergeOption mergeOption, Boolean readerOwned) +93
System.Data.Objects.Internal.ObjectQueryExecutionPlan.Execute(ObjectContext context, ObjectParameterCollection parameterValues) +736
System.Data.Objects.ObjectQuery`1.GetResults(Nullable`1 forMergeOption) +149
 System.Data.Objects.ObjectQuery`1.System.Collections.Generic.IEnumerable<T>.GetEnumerator() +44
System.Linq.Enumerable.SingleOrDefault(IEnumerable`1 source) +184
System.Data.Objects.ELinq.ObjectQueryProvider.<GetElementFunction>b__2(IEnumerable`1 sequence) +41
System.Data.Objects.ELinq.ObjectQueryProvider.ExecuteSingle(IEnumerable`1 query, Expression queryRoot) +59
System.Data.Objects.ELinq.ObjectQueryProvider.System.Linq.IQueryProvider.Execute(Expression expression) +150
System.Data.Entity.Internal.Linq.DbQueryProvider.Execute(Expression expression) +102
System.Linq.Queryable.SingleOrDefault(IQueryable`1 source, Expression`1 predicate) +300

1 Ответ

0 голосов
/ 27 октября 2011

Что такое класс пользователей? Это EF или у вас есть? Если это ваше, добавьте AllowPartiallyTrustedCallersAttribute к нему.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...