web-dev-qa-db-fra.com

Impossible de charger le fichier ou l'assembly 'log4net, Version = 1.2.10.0, Culture = neutral, PublicKeyToken = 1b44e1d426115821'

J'ai ajouté Log4Net dans mon projet en utilisant NuGet Package Manager et il montre la version 2.3 installée sur mon système.

Voici mon entrée de configuration:

  <configSections>
    <section name="dataConfiguration" type="Microsoft.Practices.EnterpriseLibrary.Data.Configuration.DatabaseSettings, Microsoft.Practices.EnterpriseLibrary.Data, Version=4.1.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>
    <section name="log4net" type="log4net.Config.Log4NetConfigurationSectionHandler, log4net" />
  </configSections>

puis référence à ce fichier ici

  <log4net configSource="Log4Net.config" />
  <system.serviceModel>

mais quand je lance le site Web. L'exception suivante s'affiche.

Could not load file or Assembly 'log4net, Version=1.2.10.0, Culture=neutral, PublicKeyToken=1b44e1d426115821' or one of its dependencies. The located Assembly's manifest definition does not match the Assembly reference. (Exception from HRESULT: 0x80131040)

Description: An unhandled exception occurred during the execution of the current web request. Please review the stack trace for more information about the error and where it originated in the code. 

Exception Details: System.IO.FileLoadException: Could not load file or Assembly 'log4net, Version=1.2.10.0, Culture=neutral, PublicKeyToken=1b44e1d426115821' or one of its dependencies. The located Assembly's manifest definition does not match the Assembly reference. (Exception from HRESULT: 0x80131040)

Source Error: 

An unhandled exception was generated during the execution of the current web request. Information regarding the Origin and location of the exception can be identified using the exception stack trace below.

J'ai vu que la DLL est présente dans le dossier bin mais montre la version 1.2.13.0 à la place.

Comment puis-je changer la version d'assemblage?

17
Naveed Butt

Il semble que l'un des projets de votre solution ou peut-être une DLL tierce ait été construit avec une version différente de log4net. Soit vous mettez à jour les références à log4net dans tous les projets (avec des DLL tierces, cela n'aidera pas), soit vous pouvez ajouter le paramètre de redirection d'assembly au web.config (app.config) qui redirigera la ou les versions spécifiées de log4net vers un nouveau.

Mettez cette section dans votre web.config (app.config) n'importe où sous l'élément de configuration

<runtime>
    <assemblyBinding xmlns="urn:schemas-Microsoft-com:asm.v1">
        <dependentAssembly>
            <assemblyIdentity name="log4net"
                          publicKeyToken="1b44e1d426115821"
                          culture="neutral" />
            <bindingRedirect oldVersion="1.2.10.0"
                         newVersion="1.2.13.0"/>
        </dependentAssembly>
    </assemblyBinding>
</runtime>

Pour plus d'informations, consultez la page de documentation sur msdn .

15
pepo