Compartir a través de


Peverify.exe (Herramienta PEVerify)

Esta herramienta ayuda a los programadores que generan lenguaje intermedio de Microsoft (MSIL) (como autores de compiladores, programadores de motores de script, etc.) a determinar si el código MSIL y los metadatos asociados satisfacen los requisitos de seguridad de tipos. Algunos compiladores sólo generan código seguro de tipos comprobable si se evita la utilización de determinadas construcciones de lenguaje. Si, como programador, está utilizando un compilador con estas características, es fácil que desee comprobar que no ha puesto en peligro la seguridad de tipos del código. Para ello, ejecute la herramienta PEVerify en los archivos con el fin de comprobar el lenguaje MSIL y los metadatos.

Esta herramienta se instala automáticamente con Visual Studio y con el SDK de Windows. Para ejecutar la herramienta, se recomienda usar el símbolo del sistema de Visual Studio o del SDK de Windows (shell de CMD). Estas utilidades permiten ejecutar la herramienta fácilmente, sin navegar a la carpeta de instalación. Para obtener más información, vea Símbolos del sistema del SDK de Windows y Visual Studio.

  • Si tiene instalado Visual Studio en el equipo: en la barra de tareas, haga clic en Start, All Programs, Visual Studio y Visual Studio Tools y, a continuación, haga clic en Visual Studio Command Prompt.

    O bien

    Si tiene el SDK de Windows instalado en el equipo: en la barra de tareas, haga clic en Start, All Programs, haga clic en la carpeta del SDK de Windows y, a continuación, haga clic en Command Prompt (o CMD Shell).

  • En el símbolo del sistema, escriba:

peverify filename [options]

Parámetros

Argumento

Descripción

filename

Archivo ejecutable portable (PE) para el que se comprueban el lenguaje MSIL y los metadatos.

Opción

Descripción

/break=recMáxErrores

Anula la comprobación si se generan tantos errores como indica maxErrorCount.

Este parámetro no es compatible con .NET Framework versión 2.0 o posterior.

/clock

Mide e informa de los siguientes tiempos de comprobación en milisegundos:

MD Val. cycle

Ciclo de validación de metadatos

MD Val. pure

Validación pura de metadatos

IL Ver. cycle

Ciclo de comprobación del Lenguaje intermedio de Microsoft (MSIL)

IL Ver pure

Comprobación pura de MSIL

Los tiempos MD Val. cycle e IL Ver. cycle incluyen el tiempo requerido para realizar los procedimientos necesarios de inicio y cierre. Los tiempos MD Val. pure e IL Ver pure reflejan el tiempo requerido únicamente para realizar la validación o comprobación.

/help

Muestra la sintaxis de comandos y opciones para la herramienta.

/hresult

Muestra los códigos de error en formato hexadecimal.

/ignore=hex.code [, hex.code]

No tiene en cuenta los códigos de error especificados.

/ignore=@archivoRespuesta

No tiene en cuenta los códigos de error enumerados en el archivo de respuesta especificado.

/il

Realiza comprobaciones de la seguridad de tipos de MSIL en los métodos implementados en el ensamblado especificado por el argumento filename. La herramienta devuelve descripciones detalladas de cada uno de los problemas encontrados, salvo que se especifique la opción /quiet.

/md

Realiza comprobaciones de validación de metadatos en el ensamblado especificado por el argumento filename. Para ello recorre la estructura completa de metadatos en el archivo y genera un informe de todos los problemas de validación producidos.

/nologo

Suprime la presentación de la versión del producto y la información de copyright.

/nosymbols

En .NET Framework versión 2.0, se suprimen los números de línea para compatibilidad con versiones anteriores.

/quiet

Especifica el modo no interactivo; suprime la salida de los informes relativos a problemas de comprobación. No obstante, Peverify.exe notifica si el archivo tiene seguridad de tipos, pero no proporciona información de los problemas que impiden la comprobación de la seguridad de tipos.

/transparent

Compruebe sólo los métodos transparentes.

/unique

No tiene en cuenta la repetición de códigos de error.

/verbose

En .NET Framework versión 2.0, se muestra información adicional en los mensajes de comprobación de MSIL.

/?

Muestra la sintaxis de comandos y opciones para la herramienta.

Comentarios

Common Language Runtime se basa en la ejecución seguro de tipos del código de la aplicación para ayudar a imponer mecanismos de aislamiento y seguridad. Normalmente, el código que no tiene seguridad de tipos comprobable no se puede ejecutar, aunque se puede establecer la directiva de seguridad para permitir la ejecución de código de confianza pero no comprobable.

Si no se especifica ninguna de las opciones /md y /il, Peverify.exe realiza ambos tipos de comprobaciones. Primero realiza comprobaciones de tipo /md. Si no se producen errores, realiza comprobaciones de tipo /il. Si especifica ambas opciones, /md y /il, se realizarán las comprobaciones de tipo /il aunque existan errores en los metadatos. Así, si no hay ningún error de metadatos, peverify filename es equivalente a peverify filename /md /il.

Peverify.exe realiza comprobaciones exhaustivas de MSIL basándose en el análisis del flujo de datos y en una lista que contiene centenares de reglas sobre metadatos válidos. Para obtener información detallada sobre las comprobaciones que realiza Peverify.exe, vea "Metadata Validation Specification" y "MSIL Instruction Set Specification" en la carpeta Tools Developer Guide de Kit de desarrollo de software de Windows (SDK).

Observe que .NET Framework versión 2.0 o posterior admite devoluciones de los datos byref verificables especificados mediante las siguientes instrucciones de MSIL: dup, ldsflda, ldflda, ldelema, call y unbox.

Ejemplos

El comando siguiente realiza comprobaciones de validación de metadatos y comprobaciones de la seguridad de tipos de MSIL en los métodos implantados en el ensamblado myAssembly.exe.

peverify myAssembly.exe /md /il

Tras la ejecución correcta de la solicitud anterior, Peverify.exe muestra el mensaje siguiente.

All classes and methods in myAssembly.exe Verified

El comando siguiente realiza comprobaciones de validación de metadatos y comprobaciones de la seguridad de tipos de MSIL en los métodos implantados en el ensamblado myAssembly.exe. La herramienta muestra el tiempo necesario para ejecutar estas comprobaciones.

peverify myAssembly.exe /md /il /clock

Tras la ejecución correcta de la solicitud anterior, Peverify.exe muestra el mensaje siguiente.

All classes and methods in myAssembly.exe Verified
Timing: Total run     320 msec
        MD Val.cycle  40 msec
        MD Val.pure   10 msec
        IL Ver.cycle  270 msec
        IL Ver.pure   230 msec

El comando siguiente realiza comprobaciones de validación de metadatos y comprobaciones de la seguridad de tipos de MSIL en los métodos implantados en el ensamblado myAssembly.exe. Peverify.exe se detiene, sin embargo, cuando llega al número máximo de errores (100). La herramienta tampoco tiene en cuenta los códigos de error especificados.

peverify myAssembly.exe /break=100 /ignore=0x12345678,0xABCD1234

El comando siguiente produce el mismo resultado que el ejemplo anterior, pero especifica los códigos de error que se omiten en el archivo de respuesta ignoreErrors.rsp.

peverify myAssembly.exe /break=100 /ignore@ignoreErrors.rsp

El archivo de respuesta puede contener una lista de códigos de error separados por comas.

0x12345678, 0xABCD1234

De modo alternativo, el archivo de respuesta puede tener un formato que incluya un código de error por línea.

0x12345678
0xABCD1234

Vea también

Referencia

Símbolos del sistema del SDK de Windows y Visual Studio

Conceptos

Escribir código seguro comprobable

Seguridad y protección de tipos

Otros recursos

Herramientas de .NET Framework

Historial de cambios

Fecha

Historial

Motivo

1 de abril de 2011

Se agregó información sobre el uso de los símbolos del sistema de Visual Studio y del SDK de Windows.

Mejora de la información.