Compilador Bytecode de PHP
Introducción
Esta extensión es EXPERIMENTAL. Esto significa que el comportamiento de esta extensión, los nombre de sus funciones y en definitiva TODO lo documentado sobre esta extensión, puede cambiar en una futura versión de PHP SIN AVISO. La advertencia queda hecha, y utilizar esta extensión queda bajo su propia responsabilidad.
Bcompiler fue escrito por varias razones:
- Para codificar un script entero en una aplicación propietaria escrita en PHP.
- Para codificar algunas clases y/o funciones en una aplicación propietaria escrita en PHP.
- Para permitir la producción de aplicaciones PHP-GTK que puedan ser usadas del lado del cliente, sin necesidad de un php.exe.
- Para hacer viable el estudio de un convertidor PHP al lenguaje de programación C.
La segunda de estas metas se pueden alcanzar usando las funciones bcompiler_write_header(), bcompiler_write_class(), bcompiler_write_footer(), bcompiler_read(), y bcompiler_load(). Los archivos bytecode pueden estar escritos tanto descomprimidos, como en texto plano. La función bcompiler_load() lee un archivo bytecode comprimido con bzip, el cual suele ser 1/3 del tamaño original del archivo.
Para crear archivos del tipo exe, bcompiler tiene que ser usado con un archivo sapi modificado o una versión de PHP que haya sido compilada como una librerÃa compartida. En este escenario, bcompiler lee el bytecode comprimido desde el final del archivo exe.
bcompiler puede mejorar su desempeño cerca del 30% cuando sólo se usa con bytecodes descomprimidos. Pero tenga presente que un bytecode descomprimido puede ser hasta 5 veces más grande que el código fuente original. Usando la compresión bytecode puede ahorrarle espacio, pero la descompresión requiere mucho más tiempo que analizar un código. Además, bcompiler no lleva a cabo alguna optimización bytecode; esto pudiera ser agregado en el futuro...
En cuanto a la protección del código, es seguro decir que serÃa imposible recrear el código fuente exacto desde el cual se construyó, y sin la compañÃa de comentarios en el código fuente. Efectivamente serÃa inútil usar los bytecodes de bcompiler para recrear y modificar una clase. Sin embargo, es posible recuperar información desde un archivo bytecode de bcompiler - asà que no coloque sus contraseñas o cualquier otra cosa privada en él.
Instalación
Nota de instalación corta:
- Necesitará tener al menos PHP 4.3 para que la compresión funcione.
- Para instalar en PHP 4.3 o mayor, escriba en el intérprete de comandos de UNIX pear install bcompiler.
- Para instalar en Windows, hasta que esté listo el mecanismo para el paquete de distribución binario, por favor busque los paquetes pre-construidos en la lista de correo pear-general. (o envÃeles un correo electrónico si no pudo hallar una referencia).
- Para instalar en versiones anteriores, necesita hacer algunos cambios ligeros al paquete.
- extraer el archivo bcompiler.tgz en el directorio php4/ext. (Obténgalo directamente desde PECL » https://pecl.php.net/get/bcompiler).
- Si el nombre del nuevo directorio no es similar a bcompiler-0.x, deberÃa cambiarle el nombre a bcompiler (a menos que sólo desee construirlo como un módulo PHP contenido desde de sà mismo).
- Si está usando versiones anteriores a PHP 4.3, entonces necesitará copiar el archivo Makefile.in.old a Makefile.in, y config.m4.old a config.m4.
- ejecute phpize en ext/bcompiler.
- ejecute ./buildconf en php4 .
- ejecute configure con --enable-bcompiler (y otras opciones que use).
- make; make install
- eso es todo.
Información de contacto
Si tiene comentarios, soluciones a fallos, mejoras o quiere ayudar a desarrollar esta bestia, puede enviarme un correo-e a » alan_k@php.net. Cualquier ayuda es bienvenida.
Table of Contents
- bcompiler_load_exe — Lee y crea clases desde un archivo exe de bcompiler
- bcompiler_load — Lee y crea clases desde un archivo comprimido bz
- bcompiler_parse_class — Lee los bytecodes de una clase y genera una llamada a una función definida por el usuario
- bcompiler_read — Lee y crea clases desde un gestor de archivo
- bcompiler_write_class — Escribe una clase determinada como bytecodes
- bcompiler_write_constant — Lee una constante definida como bytecodes
- bcompiler_write_exe_footer — Writes the start pos, and sig to the end of a exe type file
- bcompiler_write_file — Writes a php source file as bytecodes
- bcompiler_write_footer — Writes the single character \x00 to indicate End of compiled data
- bcompiler_write_function — Writes an defined function as bytecodes
- bcompiler_write_functions_from_file — Writes all functions defined in a file as bytecodes
- bcompiler_write_header — Writes the bcompiler header
- bcompiler_write_included_filename — Writes an included file as bytecodes