의 버전을 반환하는 PowerShell 스크립트.기계의 NET Framework?
의 버전을 반환하는 PowerShell 스크립트는 무엇입니까?기계의 NET Framework?
제 첫 번째 추측은 WMI와 관련된 것입니다. 더 좋은 것이 있을까요?
설치할 때마다 최신 버전만 반환하는 것이 한 줄로 되어 있어야 합니다.NET [각 라인에서].
레지스트리를 사용하려면 4.x Framework의 전체 버전을 가져오려면 레지스트리를 다시 사용해야 합니다.이전의 답변은 둘 다 시스템의 루트 번호를 반환합니다.NET 3.0(3.0 아래에 중첩된 WCF 및 WPF 번호가 더 높음 - 설명할 수 없음) 및 4.0에 대해 아무것도 반환하지 않음...
편집: 의 경우.Net 4.5 이상에서는 다시 약간 변경되었습니다. 이제 릴리스 값을 a로 변환하는 방법을 설명하는 MSDN 기사가 있습니다.순 버전 번호, 완전한 열차 사고입니다 :-(
이것은 제가 보기에 맞습니다(3.0에서 WCF 및 WPF에 대한 별도의 버전 번호를 출력합니다).저는 그것이 무엇에 관한 것인지 모릅니다).또한 4.0에서 클라이언트와 전체를 모두 출력합니다(둘 다 설치된 경우).
Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -recurse |
Get-ItemProperty -name Version,Release -EA 0 |
Where { $_.PSChildName -match '^(?!S)\p{L}'} |
Select PSChildName, Version, Release
MSDN 문서를 기반으로 룩업 테이블을 작성하고 4.5 이후 릴리스에 대한 마케팅 제품 버전 번호를 반환할 수 있습니다.
$Lookup = @{
378389 = [version]'4.5'
378675 = [version]'4.5.1'
378758 = [version]'4.5.1'
379893 = [version]'4.5.2'
393295 = [version]'4.6'
393297 = [version]'4.6'
394254 = [version]'4.6.1'
394271 = [version]'4.6.1'
394802 = [version]'4.6.2'
394806 = [version]'4.6.2'
460798 = [version]'4.7'
460805 = [version]'4.7'
461308 = [version]'4.7.1'
461310 = [version]'4.7.1'
461808 = [version]'4.7.2'
461814 = [version]'4.7.2'
528040 = [version]'4.8'
528049 = [version]'4.8'
}
# For One True framework (latest .NET 4x), change the Where-Object match
# to PSChildName -eq "Full":
Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -Recurse |
Get-ItemProperty -name Version, Release -EA 0 |
Where-Object { $_.PSChildName -match '^(?!S)\p{L}'} |
Select-Object @{name = ".NET Framework"; expression = {$_.PSChildName}},
@{name = "Product"; expression = {$Lookup[$_.Release]}},
Version, Release
사실, 제가 이 답변을 계속 업데이트해야 하기 때문에, 여기 해당 웹 페이지의 마크다운 소스에서 위의 스크립트를 생성하기 위한 스크립트가 있습니다.이것은 아마 어느 시점에서 깨질 것이기 때문에 위의 현재 복사본을 보관하고 있습니다.
# Get the text from github
$url = "https://raw.githubusercontent.com/dotnet/docs/master/docs/framework/migration-guide/how-to-determine-which-versions-are-installed.md"
$md = Invoke-WebRequest $url -UseBasicParsing
$OFS = "`n"
# Replace the weird text in the tables, and the padding
# Then trim the | off the front and end of lines
$map = $md -split "`n" -replace " installed [^|]+" -replace "\s+\|" -replace "\|$" |
# Then we can build the table by looking for unique lines that start with ".NET Framework"
Select-String "^.NET" | Select-Object -Unique |
# And flip it so it's key = value
# And convert ".NET FRAMEWORK 4.5.2" to [version]4.5.2
ForEach-Object {
[version]$v, [int]$k = $_ -replace "\.NET Framework " -split "\|"
" $k = [version]'$v'"
}
# And output the whole script
@"
`$Lookup = @{
$map
}
# For extra effect we could get the Windows 10 OS version and build release id:
try {
`$WinRelease, `$WinVer = Get-ItemPropertyValue "HKLM:\SOFTWARE\Microsoft\Windows NT\CurrentVersion" ReleaseId, CurrentMajorVersionNumber, CurrentMinorVersionNumber, CurrentBuildNumber, UBR
`$WindowsVersion = "`$(`$WinVer -join '.') (`$WinRelease)"
} catch {
`$WindowsVersion = [System.Environment]::OSVersion.Version
}
Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -Recurse |
Get-ItemProperty -name Version, Release -EA 0 |
# For The One True framework (latest .NET 4x), change match to PSChildName -eq "Full":
Where-Object { `$_.PSChildName -match '^(?!S)\p{L}'} |
Select-Object @{name = ".NET Framework"; expression = {`$_.PSChildName}},
@{name = "Product"; expression = {`$Lookup[`$_.Release]}},
Version, Release,
# Some OPTIONAL extra output: PSComputerName and WindowsVersion
# The Computer name, so output from local machines will match remote machines:
@{ name = "PSComputerName"; expression = {`$Env:Computername}},
# The Windows Version (works on Windows 10, at least):
@{ name = "WindowsVersion"; expression = { `$WindowsVersion }}
"@
스크립트에 v4.8 지원 추가:
Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -recurse |
Get-ItemProperty -name Version,Release -EA 0 |
Where { $_.PSChildName -match '^(?![SW])\p{L}'} |
Select PSChildName, Version, Release, @{
name="Product"
expression={
switch -regex ($_.Release) {
"378389" { [Version]"4.5" }
"378675|378758" { [Version]"4.5.1" }
"379893" { [Version]"4.5.2" }
"393295|393297" { [Version]"4.6" }
"394254|394271" { [Version]"4.6.1" }
"394802|394806" { [Version]"4.6.2" }
"460798|460805" { [Version]"4.7" }
"461308|461310" { [Version]"4.7.1" }
"461808|461814" { [Version]"4.7.2" }
"528040|528049" { [Version]"4.8" }
{$_ -gt 528049} { [Version]"Undocumented version (> 4.8), please update script" }
}
}
}
gci 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' |
sort pschildname -des |
select -fi 1 -exp pschildname
이 응답은 설치된 경우 4.5를 반환하지 않습니다.@Jaykul과 recurse를 사용하는 아래의 대답은 그렇습니다.
[environment]::Version
여기에 설명된 대로 현재 PSH의 복사본이 사용 중인 CLR의 인스턴스를 제공합니다.
올바른 구문:
[System.Runtime.InteropServices.RuntimeEnvironment]::GetSystemVersion()
#or
$PSVersionTable.CLRVersion
함수는 다음과 같은 문자열을 반환합니다.
v2.0.50727 #PowerShell v2.0 in Win 7 SP1
아니면 이렇게
v4.0.30319 #PowerShell v3.0 (Windows Management Framework 3.0) in Win 7 SP1
$PSVersionTable
읽기 전용 개체입니다.CLRVersion 속성은 다음과 같은 구조화된 버전 번호입니다.
Major Minor Build Revision
----- ----- ----- --------
4 0 30319 18444
osx의 powershell에서 탭 완료를 통해 이를 찾았습니다.
[System.Runtime.InteropServices.RuntimeInformation]::get_FrameworkDescription() .NET Core 4.6.25009.03
단순한 스크립트를 사용하여 모든 플랫폼 및 아키텍처에 대해 이를 수행할 수 있는 신뢰할 수 있는 방법은 없습니다.신뢰할 수 있는 방법을 알고 싶다면 블로그 게시물 업데이트 샘플에서 시작하십시오.보다 심층적인 검사를 수행하는 NET Framework 탐지 코드입니다.
좋은 해결책
다운로드 가능한 DotNetVersionLister 모듈(레지스트리 정보 및 일부 버전-마케팅-버전 조회 테이블 기반)을 사용해 보십시오.
다음과 같이 사용할 수 있습니다.
PS> Get-DotNetVersion -LocalHost -nosummary
ComputerName : localhost
>=4.x : 4.5.2
v4\Client : Installed
v4\Full : Installed
v3.5 : Installed
v3.0 : Installed
v2.0.50727 : Installed
v1.1.4322 : Not installed (no key)
Ping : True
Error :
아니면 이런 식으로 테스트를 해보길 원하신다면요.NET 프레임워크 >= 4.*:
PS> (Get-DotNetVersion -LocalHost -nosummary).">=4.x"
4.5.2
그러나 호환되지 않아 PS v2.0(Win 7, Win Server 2010 표준)에서는 작동하지 않습니다(설치/가져오기)...
아래의 "레거시" 기능에 대한 동기 부여
(이 문서를 읽지 않고 아래 코드를 사용할 수 있습니다.)
우리는 일부 컴퓨터에서 PS 2.0으로 작업해야 했고 위의 DotNetVersionLister를 설치/가져올 수 없었습니다.
다른 시스템에서는 (PS 2.0에서) PS 5.1로 업데이트하려고 했습니다(이를 위해 필요함).NET Framework >= 4.5), 두 회사의 맞춤형 솔루션을 사용합니다.Install-DotnetLatestCompany
그리고.Install-PSLatestCompany
.
관리자에게 설치/업데이트 프로세스를 원활하게 안내하려면 을 결정해야 합니다.기존의 모든 시스템 및 PS 버전에서 이러한 기능의 NET 버전.
따라서 모든 환경에서 보다 안전하게 결정하기 위해 아래의 함수도 사용했습니다.
레거시 PS 환경을 위한 기능(예: PS v2.0)
따라서 다음 코드와 아래(추출된) 사용 예는 여기에서 유용합니다(여기의 다른 답변을 기반으로 함).
function Get-DotNetVersionByFs {
<#
.SYNOPSIS
NOT RECOMMENDED - try using instead:
Get-DotNetVersion
from DotNetVersionLister module (https://github.com/EliteLoser/DotNetVersionLister),
but it is not usable/importable in PowerShell 2.0
Get-DotNetVersionByReg
reg(istry) based: (available herin as well) but it may return some wrong version or may not work reliably for versions > 4.5
(works in PSv2.0)
Get-DotNetVersionByFs (this):
f(ile) s(ystem) based: determines the latest installed .NET version based on $Env:windir\Microsoft.NET\Framework content
this is unreliable, e.g. if 4.0* is already installed some 4.5 update will overwrite content there without
renaming the folder
(works in PSv2.0)
.EXAMPLE
PS> Get-DotnetVersionByFs
4.0.30319
.EXAMPLE
PS> Get-DotnetVersionByFs -All
1.0.3705
1.1.4322
2.0.50727
3.0
3.5
4.0.30319
.NOTES
from https://stackoverflow.com/a/52078523/1915920
#>
[cmdletbinding()]
param(
[Switch]$All ## do not return only latest, but all installed
)
$list = ls $Env:windir\Microsoft.NET\Framework |
?{ $_.PSIsContainer -and $_.Name -match '^v\d.[\d\.]+' } |
%{ $_.Name.TrimStart('v') }
if ($All) { $list } else { $list | select -last 1 }
}
function Get-DotNetVersionByReg {
<#
.SYNOPSIS
NOT RECOMMENDED - try using instead:
Get-DotNetVersion
From DotNetVersionLister module (https://github.com/EliteLoser/DotNetVersionLister),
but it is not usable/importable in PowerShell 2.0.
Determines the latest installed .NET version based on registry infos under 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP'
.EXAMPLE
PS> Get-DotnetVersionByReg
4.5.51209
.EXAMPLE
PS> Get-DotnetVersionByReg -AllDetailed
PSChildName Version Release
----------- ------- -------
v2.0.50727 2.0.50727.5420
v3.0 3.0.30729.5420
Windows Communication Foundation 3.0.4506.5420
Windows Presentation Foundation 3.0.6920.5011
v3.5 3.5.30729.5420
Client 4.0.0.0
Client 4.5.51209 379893
Full 4.5.51209 379893
.NOTES
from https://stackoverflow.com/a/52078523/1915920
#>
[cmdletbinding()]
param(
[Switch]$AllDetailed ## do not return only latest, but all installed with more details
)
$Lookup = @{
378389 = [version]'4.5'
378675 = [version]'4.5.1'
378758 = [version]'4.5.1'
379893 = [version]'4.5.2'
393295 = [version]'4.6'
393297 = [version]'4.6'
394254 = [version]'4.6.1'
394271 = [version]'4.6.1'
394802 = [version]'4.6.2'
394806 = [version]'4.6.2'
460798 = [version]'4.7'
460805 = [version]'4.7'
461308 = [version]'4.7.1'
461310 = [version]'4.7.1'
461808 = [version]'4.7.2'
461814 = [version]'4.7.2'
}
$list = Get-ChildItem 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP' -Recurse |
Get-ItemProperty -name Version, Release -EA 0 |
# For One True framework (latest .NET 4x), change match to PSChildName -eq "Full":
Where-Object { $_.PSChildName -match '^(?!S)\p{L}'} |
Select-Object `
@{
name = ".NET Framework" ;
expression = {$_.PSChildName}},
@{ name = "Product" ;
expression = {$Lookup[$_.Release]}},
Version, Release
if ($AllDetailed) { $list | sort version } else { $list | sort version | select -last 1 | %{ $_.version } }
}
사용 예:
PS> Get-DotNetVersionByFs
4.0.30319
PS> Get-DotNetVersionByFs -All
1.0.3705
1.1.4322
2.0.50727
3.0
3.5
4.0.30319
PS> Get-DotNetVersionByReg
4.5.51209
PS> Get-DotNetVersionByReg -AllDetailed
.NET Framework Product Version Release
-------------- ------- ------- -------
v2.0.50727 2.0.50727.5420
v3.0 3.0.30729.5420
Windows Communication Foundation 3.0.4506.5420
Windows Presentation Foundation 3.0.6920.5011
v3.5 3.5.30729.5420
Client 4.0.0.0
Client 4.5.2 4.5.51209 379893
Full 4.5.2 4.5.51209 379893
다음 항목을 찾으려면 스크립트 페이지를 참조하십시오.NET 버전은 원격 워크스테이션에 설치됩니다.
해당 스크립트는 를 찾는 데 유용할 수 있습니다.네트워크의 여러 시스템에 대한 NET 버전입니다.
안이쁘다.확실히 예쁘지 않습니다.
ls $Env:windir\Microsoft.NET\Framework | ? { $_.PSIsContainer } | select -exp Name -l 1
이것은 작동할 수도 있고 작동하지 않을 수 있습니다.그러나 최신 버전에 관해서는 이전 버전(1.0, 1.1)에는 기본적으로 빈 폴더가 있지만 최신 버전은 아니기 때문에 이 폴더는 적절한 프레임워크가 설치된 후에만 나타납니다.
그래도 더 좋은 방법이 있을 거라고 생각합니다.
다음은 msft 문서에 이어 이 질문에 대한 제 견해입니다.
$gpParams = @{
Path = 'HKLM:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full'
ErrorAction = 'SilentlyContinue'
}
$release = Get-ItemProperty @gpParams | Select-Object -ExpandProperty Release
".NET Framework$(
switch ($release) {
({ $_ -ge 528040 }) { ' 4.8'; break }
({ $_ -ge 461808 }) { ' 4.7.2'; break }
({ $_ -ge 461308 }) { ' 4.7.1'; break }
({ $_ -ge 460798 }) { ' 4.7'; break }
({ $_ -ge 394802 }) { ' 4.6.2'; break }
({ $_ -ge 394254 }) { ' 4.6.1'; break }
({ $_ -ge 393295 }) { ' 4.6'; break }
({ $_ -ge 379893 }) { ' 4.5.2'; break }
({ $_ -ge 378675 }) { ' 4.5.1'; break }
({ $_ -ge 378389 }) { ' 4.5'; break }
default { ': 4.5+ not installed.' }
}
)"
이 예제는 모든 PowerShell 버전에서 작동하며 4.8이 마지막 버전이기 때문에 영구적으로 작동합니다.NET Framework 버전.
이것은 순전히 제가 이것을 만들고 편집하는 데 시간을 써야 했기 때문입니다. 그래서 저는 그것을 다른 모든 사람들에게 제공하고 있습니다.
아래 스크립트는 선택한(코드) OU에 있는 각 시스템의 버전 및 취약성 상태와 함께 몇 개의 CSV 파일을 TEMP로 출력합니다. 시스템의 OU를 원격으로 "보안 감사"할 수 있습니다.
연결 테스트 라인 RSAT에 필요한 Powershell 7.0은 Powershell 7.0을 얻는 데 필요한 AD 모듈 Visual Studio Code를 얻는 데 필요합니다(win7의 경우).
이 문서를 읽을 때쯤이면 파일의 버전 목록이 최신 버전이 아닐 수 있습니다.이 웹 사이트 https://learn.microsoft.com/en-us/dotnet/framework/migration-guide/versions-and-dependencies 을 사용하여 새로운 닷넷 항목을 추가합니다.이는 "DotNet4Builds"의 주요 가치입니다.
PromodisedCheck.csv에서 기계가 =0으로 표시되면 보안이 수동으로 해제된 상태이며 공급업체가 이를 수행했는지 아니면 의심스러운 직원인지 여부를 제기해야 합니다.
이것이 누군가 사업을 위해 그것을 찾는 데 도움이 되길 바랍니다.
<#
Script Name : Get-DotNetVersions_Tweaked.ps1
Description : This script reports the various .NET Framework versions installed on the local or a remote set of computers
Author : Original by Martin Schvartzman - Edited by Mark Purnell
Reference : https://msdn.microsoft.com/en-us/library/hh925568
#>
$ErrorActionPreference = "Continue”
import-module ActiveDirectory
$searchOU = "OU=OU LEVEL 1,OU=OU LEVEL 2,OU=MACHINES,OU=OUR LAPTOPS,DC=PUT,DC=MY,DC=DOMAIN,DC=CONTROLLER,DC=HERE,DC=OK"
$computerList = Get-ADComputer -searchbase $searchOU -Filter *
function Get-DotNetFrameworkVersion($computerList)
{
$dotNetter = @()
$compromisedCheck = @()
$dotNetRoot = 'SOFTWARE\Microsoft\.NETFramework'
$dotNetRegistry = 'SOFTWARE\Microsoft\NET Framework Setup\NDP'
$dotNet4Registry = 'SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\Full'
$dotNet4Builds = @{
'30319' = @{ Version = [System.Version]'4.0' }
'378389' = @{ Version = [System.Version]'4.5' }
'378675' = @{ Version = [System.Version]'4.5.1' ; Comment = '(8.1/2012R2)' }
'378758' = @{ Version = [System.Version]'4.5.1' ; Comment = '(8/7 SP1/Vista SP2)' }
'379893' = @{ Version = [System.Version]'4.5.2' }
'380042' = @{ Version = [System.Version]'4.5' ; Comment = 'and later with KB3168275 rollup' }
'393295' = @{ Version = [System.Version]'4.6' ; Comment = '(Windows 10)' }
'393297' = @{ Version = [System.Version]'4.6' ; Comment = '(NON Windows 10)' }
'394254' = @{ Version = [System.Version]'4.6.1' ; Comment = '(Windows 10)' }
'394271' = @{ Version = [System.Version]'4.6.1' ; Comment = '(NON Windows 10)' }
'394802' = @{ Version = [System.Version]'4.6.2' ; Comment = '(Windows 10 Anniversary Update)' }
'394806' = @{ Version = [System.Version]'4.6.2' ; Comment = '(NON Windows 10)' }
'460798' = @{ Version = [System.Version]'4.7' ; Comment = '(Windows 10 Creators Update)' }
'460805' = @{ Version = [System.Version]'4.7' ; Comment = '(NON Windows 10)' }
'461308' = @{ Version = [System.Version]'4.7.1' ; Comment = '(Windows 10 Fall Creators Update)' }
'461310' = @{ Version = [System.Version]'4.7.1' ; Comment = '(NON Windows 10)' }
'461808' = @{ Version = [System.Version]'4.7.2' ; Comment = '(Windows 10 April & Winserver)' }
'461814' = @{ Version = [System.Version]'4.7.2' ; Comment = '(NON Windows 10)' }
'528040' = @{ Version = [System.Version]'4.8' ; Comment = '(Windows 10 May 2019 Update)' }
'528049' = @{ Version = [System.Version]'4.8' ; Comment = '(NON Windows 10)' }
}
foreach($computerObject in $computerList)
{
$computerName = $computerObject.DNSHostName
write-host("PCName is " + $computerName)
if(test-connection -TargetName $computerName -Quiet -TimeOutSeconds 1 -count 2){
if($regKey = [Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey('LocalMachine', $computerName))
{
$os = (Get-WMIObject win32_operatingsystem -ComputerName SPL305350).Name
if(!$?){
write-host("wim not available")
$dotNetter += New-Object -TypeName PSObject -Property @{
'ComputerName' = $computerName
'OS' = "WIM not available"
'Build' = "WIM not available"
'Version' = "WIM not available"
'Comment' = "WIM not available"
}
}
else{
if ($netRegKey = $regKey.OpenSubKey("$dotNetRegistry"))
{
foreach ($versionKeyName in $netRegKey.GetSubKeyNames())
{
if ($versionKeyName -match '^v[123]') {
$versionKey = $netRegKey.OpenSubKey($versionKeyName)
$version = [System.Version]($versionKey.GetValue('Version', ''))
write-host("adding old dotnet")
$dotNetter += New-Object -TypeName PSObject -Property @{
ComputerName = $computerName
OS = $os
Build = $version.Build
Version = $version
Comment = ''
}
}
}
}
if ($net4RegKey = $regKey.OpenSubKey("$dotNet4Registry"))
{
if(-not ($net4Release = $net4RegKey.GetValue('Release')))
{
$net4Release = 30319
}
write-host("adding new dotnet")
$dotNetter += New-Object -TypeName PSObject -Property @{
'ComputerName' = $computerName
'OS' = $os
'Build' = $net4Release
'Version' = $dotNet4Builds["$net4Release"].Version
'Comment' = $dotNet4Builds["$net4Release"].Comment
}
}
if ($netRegKey = $regKey.OpenSubKey("$dotNetRoot")){
write-host("Checking for hacked keys")
foreach ($versionKeyName in $netRegKey.GetSubKeyNames())
{
if ($versionKeyName -match '^v[1234]') {
$versionKey = $netRegKey.OpenSubKey($versionKeyName)
write-host("versionKeyName is" + $versionKeyName)
write-host('ASPNetEnforceViewStateMac = ' + $versionKey.GetValue('ASPNetEnforceViewStateMac', ''))
$compromisedCheck += New-Object -TypeName PSObject -Property @{
'ComputerName' = $computerName
'version' = $versionKeyName
'compromisedCheck' = ('ASPNetEnforceViewStateMac = ' + $versionKey.GetValue('ASPNetEnforceViewStateMac', ''))
}
}
}
}
}
}
}
else{
write-host("could not connect to machine")
$dotNetter += New-Object -TypeName PSObject -Property @{
'ComputerName' = $computerName
'OS' = $os
'Build' = "Could not connect"
'Version' = "Could not connect"
'Comment' = "Could not connect"
}
}
}
$dotNetter | export-CSV c:\temp\DotNetVersions.csv
$compromisedCheck | export-CSV C:\temp\CompromisedCheck.csv
}
get-dotnetframeworkversion($computerList)
일반적인 아이디어는 다음과 같습니다.
에서 하위 항목을 가져옵니다.이름이 패턴 v 번호 도트 번호와 일치하는 컨테이너인 NET Framework 디렉터리.내림차순 이름으로 정렬하고 첫 번째 개체를 가져온 다음 이름 속성을 반환합니다.
대본은 다음과 같습니다.
(Get-ChildItem -Path $Env:windir\Microsoft.NET\Framework | Where-Object {$_.PSIsContainer -eq $true } | Where-Object {$_.Name -match 'v\d\.\d'} | Sort-Object -Property Name -Descending | Select-Object -First 1).Name
저는 PowerShell에서 이것을 시도할 것입니다: 저에게 적합합니다!
(Get-Item Property "HKLM: 소프트웨어\Microsoft\NET 프레임워크 설정\NDP\v4\Full").버전
컴퓨터에 Visual Studio를 설치한 경우 Visual Studio Developer Command Prompt를 열고 다음 명령을 입력합니다. crrver
설치된 의 모든 버전이 나열됩니다.해당 시스템의 NET Framework.
제 PowerShell 구문에 대해서는 잘 모르지만, 시스템에 전화하시면 될 것 같습니다.런타임.Interop Services.런타임 환경.시스템 버전()을 가져옵니다.이렇게 하면 버전이 문자열로 반환됩니다(예:v2.0.50727
그런 것 같아요.
이것은 이전 게시물의 파생물이지만 제 테스트에서 최신 버전의 .net 프레임워크 4를 얻습니다.
get-itemproperty -name version,release "hklm:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\FULL"
원격 시스템에 명령을 호출할 수 있습니다.
invoke-command -computername server01 -scriptblock {get-itemproperty -name version,release "hklm:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\FULL" | select pscomputername,version,release}
AD 모듈 및 명명 규칙 접두사를 사용하여 이 가능성을 설정합니다.
get-adcomputer -Filter 'name -like "*prefix*"' | % {invoke-command -computername $_.name -scriptblock {get-itemproperty -name version,release "hklm:\SOFTWARE\Microsoft\NET Framework Setup\NDP\v4\FULL" | select pscomputername,version,release}} | ft
언급URL : https://stackoverflow.com/questions/3487265/powershell-script-to-return-versions-of-net-framework-on-a-machine
'source' 카테고리의 다른 글
Eclipse용 경량 SQL 편집기 (0) | 2023.05.04 |
---|---|
cricinfo 점수 카드의 html 구문 분석 (0) | 2023.05.04 |
그래프에서 xxick을 제거하는 방법 (0) | 2023.05.04 |
PostgreSQL에서 다대다 관계를 구현하는 방법은 무엇입니까? (0) | 2023.05.04 |
iOS에서 최신 장치 언어를 가져오시겠습니까? (0) | 2023.05.04 |