Compartir a través de


Filtro <filter>

Información general

El elemento <filter> de la colección <isapiFilters> configura un filtro ISAPI para procesar datos de solicitudes de cliente o datos de respuesta del servidor.

Compatibilidad

Versión Notas
IIS 10.0 El elemento <filter> no se modificó en IIS 10.0.
IIS 8.5 El elemento <filter> no se modificó en IIS 8.5.
IIS 8.0 El elemento <filter> no se modificó en IIS 8.0.
IIS 7.5 El elemento <filter> no se modificó en IIS 7.5.
IIS 7.0 El elemento <filter> de la colección <isapiFilters> se introdujo en IIS 7.0.
IIS 6,0 La colección <isapiFilters> reemplaza a las propiedades de metabase FilterEnableCache y FilterPath de IIS 6.0.

Configuración

Para usar el elemento <isapiFilters>, debe instalar el módulo Filtros ISAPI en el servidor IIS 7 y versiones posteriores. Para ello, siga estos pasos.

Windows Server 2012 o Windows Server 2012 R2

  1. En la barra de tareas, haga clic en Administrador del servidor.
  2. En Administrador del servidor, haga clic en el menú Administrar y, después, haga clic en Agregar roles y características.
  3. En el asistente para Agregar roles y características, haga clic en Siguiente. Seleccione el tipo de instalación y haga clic en Siguiente. Seleccione el servidor de destino y haga clic en Siguiente.
  4. En la página Roles de servidor, expanda Servidor web (IIS), expanda Servidor web, expanda Desarrollo de aplicaciones y, a continuación, seleccione Filtros ISAPI. Haga clic en Next.
    Screenshot of Web Server and Application Development Features node expanded with I S A P I Filters selected..
  5. En la página Seleccionar características, haz clic en Siguiente.
  6. En la página Confirmar selecciones de instalación, haga clic en Instalar.
  7. En la página Resultados , haga clic en Cerrar.

Windows 8 o Windows 8.1

  1. En la pantalla Inicio, mueva el puntero hasta la esquina inferior izquierda, haga clic con el botón derecho en el botón Inicio y, a continuación, haga clic en Panel de control.
  2. En Panel de control, haga clic en Programas y características y después en Activar o desactivar las características de Windows.
  3. Expanda sucesivamente Internet Information Services, World Wide Web Services y Características de desarrollo de aplicaciones y, a continuación, seleccione Filtros ISAPI.
    Screenshot displays World Wide Web Services and Application Development Features pane expanded with I S A P I Filters selected.
  4. Haga clic en OK.
  5. Haga clic en Cerrar.

Windows Server 2008 o Windows Server 2008 R2

  1. En la barra de tareas, haga clic en Inicio, seleccione Herramientas administrativas y, luego, haga clic en Administrador del servidor.
  2. En el panel de jerarquía del Administrador del servidor, expanda Roles y, luego, haga clic en Servidor web (IIS).
  3. En el panel Servidor web (IIS), desplácese hasta la sección Servicios de rol y, luego, haga clic en Agregar servicios de rol.
  4. En la página Seleccionar servicios de rol del Asistente para agregar servicios de rol, seleccione Filtros ISAPI y haga clic en Siguiente.
    Screenshot of Application Development Features node expanded in Turn Windows features on or off page displaying I S A P I Filters selected.
  5. En la página Confirmar selecciones de instalación, haz clic en Instalar.
  6. En la página Resultados , haga clic en Cerrar.

Windows Vista o Windows 7

  1. En la barra de tareas, haga clic en Inicio y, luego, haga clic en Panel de control.
  2. En Panel de control, haga clic en Programas y características y después en Activar o desactivar las características de Windows.
  3. En el cuadro de diálogo Características de Windows, expanda Internet Information Services, después World Wide Web Services y, a continuación, Características de desarrollo de aplicaciones.
    Screenshot shows World Wide Web Services and Application Development Features pane expanded with I S A P I Filters selected.
  4. Seleccione Filtros ISAPI y, a continuación, haga clic en Aceptar.

Procedimientos

Adición de filtros ISAPI

  1. Abra el Administrador de Internet Information Services (IIS):

    • Si usa Windows Server 2012 o Windows Server 2012 R2:

      • En la barra de tareas, haga clic en Administrador del servidor, en Herramientas y, a continuación, en Administrador de Internet Information Services (IIS).
    • Si usa Windows 8 o Windows 8.1:

      • Mantenga presionada la tecla Windows, presione la letra X y haga clic en Panel de control.
      • En Panel de control, haga clic en Herramientas administrativas y, a continuación, haga doble clic en Administrador de Internet Information Services (IIS).
    • Si usa Windows Server 2008 o Windows Server 2008 R2:

      • En la barra de tareas, haga clic en Inicio, seleccione Herramientas administrativas y, a continuación, haga clic en Administrador de Internet Information Services (IIS).
    • Si usa Windows Vista o Windows 7:

      • En la barra de tareas, haga clic en Inicio y, luego, haga clic en Panel de control.
      • Haga doble clic en Herramientas administrativas y, a continuación, haga doble clic en Administrador de Internet Information Services (IIS).
  2. En el panel Conexiones, vaya a la conexión o al sitio para el que desea configurar filtros ISAPI.

  3. En el panel Inicio, haga doble clic en Filtros ISAPI.
    Screenshot of Home pane showing I S A P I Filters selected.

  4. En el panel Acciones, haga clic en Agregar....

  5. En el cuadro de texto Nombre de filtro del cuadro de diálogo Agregar filtro ISAPI, escriba un nombre descriptivo para el filtro ISAPI.

  6. En el cuadro Ejecutable, escriba la ruta de acceso del sistema de archivos de la ubicación del archivo de filtro ISAPI o haga clic en los puntos suspensivos (...) para ir a la carpeta que contiene el archivo de filtro ISAPI y, a continuación, haga clic en Aceptar.
    Screenshot of Add I S A P I Filter dialog box displaying Executable box and Filter name box.

Configuración

Atributos

Atributo Descripción
enableCache Atributo Boolean opcional.

Especifica si el almacenamiento en caché de HTTP.sys está habilitado (true) o deshabilitado (false) para las respuestas de servidor filtradas.

El valor predeterminado es false.
enabled Atributo Boolean opcional.

Especifica si el filtro instalado está habilitado (true) o deshabilitado (false).

El valor predeterminado es true.
name Atributo de cadena necesario.

Especifica el nombre único del filtro ISAPI.
path Atributo de cadena necesario.

Especifica la ruta de acceso física completa del archivo .dll de filtro ISAPI.
preCondition Atributo de cadena opcional.

Especifica las condiciones en las que se ejecutará el filtro ISAPI.

El atributo preCondition puede tener uno o varios de los siguientes valores posibles. Si especifica más de un valor, separe los valores con una coma (,).
Valor Descripción
bitness32 Especifique el valor bitness32 cuando el filtro ISAPI sea un archivo .dll de 32 bits e IIS deba cargarlo solo para los procesos de trabajo que se ejecutan en modo WOW64 (simulación de 32 bits) en un sistema operativo de 64 bits.
bitness64 Especifique el valor bitness64 cuando el filtro ISAPI sea un archivo .dll de 64 bits e IIS solo deba cargar el controlador para los procesos de trabajo que se ejecutan en modo de 64 bits.
integratedMode Especifique el valor integratedMode cuando el filtro ISAPI deba usar la canalización de procesamiento de solicitudes integrada para procesar solicitudes de contenido administrado.
ISAPIMode Especifique el valor ISAPIMode cuando el filtro ISAPI deba usar la extensión ISAPI de ASP.NET, Aspnet_isapi.dll, para procesar las solicitudes de contenido administrado.
runtimeVersionv1.1 Especifique el valor runtimeVersionv1.1 cuando el filtro ISAPI solo deba cargarse para los grupos de aplicaciones configurados para usar .NET Framework 1.1.
runtimeVersionv2.0 Especifique el valor runtimeVersionv2.0 cuando el filtro ISAPI solo deba cargarse para los grupos de aplicaciones configurados para usar .NET Framework 2.0.

Elementos secundarios

Ninguno.

Ejemplo de configuración

En el ejemplo de configuración siguiente se agrega un filtro ISAPI denominado SalesQueryIsapi a un sitio o aplicación web. Usa los nombres de ejemplo y habilita el filtro ISAPI con los atributos name y enabled. También usa el atributo enableCache para deshabilitar el almacenamiento en caché de HTTP.sys y el atributo path para especificar la ubicación del archivo DLL de ISAPI.

<configuration>
   <system.webServer>
      <isapiFilters>
         <filter 
            name="SalesFilter" 
            enabled="true" 
            enableCache="false" 
            path="C:\Inetpub\filters\SalesFilter.dll" />
      </isapiFilters>
   </system.webServer>
</configuration>

Código de ejemplo

En los ejemplos siguientes se configura un filtro ISAPI denominado SalesQueryIsapi en el servidor. En cada uno de los ejemplos se usa la propiedad name para especificar un nombre para el filtro ISAPI, la propiedad enableCache para deshabilitar el almacenamiento en caché de HTTP.sys y la propiedad path para especificar la ubicación del archivo DLL de ISAPI.

AppCmd.exe

appcmd.exe set config -section:system.webServer/isapiFilters /+"[name='SalesQueryIsapi',path='c:\Inetpub\www.contoso.com\filters\SalesQueryIsapi.dll',enabled='True',enableCache='True']" /commit:apphost

Nota:

Debe asegurarse de establecer el parámetro de confirmación en apphost cuando use AppCmd.exe para configurar estas opciones. Esto confirma los valores de configuración en la sección de ubicación adecuada del archivo ApplicationHost.config.

C#

using System;
using System.Text;
using Microsoft.Web.Administration;

internal static class Sample
{
   private static void Main()
   {
      using (ServerManager serverManager = new ServerManager())
      {
         Configuration config = serverManager.GetApplicationHostConfiguration();
         ConfigurationSection isapiFiltersSection = config.GetSection("system.webServer/isapiFilters");
         ConfigurationElementCollection isapiFiltersCollection = isapiFiltersSection.GetCollection();

         ConfigurationElement filterElement = isapiFiltersCollection.CreateElement("filter");
         filterElement["name"] = @"SalesQueryIsapi";
         filterElement["path"] = @"c:\Inetpub\www.contoso.com\filters\SalesQueryIsapi.dll";
         filterElement["enabled"] = true;
         filterElement["enableCache"] = true;
         isapiFiltersCollection.Add(filterElement);

         serverManager.CommitChanges();
      }
   }
}

VB.NET

Imports System
Imports System.Text
Imports Microsoft.Web.Administration

Module Sample
   Sub Main()
      Dim serverManager As ServerManager = New ServerManager
      Dim config As Configuration = serverManager.GetApplicationHostConfiguration
      Dim isapiFiltersSection As ConfigurationSection = config.GetSection("system.webServer/isapiFilters")
      Dim isapiFiltersCollection As ConfigurationElementCollection = isapiFiltersSection.GetCollection
      Dim filterElement As ConfigurationElement = isapiFiltersCollection.CreateElement("filter")
      filterElement("name") = "SalesQueryIsapi"
      filterElement("path") = "c:\Inetpub\www.contoso.com\filters\SalesQueryIsapi.dll"
      filterElement("enabled") = True
      filterElement("enableCache") = True
      isapiFiltersCollection.Add(filterElement)
      serverManager.CommitChanges()
   End Sub
End Module

JavaScript

var adminManager = new ActiveXObject('Microsoft.ApplicationHost.WritableAdminManager');
adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST";
var isapiFiltersSection = adminManager.GetAdminSection("system.webServer/isapiFilters", "MACHINE/WEBROOT/APPHOST");
var isapiFiltersCollection = isapiFiltersSection.Collection;

var filterElement = isapiFiltersCollection.CreateNewElement("filter");
filterElement.Properties.Item("name").Value = "SalesQueryIsapi";
filterElement.Properties.Item("path").Value = "c:\\Inetpub\\www.contoso.com\\filters\\SalesQueryIsapi.dll";
filterElement.Properties.Item("enabled").Value = true;
filterElement.Properties.Item("enableCache").Value = true;
isapiFiltersCollection.AddElement(filterElement);

adminManager.CommitChanges();

VBScript

Set adminManager = createObject("Microsoft.ApplicationHost.WritableAdminManager")
adminManager.CommitPath = "MACHINE/WEBROOT/APPHOST"
Set isapiFiltersSection = adminManager.GetAdminSection("system.webServer/isapiFilters", "MACHINE/WEBROOT/APPHOST")
Set isapiFiltersCollection = isapiFiltersSection.Collection

Set filterElement = isapiFiltersCollection.CreateNewElement("filter")
filterElement.Properties.Item("name").Value = "SalesQueryIsapi"
filterElement.Properties.Item("path").Value = "c:\\Inetpub\\www.contoso.com\\filters\\SalesQueryIsapi.dll"
filterElement.Properties.Item("enabled").Value = True
filterElement.Properties.Item("enableCache").Value = True
isapiFiltersCollection.AddElement filterElement

adminManager.CommitChanges()