Программное удаление суффикса etag (номера изменения) из метабазы ​​IIS6

IIS 6.0 генерирует значения eTag в формате «hash: changenumber». Номер изменения увеличивается каждый раз при сбросе IIS, поэтому ваш eTag действителен только в течение всего срока службы вашего процесса IIS. Перезагрузка, номер увеличивается, hash: changenumber! = Hash: changenumber + 1.

Чтобы исправить это, необходимо жестко запрограммировать номер изменения, что возможно с помощью Metabase Explorer. , служебная программа .NET для редактирования метабазы ​​или путем редактирования файла XML, когда службы IIS остановлены.

Я хочу сделать это программно, при работающем сервере, как будто я могу установить все остальные свойства метабазы ​​с помощью ADSI или WMI. Для этого это кажется невозможным, поскольку свойство (которое внутренне упоминается как MD_ETAG_CHANGENUMBER), похоже, не имеет совпадающего имени свойства.

Вот пример проблемы в VBScript:

set obj=GetObject("IIS://localhost/W3svc")
WScript.Echo "Log type: " & obj.LogType
WScript.Echo "Change number: " & obj.MD_ETAG_CHANGENUMBER

Выход:

Log type: 1
etag.vbs(3, 1) Microsoft VBScript runtime error: Object doesn't support this property or method: 'obj.MD_ETAG_CHANGENUMBER'

Я хочу иметь возможность устанавливать это значение на C #. Есть ли способ программной установки этого значения, кроме остановки IIS, установки значения в XML и его повторного запуска?

Моя лучшая мысль - (ab) использовать IISMbLib.dll, который поставляется с Metabase Explorer, поэтому, если у кого-то есть опыт использования этого, я хотел бы его услышать.

Использованная литература:


person crb    schedule 28.05.2009    source источник


Ответы (2)


crb, спасибо за отличное решение, мне не удалось найти альтернативу (хотя я ранее добавил свои собственные свойства метабазы ​​в схему IIS 6 с помощью некоторых сложных сценариев ADSI, которые используются настраиваемым ISAPI)

Вот версия вашего решения для PowerShell. Предполагается, что сборка MB Explorer скопирована в нее локально.

$myPath = [System.IO.Path]::GetDirectoryName($MyInvocation.MyCommand.Path)

Import-Module "$myPath\IISMbLib.dll"

$etagValue = 12345
$metabase = New-Object IISConfig.Metabase
$metabase.OpenLocalMachine()

$key = $metabase.GetKeyFromPath("/LM/W3SVC")

if ($key.ContainsRecord(2039) -eq [IISConfig.ValueExistOptions]::Explicit)
{
    $record = $key.GetRecord(2039)
    Write-Host "Existing ETag value found:", $record.Data.ToString()
}
else
{
    Write-Host "Creating new value..."
    $record = New-Object IISConfig.Record
    $record.DataType = [IISConfig.Record+DataTypes]::DWORD
    $record.Identifier = 2039
    $record.ChangeAttribute([IISConfig.Record+AttributeList]::Inherit, $true)
}
$record.Data = [System.Convert]::ToUInt32($etagValue)
Write-Host "New ETag value:", $record.Data.ToString()
$key.SetRecord($record)
person Troy Parsons    schedule 20.04.2012

Моя лучшая мысль была довольно хорошей. Вот решение, которое зависит от IISMbLib.dll из Metabase Explorer в IIS 6.0 Resource Kit.

        Metabase metabase = new Metabase();
        metabase.OpenLocalMachine();

        IKey key = metabase.GetKeyFromPath("/LM/W3SVC/");
        if (key.ContainsRecord(2039) == IISConfig.ValueExistOptions.Explicit) {
            Record r = key.GetRecord(2039);
            r.Data = Convert.ToUInt32(0);
            key.SetRecord(r);
        } else {
            Record r = new Record();
            r.Data = Convert.ToUInt32(0);
            r.DataType = Record.DataTypes.DWORD;
            r.Identifier = 2039;
            r.ChangeAttribute(Record.AttributeList.Inherit, true);
            key.SetRecord(r);
        }
person crb    schedule 28.05.2009