Partilhar via


Como configurar o IIS 5.0 e o IIS 6.0 para implantar aplicativos WPF

Você pode implantar um aplicativo Windows Presentation Foundation (WPF) da maioria dos servidores Web, desde que eles estejam configurados com os tipos MIME (Multipurpose Internet Mail Extensions) apropriados. Por padrão, o Microsoft Internet Information Services (IIS) 7.0 é configurado com esses tipos de MIME, mas o Microsoft Internet Information Services (IIS) 5.0 e o Microsoft Internet Information Services (IIS) 6.0 não são.

Este tópico descreve como configurar o Microsoft Internet Information Services (IIS) 5.0 e o Microsoft Internet Information Services (IIS) 6.0 para implantar aplicativos WPF.

Observação

Você pode verificar a cadeia de caracteres UserAgent no Registro para determinar se um sistema tem o .NET Framework instalado. Para detalhes e um script que examina a string de UserAgent para verificar se o .NET Framework está instalado num sistema, consulte Verificar se o .NET Framework 3.0 está instalado.

Ajustar a configuração de expiração de conteúdo

Você deve ajustar a configuração de expiração de conteúdo para 1 minuto. O procedimento a seguir descreve como fazer isso com o IIS.

  1. Clique no menu Iniciar, aponte para Ferramentas Administrativase clique em Gerenciador dos Serviços de Informações da Internet (IIS). Também pode iniciar esta aplicação a partir da linha de comandos com "%SystemRoot%\system32\inetsrv\iis.msc".

  2. Expanda a árvore do IIS até encontrar o site padrão nó.

  3. Clique com o botão direito no site Web padrão e selecione Propriedades no menu de contexto.

  4. Selecione o separador Cabeçalhos HTTP e clique em "Ativar expiração de conteúdo".

  5. Defina o conteúdo para expirar após 1 minuto.

Registrar tipos de MIME e extensões de arquivo

Você deve registrar vários tipos de MIME e extensões de arquivo para que o navegador no sistema do cliente possa carregar o manipulador correto. Você precisa adicionar os seguintes tipos:

Extensão Tipo MIME
.manifest Aplicação/manifesto
.xaml aplicativo/xaml+xml
.aplicação aplicativo/x-ms-application
.xbap aplicação/x-ms-xbap
.implantar application/octet-stream
.xps aplicativo/vnd.ms-xpsdocument

Observação

Não é necessário registrar tipos MIME ou extensões de arquivo em sistemas cliente. Eles são registrados automaticamente quando você instala o Microsoft .NET Framework.

O seguinte exemplo do Microsoft Visual Basic Scripting Edition (VBScript) adiciona automaticamente os tipos MIME necessários ao IIS. Para usar o script, copie o código para um arquivo .vbs no servidor. Em seguida, execute o script executando o arquivo a partir da linha de comando ou clicando duas vezes no arquivo no Microsoft Windows Explorer.

' This script adds the necessary Windows Presentation Foundation MIME types
' to an IIS Server.
' To use this script, just double-click or execute it from a command line.
' Running this script multiple times results in multiple entries in the IIS MimeMap.

Dim MimeMapObj, MimeMapArray, MimeTypesToAddArray, WshShell, oExec
Const ADS_PROPERTY_UPDATE = 2

' Set the MIME types to be added
MimeTypesToAddArray = Array(".manifest", "application/manifest", ".xaml", _
    "application/xaml+xml", ".application", "application/x-ms-application", _
    ".deploy", "application/octet-stream", ".xbap", "application/x-ms-xbap", _
    ".xps", "application/vnd.ms-xpsdocument")

' Get the MimeMap object
Set MimeMapObj = GetObject("IIS://LocalHost/MimeMap")

' Call AddMimeType for every pair of extension/MIME type
For counter = 0 to UBound(MimeTypesToAddArray) Step 2
    AddMimeType MimeTypesToAddArray(counter), MimeTypesToAddArray(counter+1)
Next

' Create a Shell object
Set WshShell = CreateObject("WScript.Shell")

' Stop and Start the IIS Service
Set oExec = WshShell.Exec("net stop w3svc")
Do While oExec.Status = 0
    WScript.Sleep 100
Loop

Set oExec = WshShell.Exec("net start w3svc")
Do While oExec.Status = 0
    WScript.Sleep 100
Loop

Set oExec = Nothing

' Report status to user
WScript.Echo "Windows Presentation Foundation MIME types have been registered."

' AddMimeType Sub
Sub AddMimeType (Ext, MType)

    ' Get the mappings from the MimeMap property.
    MimeMapArray = MimeMapObj.GetEx("MimeMap")

    ' Add a new mapping.
    i = UBound(MimeMapArray) + 1
    ReDim Preserve MimeMapArray(i)
    Set MimeMapArray(i) = CreateObject("MimeMap")
    MimeMapArray(i).Extension = Ext
    MimeMapArray(i).MimeType = MType
    MimeMapObj.PutEx ADS_PROPERTY_UPDATE, "MimeMap", MimeMapArray
    MimeMapObj.SetInfo

End Sub

Observação

A execução desse script várias vezes cria várias entradas de mapa MIME na metabase Microsoft Internet Information Services (IIS) 5.0 ou Microsoft Internet Information Services (IIS) 6.0.

Depois de executar este script, poderá não ver tipos MIME adicionais a partir do Microsoft Internet Information Services (IIS) 5.0 ou Microsoft Internet Information Services (IIS) 6.0 Microsoft Management Console (MMC). No entanto, esses tipos MIME foram adicionados à metabase Microsoft Internet Information Services (IIS) 5.0 ou Microsoft Internet Information Services (IIS) 6.0. O script a seguir exibirá todos os tipos MIME na metabase Microsoft Internet Information Services (IIS) 5.0 ou Microsoft Internet Information Services (IIS) 6.0.

' This script lists the MIME types for an IIS Server.
' To use this script, just double-click or execute it from a command line
' by calling cscript.exe

dim mimeMapEntry, allMimeMaps

' Get the MimeMap object.
Set mimeMapEntry = GetObject("IIS://localhost/MimeMap")
allMimeMaps = mimeMapEntry.GetEx("MimeMap")

' Display the mappings in the table.
For Each mimeMap In allMimeMaps
    WScript.Echo(mimeMap.MimeType & " (" & mimeMap.Extension + ")")
Next

Salve o script como um arquivo .vbs (por exemplo, DiscoverIISMimeTypes.vbs) e execute-o no prompt de comando usando o seguinte comando:

cscript DiscoverIISMimeTypes.vbs