Como ya se ha señalado por /programming/32780315#34391473 , la solución rápida es utilizar el gestor de paquetes,
Tools
> Nuget Package Manager
> Package Manager Console
, para funcionar
Update-Package Microsoft.CodeDom.Providers.DotNetCompilerPlatform -r
Pero una solución alternativa (que recrea de forma automática y silenciosa sus paquetes si faltan) es eliminar un atributo del Web.config
archivo de su proyecto .
( Web.config
está en el mismo directorio que su.csproj
archivo).
Abra el Web.config
archivo en un editor de texto (o dentro de Visual Studio).
- En la etiqueta configuration
> system.codedom
> compilers
> compiler language="c#;cs;csharp"
, eliminar completamente el type
atributo.
<?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 resumen, elimine la línea que comienza con type="Microsoft.CodeDom.Providers.DotNetCompilerPlatform.CSharpCodeProvider, Microsoft
.
(Presumiblemente, la misma solución funciona tanto para Visual Basic como para Csharp, pero no lo he probado).
Visual Studio se encargará del resto. No más Server Error in '/' Application
.
En el código de ejemplo que proporcioné en el archivo zip anterior, ahora obtendrá HTTP Error 403
cuando presione Ctrl+ F5.
Intente reemplazar http://localhost:64195
en su navegador web con http://localhost:64195/api/products
.
La API web ahora se muestra como debería:
Como provocación, intenté eliminar todo el package
directorio de mi solución de Visual Studio.
Se recreó automática y silenciosamente tan pronto como la (re) construí.
Por último, pero no menos importante, aquí hay un código que reproduce el error:
http://schulze.000webhostapp.com/vs/SrvrErr-reproduce.zip (Originalmente de
https://github.com/aspnet/AspNetDocs/tree/master/aspnet / web-api / overview / advanced / calling-a-web-api-from-a-net-client / sample / server / ProductsApp )