Eine scheinbar einfache Frage, welche allerdings einige Fallen in sich birgt.
Grund hierfür liegt darin, dass man theoretisch zwischen CLR Version und Framework Version unterscheiden kann. So war es in den .NET 3.5 Zeiten üblich, dass die CLR Version weiterhin auf Version 2.0 blieb, weil nur neue Libraries in das Framework gekommen sind.
Allerdings ist meist mit “.NET Framework 4.5” die Kombination aus der “neusten” Framework- und CLR Version gemeint. Allerdings ist .NET 4.5 ein “in-place upgrade” für .NET 4.0. Was die ganze Sache nicht einfacher macht.
Guter Einstieg (und ich komme weiter unten nochmal darauf zurück) ist der Post von Scott Hanselman:
.NET Versioning and Multi-Targeting - .NET 4.5 is an in-place upgrade to .NET 4.0
Einfacher Check für: Ist die .NET Framework Version 4.5 installiert?
Um festzustellen, welche Version installiert ist, liefert die Registry den entscheidenden Hinweis unter dem Pfad “Computer\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full”
In meinem Fall: Jepp - .NET 4.5 ist installiert. Diese Prüfung geht vermutlich nur wenn man selber System-Admin ist und eine volle Kontrolle über das System und die Anwendungen hat.
Mit der Information wissen wir schonmal: Das Framework ist auf dem System installiert.
Läuft meine Applikation unter .NET 4.5?
Hiermit ist jetzt nicht gemeint ob die Applikation “kompatibel” zu .NET 4.5 ist, sondern ob die Applikation überhaupt .NET 4.5 Features nutzen kann.
Diese Frage ist schon etwas schwer zu beantworten, da dies z.B. von der app.config bzw. web.config abhängig ist und wenn der IIS im Spiel ist muss der AppPool entsprechend eingestellt sein.
Wer den Hanselman Post gelesen hat, der wird jetzt eine sehr verkürzte Fassung dessem lesen ;)
Wer eine Desktop Applikation ausführt und nicht die geeignete Framework-Version, welche im supportedRuntime Element der app.config ausführt, der bekommt eine Fehlermeldung. Damit sage ich der Runtime, dass meine App .NET 4.5 benötigt:
<?xml version="1.0" encoding="utf-8" ?> <configuration> <startup> <supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5" /> </startup> </configuration>
Falls kein .NET 4.5 vorhanden ist wird, kommt diese Fehlermeldung:
Für Web-Applikationen gibt es ein ähnliches Element in der web.config:
<configuration> <system.web> <compilation debug="true" strict="false" explicit="true" targetFramework="4.5" /> </system.web> </configuration>
Falls die im TargetFramework vorgegebene Runtime nicht da ist, gibts eine Fehlermeldung beim Aufruf der Webapp.
Best Practice: Feature Detection zur Laufzeit
Da das Framework immer mehr Libraries umfasst und jede der Libraries eine andere Versionsnummer haben können und sich die Runtime unterscheiden kann, ist es wohl am besten, wenn man genau prüft, ob z.B. eine bestimmte Klasse vorhanden ist.
Empfehlenswerte Links
Der Blogpost von Scott Hanselman ist zu dem Thema sehr aufschlussreich und verweisst auf eine sehr gute Erklärung der Problematik auf Stackoverflow.