require("shared.inc"); commonHeader("Migrating from PHP 3.0 to PHP 4.0"); ?>
Migration from PHP 3.0 to PHP 4.0 is relatively easy, and should not require you to change your code in any way. There are minor incompatibilities between the two versions; You may want to check the incompatibilities list to make sure that you're indeed not affected by them (the chances you're affected by these incompatibilities are extremely slim).
Recent operating systems provide the ability to perform versioning and scoping. This features make it possible to let PHP3 and PHP4 run as concurrent modules in one Apache server.
This feature is known to work on the following platforms:
To enable it, configure PHP3 and PHP4 to use APXS (--with-apxs) and the necessary link extensions (--enable-versioning). Otherwise, all standard installations instructions apply. For example:
$ ./configure \
--with-apxs=/apache/bin/apxs \
--enable-versioning \
--with-mysql \
--enable-track-vars
If this also works on your platform or if you know a way to do it, please report it to our bug database at http://bugs.php.net
The global configuration file, php3.ini, has changed its name to php.ini.
The MIME types recognized by the PHP module have changed:
application/x-httpd-php3 --> application/x-httpd-php
application/x-httpd-php3-source --> application/x-httpd-php-source
You can make your configuration files work with both versions of PHP
(depending on which one is currently compiled into the server), using the
following syntax:
AddType application/x-httpd-php3 .php3 AddType application/x-httpd-php3-source .phps AddType application/x-httpd-php .php .php4 AddType application/x-httpd-php-source .phps
In addition, the PHP directive names for Apache have changed.
Starting with PHP 4.0, there are only four Apache directives that relate to PHP:
php_value [PHP directive name] [value]
php_flag [PHP directive name] [On|Off]
php_admin_value [PHP directive name] [value]
php_admin_flag [PHP directive name] [On|Off]
There are two differences between the Admin values and the non admin values:
To make the transition process easier, PHP 4.0 is bundled with scripts that automatically convert your Apache configuration and .htaccess files to work with both PHP 3.0 and PHP 4.0. These scripts do NOT convert the mime type lines! You have to convert these yourself.
To convert your Apache configuration files, run the apconf-conv.sh script (available in the scripts/apache/ directory). For example:
~/php4/scripts/apache:# ./apconf-conv.sh /usr/local/apache/conf/httpd.conf
Your original configuration file will be saved in httpd.conf.orig.
To convert your .htaccess files, run the aphtaccess-conv.sh script (available in the scripts/apache/ directory as well):
~/php4/scripts/apache:# find / -name .htaccess -exec ./aphtaccess-conv.sh {} \;
Likewise, your old .htaccess files will be saved with an .orig prefix.
The conversion scripts require awk to be installed.
commonFooter(); ?>