Створіть веб-сайт в IIS з шейлера з декількома прив'язками


8

Я намагаюся зробити простий сценарій, щоб мій сайт можна було отримати як www.example.comі просто example.com. Як я можу передати це як обов'язковий аргумент?

Ось що я намагаюся:

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

Відповіді:


7

Параметри прив'язування інформації очікують масив записів (які є самими масивами, зауважте @), а не список, розділений комами.

Приклад - спочатку визначте правильний масив записів, а потім призначте його як аргумент прив'язуючої інформації:

$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

Крім того, після створення сайту ви можете додати додаткові прив’язки за допомогою команди New-WebBinding . наприклад:

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

0

Я використовую це для оновлення прив’язок, це може комусь допомогти, оскільки мені довелося це зрозуміти.

$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" 
                        }
                }
     }

Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.