VS 2015. Setting right target framework for ASP.NET 5 web project

21,979

Solution 1

The problem is that DNX is aware that your project is targeting dnx46 but IIS is not :). So, IIS is starting as .NET 4.5.1 (by default) and trying to load your project which isn't compatible with 4.5.1.

In a future version of the VS Tooling, we're going to do a better job of detecting that but until then, things are a little rough for Web Applications that want to target .NET versions above 4.5.1. For now, I suggest just using dnx451 until then (if you aren't depending on .NET 4.5.2/4.6 functionality), but I'll provide some instructions below on how to make this work today if you need to use 4.5.2 or higher.

Note: dnx452 and dnx46 are fully supported in Console Applications and when using servers other than IIS (such as Kestrel or WebListener). Basically anything you can launch using the native dnx.exe bootstrapper works with dnx451 and dnx46 but the other hosting environments (IIS, IIS Express) need additional hints to launch the correct framework.

To make this work today, you need to set an environment variable DNX_IIS_RUNTIME_FRAMEWORK to the target framework you want to use. You can do this in the Project Properties page for the web application, on the Debug tab. Just choose the IIS Express profile and add the environment variable as below:

Launch Profile

We're going to get this added to the Known Issues, because it looks like we missed it, and as I said above, we're going to improve the default experience in VS so this isn't necessary :).

Solution 2

"DNX_IIS_RUNTIME_FRAMEWORK" : "DNX46"

The value is case sensitive

Share:
21,979
Sergiy
Author by

Sergiy

Simplifying data search and filtering for .NET with EasyQuery. Making smart Q&A services with Aistant

Updated on August 29, 2020

Comments

  • Sergiy
    Sergiy over 3 years

    I've created new ASP.NET 5 MVC project in Visual Studio 2015. On project creation wizard I've chosen to show the templates for .NET framework 4.6 and then on the next screen selected "Web Application" from ASP.NET 5 Preview Templates.

    However, after creation it appears that the project listed only "dnx451" and "dnxcore50" in "frameworks" section of project.json:

      "frameworks": {
        "dnx451": { },
        "dnxcore50": { }
      },
    

    I've tried to change "dnx451" to "dnx46". The project has been built well but when I tried to run it, I got the following error message:

    The current runtime target framework is not compatible with '...'.

    Current runtime Target Framework: 'DNX,Version=v4.5.1 (dnx451)' Type: CLR Architecture: x86 Version: 1.0.0-beta5

    How is it possible to change that "target framework" for ASP.NET 5 project?

    Here is my global.json now:

    {
      "projects": [
        "src",
        "test",
        "wrap"
      ],
      "sdk": {
        "version": "1.0.0-beta5",
        "runtime": "clr",
        "architecture": "x86"
      }
    }
    

    but it does not really matter what is listed there. I've already tried different builds of 1.0.0-beta5 and the latest 1.0.0-beta6

  • Sergiy
    Sergiy almost 9 years
    Thank you for so detailed explanation. Good to know that it was not my fault :)
  • Dbl
    Dbl over 8 years
    @Andrew Nurse Do i need to uninstall beta5 for this to work? apparently it keeps trying to start iis with dnx 451 despite my efforts to use a specific runtime (beta6)
  • crazy_in_love
    crazy_in_love over 8 years
    Today I tried to create a new project but this error keeps happening (beta6). This solution never worked for me.
  • Nathan Teague
    Nathan Teague over 8 years
    In case anyone had not stumbled on this yet -- for production, IIS won't see this setting, unless the environment variable is manually set on the server. I have actually been building more outside of vs2015 and authoring a publish powershell script; this solved the issue for me, while allowing me to keep the admins from clawing ef7 and DI from my cold, dead, hands
  • DRobertE
    DRobertE over 8 years
    From what I've read DNX for framework identification is going away. After reading these two articles hanselman.com/blog/….... github.com/dotnet/corefx/blob/master/Documentation/project-d‌​ocs/…
  • Gobe
    Gobe about 8 years
    Briefly, I had class libraries targeting at .NET 4.5.2 and my just updated ASP.NET 5 framework project created from scratch had DNX 4.5.1 included. As I do not depend on 4.5.2+ features, I have targeted all my class libraries to .NET 4.5.1 - rebuilt them (very important) - and then it was finally possible to reference them.