Comme nous l' avons noté /programming/32780315#34391473 , la solution rapide est d'utiliser le gestionnaire de paquets,
Tools
> Nuget Package Manager
> Package Manager Console
, pour exécuter
Update-Package Microsoft.CodeDom.Providers.DotNetCompilerPlatform -r
Mais une solution alternative (qui recrée automatiquement et silencieusement vos packages s'ils sont manquants) consiste à supprimer un attribut du Web.config
fichier de votre projet .
(se Web.config
trouve dans le même répertoire que votre .csproj
fichier.)
Ouvrez le Web.config
fichier dans un éditeur de texte (ou dans Visual Studio).
- Dans la balise configuration
> system.codedom
> compilers
> compiler language="c#;cs;csharp"
, supprimer complètement l' type
attribut.
<?xml version="1.0" encoding="utf-8"?>
<configuration>
<!-- ... -->
<system.codedom>
<compilers>
<compiler language="c#;cs;csharp" extension=".cs"
type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.5.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
warningLevel="4" compilerOptions="/langversion:default /nowarn:1659;1699;1701"/>
<compiler language="vb;vbs;visualbasic;vbscript" extension=".vb"
type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.VBCodeProvider, Microsoft.CodeDom.Providers.DotNetCompilerPlatform, Version=1.0.5.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"
warningLevel="4" compilerOptions="/langversion:default /nowarn:41008 /define:_MYTYPE=\"Web\" /optionInfer+"/>
</compilers>
</system.codedom>
</configuration>
En bref, supprimez la ligne commençant par type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft
.
(Vraisemblablement, le même correctif fonctionne pour Visual Basic ainsi que pour Csharp, mais je ne l'ai pas essayé.)
Visual Studio s'occupe du reste. Pas plus Server Error in '/' Application
.
Dans l'exemple de code que j'ai fourni dans le fichier zip ci-dessus, vous obtiendrez maintenant HTTP Error 403
lorsque vous appuyez sur Ctrl+ F5.
Essayez de remplacer http://localhost:64195
dans votre navigateur Web par http://localhost:64195/api/products
.
L'API Web s'affiche désormais comme il se doit:
Par provocation, j'ai essayé de supprimer tout le package
répertoire de ma solution Visual Studio.
Il a été recréé automatiquement et silencieusement dès que je l'ai (re) construit.
Enfin, voici le code qui reproduit l'erreur:
http://schulze.000webhostapp.com/vs/SrvrErr-reproduce.zip (à l'origine de
https://github.com/aspnet/AspNetDocs/tree/master/aspnet / web-api / présentation / avancé / appeler-un-web-api-à-partir-d'un-net-client / exemple / serveur / ProductsApp )