2017-01-18 3 views
0

В настоящее время мы находимся на общем сервере Windows через Hostgator. Они вынуждают общие серверы работать в среде «Средний траст». Они имеют MySql.Data.DLL (6.9.7) в GAC. Проблема в том, что они не имеют MySql.Data.Entity.EF6.DLL в GAC, и они не установят его для меня. Поэтому я попробовал ссылку там dll mysql.Data из gac, а затем ссылался на MySql.Data.Entity.EF6.dll (6.9.9) из нашего проекта. Когда я это сделаю, я получаю сообщение об ошибке безопасности. Я предполагаю, что это связано с тем, что dll EF6 требует полного доверия. Любое решение? БлагодаряMySql Data Entity EF6 In Medium Trust

Ошибка:

{"Message":"An error has occurred.","ExceptionMessage":"Request for the permission of type 'System.Security.Permissions.EnvironmentPermission, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089' failed.","ExceptionType":"System.Security.SecurityException","StackTrace":" at System.Security.CodeAccessSecurityEngine.Check(Object demand, StackCrawlMark& stackMark, Boolean isPermSet)\r\n at System.Security.CodeAccessSecurityEngine.Check(CodeAccessPermission cap, StackCrawlMark& stackMark)\r\n at System.Security.CodeAccessPermission.Demand()\r\n at System.Environment.GetEnvironmentVariable(String variable)\r\n at MySql.Data.MySqlClient.MySqlConnectAttrs.Is64BitOS()\r\n at MySql.Data.MySqlClient.MySqlConnectAttrs.get_Platform()"}

WebConfig:

<configSections> 
    <section name="entityFramework" type="System.Data.Entity.Internal.ConfigFile.EntityFrameworkSection, EntityFramework, Version=6.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" /> 
</configSections> 

<entityFramework> 
<providers> 
    <provider invariantName="MySql.Data.MySqlClient" type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6, Version=6.9.7.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d"></provider> 
</providers> 
</entityFramework> 
<system.data> 
<DbProviderFactories> 
    <remove invariant="MySql.Data.MySqlClient" /> 
    <add name="MySQL Data Provider" invariant="MySql.Data.MySqlClient" description=".Net Framework Data Provider for MySQL" type="MySql.Data.MySqlClient.MySqlClientFactory, MySql.Data, Version=6.9.7.0, Culture=neutral, PublicKeyToken=c5687fc88969c44d" /> 
</DbProviderFactories> 
</system.data> 

<dependentAssembly> 
<assemblyIdentity name="MySql.Data" publicKeyToken="c5687fc88969c44d" /> 
<bindingRedirect oldVersion="0.0.0.0-6.9.9.0" newVersion="6.9.7.0" /> 
</dependentAssembly> 
<dependentAssembly> 
<assemblyIdentity name="MySql.Data.Entity.EF6" publicKeyToken="c5687fc88969c44d" /> 
<bindingRedirect oldVersion="0.0.0.0-6.9.9.0" newVersion="6.9.9.0" /> 
</dependentAssembly> 

enter image description here

ответ

0

Я не знаю, ошибка, которую вы mentioned.But я предлагаю вам внимательно прочитать эту страницу https://dev.mysql.com/doc/connector-net/en/connector-net-entityframework60.html
Ваш WebConfig не такой, как указано ниже.

<connectionStrings> 
 
    <add name="MyContext" providerName="MySql.Data.MySqlClient" 
 
     connectionString="server=localhost;port=3306;database=mycontext;uid=root;password=********"/> 
 
</connectionStrings> 
 
<entityFramework codeConfigurationType="MySql.Data.Entity.MySqlEFConfiguration, MySql.Data.Entity.EF6"> 
 
    <defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework"/> 
 
    <providers> 
 
     <provider invariantName="MySql.Data.MySqlClient" 
 
      type="MySql.Data.MySqlClient.MySqlProviderServices, MySql.Data.Entity.EF6"/> 
 
     <provider invariantName="System.Data.SqlClient" 
 
      type="System.Data.Entity.SqlServer.SqlProviderServices, EntityFramework.SqlServer"/> 
 
    </providers> 
 
</entityFramework>

+0

Это не сделал никаких изменений ничего. По-прежнему возникает ошибка безопасности. благодаря – mikemike396

Смежные вопросы