Utwórz stronę internetową w IIS z PowerShell z wieloma powiązaniami


8

Staram się stworzyć prosty skrypt, aby moja strona była dostępna zarówno jako, jak www.example.comi po prostu example.com. Jak przekazać to jako wiążący argument?

Oto, co próbuję:

$iisApp = New-Item $iisAppName -bindings @{protocol="http";bindingInformation="*:80:"+ $url + ",*:80:www." + $url} -physicalPath $directoryPath
$iisApp | Set-ItemProperty -Name "applicationPool" -Value $iisAppPoolName

Odpowiedzi:


7

Opcje bindInformation oczekują tablicy wpisów (które same są tablicami, zwróć uwagę na @), a nie listy oddzielonej przecinkami.

Przykład - najpierw zdefiniuj odpowiednią tablicę wpisów, a następnie przypisz ją jako argument bindInformation:

$bindings = @(
   @{protocol="http";bindingInformation="*:80:" + $url},
   @{protocol="http";bindingInformation="*:80:www." + $url},
)

$iisApp = New-Item $iisAppName -bindings $bindings -physicalPath $directoryPath
$iisApp | Set-ItemProperty -Name "applicationPool" -Value $iisAppPoolName

Alternatywnie po utworzeniu witryny można dodać dodatkowe powiązania za pomocą polecenia New-WebBinding . na przykład:

New-WebBinding -Name $iisAppName -IPAddress "*" -Port 80 -HostHeader "www.$url"

0

Używam tego do aktualizacji powiązań, może to komuś pomóc, ponieważ sam musiałem to rozgryźć.

$hostname =$env:COMPUTERNAME
$fqdn = $env:USERDNSDOMAIN
$Bindings = Get-WebBinding |Select -expandproperty bindinginformation
$websites = Get-Website
foreach ($website in $websites)
    {
    $siteName=$website.name
         foreach ($Binding in $Bindings)
                {
                $oldheader =($Binding -split ":")[-1]
                    if ($oldheader -eq "")
                        {
                         Set-WebBinding -Name $sitename -BindingInformation $Binding -PropertyName "HostHeader" -Value "$hostname.$fqdn" 
                        }
                }
     }

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.