]> granicus.if.org Git - php/commitdiff
Point to the online documentation for installation of PHP in INSTALL, and remove...
authorKalle Sommer Nielsen <kalle@php.net>
Fri, 21 Jul 2017 16:42:57 +0000 (18:42 +0200)
committerKalle Sommer Nielsen <kalle@php.net>
Fri, 21 Jul 2017 16:42:57 +0000 (18:42 +0200)
INSTALL
win32/install.txt [deleted file]

diff --git a/INSTALL b/INSTALL
index 5242ad17cdc5628baa4dc09a0e52cf40d42c398c..d2f4f42a99830b5b5750faa5cc1a3d083b4b9647 100644 (file)
--- a/INSTALL
+++ b/INSTALL
-     __________________________________________________________________
+For installation of PHP, please refer to the online documentation available at:
 
-Installing PHP
-     __________________________________________________________________
-
-     * General Installation Considerations
-     * Installation on Unix systems
-          + Apache 2.x on Unix systems
-          + Lighttpd 1.4 on Unix systems
-          + Sun, iPlanet and Netscape servers on Sun Solaris
-          + CGI and command line setups
-          + HP-UX specific installation notes
-          + OpenBSD installation notes
-          + Solaris specific installation tips
-          + Debian GNU/Linux installation notes
-     * Installation on Mac OS X
-          + Using Packages
-          + Using the bundled PHP
-          + Compiling PHP on Mac OS X
-     * Installation of PECL extensions
-          + Introduction to PECL Installations
-          + Downloading PECL extensions
-          + Installing a PHP extension on Windows
-          + Compiling shared PECL extensions with the pecl command
-          + Compiling shared PECL extensions with phpize
-          + php-config
-          + Compiling PECL extensions statically into PHP
-     * Problems?
-          + Read the FAQ
-          + Other problems
-          + Bug reports
-     * Runtime Configuration
-          + The configuration file
-          + .user.ini files
-          + Where a configuration setting may be set
-          + How to change configuration settings
-     * Installation
-     __________________________________________________________________
-
-     __________________________________________________________________
-
-Preface
-
-   These installation instructions were generated from the HTML version of
-   the  PHP  Manual  so  formatting and linking have been altered. See the
-   online and updated version at: http://php.net/install.unix
-     __________________________________________________________________
-
-General Installation Considerations
-
-   Before  starting  the  installation, first you need to know what do you
-   want  to  use  PHP for. There are three main fields you can use PHP, as
-   described in the What can PHP do? section:
-     * Websites and web applications (server-side scripting)
-     * Command line scripting
-     * Desktop (GUI) applications
-
-   For  the first and most common form, you need three things: PHP itself,
-   a  web  server  and  a  web  browser.  You  probably already have a web
-   browser,  and  depending  on  your operating system setup, you may also
-   have  a  web server (e.g. Apache on Linux and MacOS X; IIS on Windows).
-   You  may  also  rent webspace at a company. This way, you don't need to
-   set  up anything on your own, only write your PHP scripts, upload it to
-   the server you rent, and see the results in your browser.
-
-   If PHP has no module  support  for your web server, ´you can always use 
-   it as a CGI or FastCGI  processor.  This  means  you set up your server 
-   to use the  CGI executable of PHP to process all  PHP file  requests on 
-   the server.
-
-   If  you are also interested to use PHP for command line scripting (e.g.
-   write scripts autogenerating some images for you offline, or processing
-   text  files  depending  on some arguments you pass to them), you always
-   need  the  command  line  executable.  For  more  information, read the
-   section  about writing command line PHP applications. In this case, you
-   need no server and no browser.
-
-   With  PHP you can also write desktop GUI applications using the PHP-GTK
-   extension.  This  is  a  completely different approach than writing web
-   pages,  as  you  do not output any HTML, but manage windows and objects
-   within  them.  For  more  information about PHP-GTK, please » visit the
-   site  dedicated  to  this  extension.  PHP-GTK  is  not included in the
-   official PHP distribution.
-
-   From  now on, this section deals with setting up PHP for web servers on
-   Unix and Windows with server module interfaces and CGI executables. You
-   will  also  find  information  on  the  command  line executable in the
-   following sections.
-
-   PHP  source  code  and binary distributions for Windows can be found at
-   » http://www.php.net/downloads.php.   We  recommend  you  to  choose  a
-   » mirror nearest to you for downloading the distributions.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Installation on Unix systems
-
-Table of Contents
-
-     * Apache 2.x on Unix systems
-     * Lighttpd 1.4 on Unix systems
-     * Sun, iPlanet and Netscape servers on Sun Solaris
-     * CGI and command line setups
-     * HP-UX specific installation notes
-     * OpenBSD installation notes
-     * Solaris specific installation tips
-     * Debian GNU/Linux installation notes
-
-   This  section  will  guide  you  through  the general configuration and
-   installation  of  PHP  on  Unix  systems.  Be  sure  to investigate any
-   sections  specific  to your platform or web server before you begin the
-   process.
-
-   As  our  manual  outlines  in  the  General Installation Considerations
-   section,  we  are mainly dealing with web centric setups of PHP in this
-   section,  although  we will cover setting up PHP for command line usage
-   as well.
-
-   There  are  several  ways  to install PHP for the Unix platform, either
-   with  a  compile and configure process, or through various pre-packaged
-   methods.  This  documentation  is  mainly focused around the process of
-   compiling and configuring PHP. Many Unix like systems have some sort of
-   package  installation  system. This can assist in setting up a standard
-   configuration,  but  if  you  need  to have a different set of features
-   (such as a secure server, or a different database driver), you may need
-   to  build  PHP  and/or  your  web  server.  If  you are unfamiliar with
-   building  and  compiling your own software, it is worth checking to see
-   whether  somebody  has already built a packaged version of PHP with the
-   features you need.
-
-   Prerequisite knowledge and software for compiling:
-     * Basic Unix skills (being able to operate "make" and a C compiler)
-     * An ANSI C compiler
-     * A web server
-     * Any module specific components (such as GD, PDF libs, etc.)
-
-   When  building  directly from Git sources or after custom modifications
-   you might also need:
-     * autoconf: 2.13+ (for PHP < 5.4.0), 2.59+ (for PHP >= 5.4.0)
-     * automake: 1.4+
-     * libtool: 1.4.x+ (except 1.4.2)
-     * re2c: Version 0.13.4 or newer
-     * flex: Version 2.5.4 (for PHP <= 5.2)
-     * bison: Version 1.28 (preferred), 1.35, or 1.75
-
-   The  initial  PHP  setup and configuration process is controlled by the
-   use  of the command line options of the configure script. You could get
-   a  list  of all available options along with short explanations running
-   ./configure   --help.   Our  manual  documents  the  different  options
-   separately.  You  will find the core options in the appendix, while the
-   different  extension  specific  options  are  described on the reference
-   pages.
-
-   When  PHP  is  configured,  you  are  ready  to build the module and/or
-   executables. The command make should take care of this. If it fails and
-   you can't figure out why, see the Problems section.
-     __________________________________________________________________
-
-Apache 2.x on Unix systems
-
-   This  section  contains notes and hints specific to Apache 2.x installs
-   of PHP on Unix systems.
-   Warning
-
-   We  do  not recommend using a threaded MPM in production with Apache 2.
-   Use  the prefork MPM, which is the default MPM with Apache 2.0 and 2.2.
-   For  information  on  why,  read the related FAQ entry on using Apache2
-   with a threaded MPM
-
-   The   » Apache  Documentation  is  the  most  authoritative  source  of
-   information   on   the   Apache  2.x  server.  More  information  about
-   installation options for Apache may be found there.
-
-   The  most  recent  version  of  Apache HTTP Server may be obtained from
-   » Apache  download  site,  and  a  fitting  PHP  version from the above
-   mentioned  places.  This  quick  guide  covers  only  the basics to get
-   started with Apache 2.x and PHP. For more information read the » Apache
-   Documentation.  The  version  numbers have been omitted here, to ensure
-   the  instructions are not incorrect. In the examples below, 'NN' should
-   be replaced with the specific version of Apache being used.
-
-   There  are  currently two versions of Apache 2.x - there's 2.0 and 2.2.
-   While  there  are various reasons for choosing each, 2.2 is the current
-   latest  version,  and  the  one  that is recommended, if that option is
-   available  to  you. However, the instructions here will work for either
-   2.0 or 2.2.
-    1. Obtain  the  Apache HTTP server from the location listed above, and
-       unpack it:
-gzip -d httpd-2_x_NN.tar.gz
-tar -xf httpd-2_x_NN.tar
-
-    2. Likewise, obtain and unpack the PHP source:
-gunzip php-NN.tar.gz
-tar -xf php-NN.tar
-
-    3. Build  and install Apache. Consult the Apache install documentation
-       for more details on building Apache.
-cd httpd-2_x_NN
-./configure --enable-so
-make
-make install
-
-    4. Now  you  have  Apache  2.x.NN  available under /usr/local/apache2,
-       configured  with  loadable  module  support  and  the  standard MPM
-       prefork.  To  test  the  installation use your normal procedure for
-       starting the Apache server, e.g.:
-/usr/local/apache2/bin/apachectl start
-
-       and stop the server to go on with the configuration for PHP:
-/usr/local/apache2/bin/apachectl stop
-
-    5. Now,  configure and build PHP. This is where you customize PHP with
-       various  options,  like  which  extensions  will  be  enabled.  Run
-       ./configure  --help for a list of available options. In our example
-       we'll do a simple configure with Apache 2 and MySQL support.
-       If  you  built  Apache  from  source, as described above, the below
-       example  will match your path for apxs, but if you installed Apache
-       some other way, you'll need to adjust the path to apxs accordingly.
-       Note that some distros may rename apxs to apxs2.
-cd ../php-NN
-./configure --with-apxs2=/usr/local/apache2/bin/apxs --with-mysql
-make
-make install
-
-       If  you decide to change your configure options after installation,
-       you'll  need to re-run the configure, make, and make install steps.
-       You  only need to restart apache for the new module to take effect.
-       A recompile of Apache is not needed.
-       Note  that  unless told otherwise, 'make install' will also install
-       PEAR,  various  PHP  tools such as phpize, install the PHP CLI, and
-       more.
-    6. Setup your php.ini
-cp php.ini-development /usr/local/lib/php.ini
-
-       You  may  edit  your  .ini  file  to set PHP options. If you prefer
-       having php.ini in another location, use
-       --with-config-file-path=/some/path in step 5.
-       If  you  instead  choose php.ini-production, be certain to read the
-       list of changes within, as they affect how PHP behaves.
-    7. Edit  your httpd.conf to load the PHP module. The path on the right
-       hand side of the LoadModule statement must point to the path of the
-       PHP  module  on  your  system. The make install from above may have
-       already added this for you, but be sure to check.
-LoadModule php7_module modules/libphp7.so
-    8. Tell  Apache to parse certain extensions as PHP. For example, let's
-       have  Apache  parse  .php  files  as PHP. Instead of only using the
-       Apache  AddType  directive,  we want to avoid potentially dangerous
-       uploads  and  created  files  such  as  exploit.php.jpg  from being
-       executed   as   PHP.   Using  this  example,  you  could  have  any
-       extension(s)  parse as PHP by simply adding them. We'll add .php to
-       demonstrate.
-<FilesMatch \.php$>
-    SetHandler application/x-httpd-php
-</FilesMatch>
-       Or,  if we wanted to allow .php, .php2, .php3, .php4, .php5, .php7,
-       and  .phtml files to be executed as PHP, but nothing else, we'd use
-       this:
-<FilesMatch "\.ph(p[2-7]?|tml)$">
-    SetHandler application/x-httpd-php
-</FilesMatch>
-       And  to  allow  .phps files to be handled by the php source filter,
-       and displayed as syntax-highlighted source code, use this:
-<FilesMatch "\.phps$">
-    SetHandler application/x-httpd-php-source
-</FilesMatch>
-       mod_rewrite  may  be  used  To  allow any arbitrary .php file to be
-       displayed  as  syntax-highlighted  source  code,  without having to
-       rename or copy it to a .phps file:
-RewriteEngine On
-RewriteRule (.*\.php)s$ $1 [H=application/x-httpd-php-source]
-       The  php source filter should not be enabled on production systems,
-       where it may expose confidential or otherwise sensitive information
-       embedded in source code.
-    9. Use your normal procedure for starting the Apache server, e.g.:
-/usr/local/apache2/bin/apachectl start
-
-       OR
-service httpd restart
-
-   Following  the  steps  above you will have a running Apache2 web server
-   with  support  for  PHP as a SAPI module. Of course there are many more
-   configuration  options  available  Apache and PHP. For more information
-   type ./configure --help in the corresponding source tree.
-
-   Apache  may  be built multithreaded by selecting the worker MPM, rather
-   than  the  standard  prefork MPM, when Apache is built. This is done by
-   adding  the  following option to the argument passed to ./configure, in
-   step 3 above:
-   --with-mpm=worker
-
-   This  should  not be undertaken without being aware of the consequences
-   of  this  decision,  and  having  at  least a fair understanding of the
-   implications.   The   Apache   documentation   regarding  » MPM-Modules
-   discusses MPMs in a great deal more detail.
-
-     Note:
-
-     The Apache MultiViews FAQ discusses using multiviews with PHP.
-
-     Note:
-
-     To  build  a multithreaded version of Apache, the target system must
-     support  threads.  In  this  case,  PHP  should  also  be built with
-     experimental Zend Thread Safety (ZTS). Under this configuration, not
-     all  extensions will be available. The recommended setup is to build
-     Apache with the default prefork MPM-Module.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Lighttpd 1.4 on Unix systems
-
-   This section contains notes and hints specific to Lighttpd 1.4 installs
-   of PHP on Unix systems.
-
-   Please  use  the  » Lighttpd  trac  to  learn  how  to install Lighttpd
-   properly before continuing.
-
-   Fastcgi  is  the preferred SAPI to connect PHP and Lighttpd. Fastcgi is
-   automagically  enabled  in  php-cgi  in PHP 5.3, but for older versions
-   configure  PHP  with  --enable-fastcgi. To confirm that PHP has fastcgi
-   enabled,  php  -v should contain PHP 5.2.5 (cgi-fcgi) Before PHP 5.2.3,
-   fastcgi was enabled on the php binary (there was no php-cgi).
-
-Letting Lighttpd spawn php processes
-
-   To  configure  Lighttpd  to connect to php and spawn fastcgi processes,
-   edit  lighttpd.conf.  Sockets  are  preferred  to  connect  to  fastcgi
-   processes on the local system.
-
-   Example #1 Partial lighttpd.conf
-server.modules += ( "mod_fastcgi" )
-
-fastcgi.server = ( ".php" =>
-  ((
-    "socket" => "/tmp/php.socket",
-    "bin-path" => "/usr/local/bin/php-cgi",
-    "bin-environment" => (
-      "PHP_FCGI_CHILDREN" => "16",
-      "PHP_FCGI_MAX_REQUESTS" => "10000"
-    ),
-    "min-procs" => 1,
-    "max-procs" => 1,
-    "idle-timeout" => 20
-  ))
-)
-
-   The  bin-path  directive  allows  lighttpd  to  spawn fastcgi processes
-   dynamically. PHP will spawn children according to the PHP_FCGI_CHILDREN
-   environment   variable.   The   "bin-environment"  directive  sets  the
-   environment  for  the  spawned processes. PHP will kill a child process
-   after  the  number  of  requests  specified by PHP_FCGI_MAX_REQUESTS is
-   reached. The directives "min-procs" and "max-procs" should generally be
-   avoided  with  PHP. PHP manages its own children and opcode caches like
-   APC  will  only  share among children managed by PHP. If "min-procs" is
-   set  to  something  greater  than 1, the total number of php responders
-   will  be  multiplied PHP_FCGI_CHILDREN (2 min-procs * 16 children gives
-   32 responders).
-
-Spawning with spawn-fcgi
-
-   Lighttpd  provides  a  program called spawn-fcgi to ease the process of
-   spawning fastcgi processes easier.
-
-Spawning php-cgi
-
-   It  is  possible to spawn processes without spawn-fcgi, though a bit of
-   heavy-lifting  is  required.  Setting the PHP_FCGI_CHILDREN environment
-   var  controls  how  many  children  PHP  will  spawn to handle incoming
-   requests.  Setting  PHP_FCGI_MAX_REQUESTS  will  determine how long (in
-   requests)  each  child  will  live. Here's a simple bash script to help
-   spawn php responders.
-
-   Example #2 Spawning FastCGI Responders
-#!/bin/sh
-
-# Location of the php-cgi binary
-PHP=/usr/local/bin/php-cgi
-
-# PID File location
-PHP_PID=/tmp/php.pid
-
-# Binding to an address
-#FCGI_BIND_ADDRESS=10.0.1.1:10000
-# Binding to a domain socket
-FCGI_BIND_ADDRESS=/tmp/php.sock
-
-PHP_FCGI_CHILDREN=16
-PHP_FCGI_MAX_REQUESTS=10000
-
-env -i PHP_FCGI_CHILDREN=$PHP_FCGI_CHILDREN \
-       PHP_FCGI_MAX_REQUESTS=$PHP_FCGI_MAX_REQUESTS \
-       $PHP -b $FCGI_BIND_ADDRESS &
-
-echo $! > "$PHP_PID"
-
-
-Connecting to remote FCGI instances
-
-   Fastcgi  instances  can be spawned on multiple remote machines in order
-   to scale applications.
-
-   Example #3 Connecting to remote php-fastcgi instances
-fastcgi.server = ( ".php" =>
-   (( "host" => "10.0.0.2", "port" => 1030 ),
-    ( "host" => "10.0.0.3", "port" => 1030 ))
-)
-
-     __________________________________________________________________
-     __________________________________________________________________
-
-CGI and command line setups
-
-   By  default,  PHP  is built as both a CLI and CGI program, which can be
-   used  for  CGI processing. If you are running a web server that PHP has
-   module  support  for,  you  should  generally  go for that solution for
-   performance  reasons.  However,  the  CGI  version enables users to run
-   different PHP-enabled pages under different user-ids.
-   Warning
-
-   A   server   deployed   in   CGI  mode  is  open  to  several  possible
-   vulnerabilities.  Please  read our CGI security section to learn how to
-   defend yourself from such attacks.
-
-Testing
-
-   If  you  have  built  PHP  as a CGI program, you may test your build by
-   typing make test. It is always a good idea to test your build. This way
-   you  may  catch  a  problem  with PHP on your platform early instead of
-   having to struggle with it later.
-
-Using Variables
-
-   Some  server  supplied  environment  variables  are  not defined in the
-   current  » CGI/1.1  specification.  Only  the  following  variables are
-   defined     there:     AUTH_TYPE,     CONTENT_LENGTH,     CONTENT_TYPE,
-   GATEWAY_INTERFACE,     PATH_INFO,     PATH_TRANSLATED,    QUERY_STRING,
-   REMOTE_ADDR,  REMOTE_HOST,  REMOTE_IDENT,  REMOTE_USER, REQUEST_METHOD,
-   SCRIPT_NAME,    SERVER_NAME,    SERVER_PORT,    SERVER_PROTOCOL,    and
-   SERVER_SOFTWARE.   Everything   else   should  be  treated  as  'vendor
-   extensions'.
-     __________________________________________________________________
-     __________________________________________________________________
-
-HP-UX specific installation notes
-
-   This  section  contains  notes  and hints specific to installing PHP on
-   HP-UX systems.
-
-   There  are two main options for installing PHP on HP-UX systems. Either
-   compile it, or install a pre-compiled binary.
-
-   Official      pre-compiled      packages      are     located     here:
-   » http://software.hp.com/
-
-   Until  this  manual  section  is  rewritten,  the  documentation  about
-   compiling  PHP  (and  related  extensions)  on  HP-UX  systems has been
-   removed.  For  now,  consider  reading the following external resource:
-   » Building Apache and PHP on HP-UX 11.11
-     __________________________________________________________________
-     __________________________________________________________________
-
-OpenBSD installation notes
-
-   This  section  contains  notes  and hints specific to installing PHP on
-   » OpenBSD 3.6.
-
-Using Binary Packages
-
-   Using  binary packages to install PHP on OpenBSD is the recommended and
-   simplest  method.  The core package has been separated from the various
-   modules,  and  each can be installed and removed independently from the
-   others.  The  files  you need can be found on your OpenBSD CD or on the
-   FTP site.
-
-   The  main  package  you  need  to install is php4-core-4.3.8.tgz, which
-   contains  the  basic engine (plus gettext and iconv). Next, take a look
-   at    the    module   packages,   such   as   php4-mysql-4.3.8.tgz   or
-   php4-imap-4.3.8.tgz.  You need to use the phpxs command to activate and
-   deactivate these modules in your php.ini.
-
-   Example #1 OpenBSD Package Install Example
-# pkg_add php4-core-4.3.8.tgz
-# /usr/local/sbin/phpxs -s
-# cp /usr/local/share/doc/php4/php.ini-recommended /var/www/conf/php.ini
-  (add in mysql)
-# pkg_add php4-mysql-4.3.8.tgz
-# /usr/local/sbin/phpxs -a mysql
-  (add in imap)
-# pkg_add php4-imap-4.3.8.tgz
-# /usr/local/sbin/phpxs -a imap
-  (remove mysql as a test)
-# pkg_delete php4-mysql-4.3.8
-# /usr/local/sbin/phpxs -r mysql
-  (install the PEAR libraries)
-# pkg_add php4-pear-4.3.8.tgz
-
-   Read  the  » packages(7)  manual page for more information about binary
-   packages on OpenBSD.
-
-Using Ports
-
-   You  can  also  compile  up  PHP  from  source  using the » ports tree.
-   However,  this is only recommended for users familiar with OpenBSD. The
-   PHP  4 port is split into two sub-directories: core and extensions. The
-   extensions  directory  generates  sub-packages for all of the supported
-   PHP  modules.  If  you  find  you  do  not want to create some of these
-   modules,  use  the  no_* FLAVOR. For example, to skip building the imap
-   module, set the FLAVOR to no_imap.
-
-Common Problems
-
-     * The default install of Apache runs inside a » chroot(2) jail, which
-       will  restrict  PHP  scripts to accessing files under /var/www. You
-       will  therefore  need  to  create  a /var/www/tmp directory for PHP
-       session  files to be stored, or use an alternative session backend.
-       In  addition, database sockets need to be placed inside the jail or
-       listen  on  the  localhost interface. If you use network functions,
-       some  files  from  /etc  such as /etc/resolv.conf and /etc/services
-       will  need  to be moved into /var/www/etc. The OpenBSD PEAR package
-       automatically  installs  into the correct chroot directories, so no
-       special  modification  is  needed  there.  More  information on the
-       OpenBSD Apache is available in the » OpenBSD FAQ.
-     * The  OpenBSD 3.6 package for the » gd extension requires XFree86 to
-       be  installed.  If you do not wish to use some of the font features
-       that  require  X11,  install  the  php4-gd-4.3.8-no_x11.tgz package
-       instead.
-
-Older Releases
-
-   Older  releases  of  OpenBSD  used  the  FLAVORS system to compile up a
-   statically  linked  PHP.  Since  it is hard to generate binary packages
-   using  this  method,  it  is  now deprecated. You can still use the old
-   stable ports trees if you wish, but they are unsupported by the OpenBSD
-   team.  If  you have any comments about this, the current maintainer for
-   the port is Anil Madhavapeddy (avsm at openbsd dot org).
-     __________________________________________________________________
-     __________________________________________________________________
-
-Solaris specific installation tips
-
-   This  section  contains  notes  and hints specific to installing PHP on
-   Solaris systems.
-
-Required software
-
-   Solaris  installs  often lack C compilers and their related tools. Read
-   this  FAQ  for  information on why using GNU versions for some of these
-   tools is necessary.
-
-   For unpacking the PHP distribution you need
-     * tar
-     * gzip or
-     * bzip2
-
-   For compiling PHP you need
-     * gcc (recommended, other C compilers may work)
-     * make
-     * GNU sed
-
-   For building extra extensions or hacking the code of PHP you might also
-   need
-     * flex (up to PHP 5.2)
-     * re2c
-     * bison
-     * m4
-     * autoconf
-     * automake
-
-   In  addition,  you  will  need  to  install  (and possibly compile) any
-   additional  software  specific to your configuration, such as Oracle or
-   MySQL.
-
-Using Packages
-
-   You can simplify the Solaris install process by using pkgadd to install
-   most  of  your  needed components. The Image Packaging System (IPS) for
-   Solaris  11  Express  also contains most of the required components for
-   installation using the pkg command.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Debian GNU/Linux installation notes
-
-   This  section  contains  notes  and hints specific to installing PHP on
-   » Debian GNU/Linux.
-   Warning
-
-   Unofficial  builds  from third-parties are not supported here. Any bugs
-   should  be  reported  to  the Debian team unless they can be reproduced
-   using the latest builds from our » download area.
-
-   While  the  instructions  for  building  PHP on Unix apply to Debian as
-   well, this manual page contains specific information for other options,
-   such as using either the apt-get or aptitude commands. This manual page
-   uses these two commands interchangeably.
-
-Using APT
-
-   First,   note   that   other  related  packages  may  be  desired  like
-   libapache2-mod-php7 to integrate with Apache 2, and php-pear for PEAR.
-
-   Second,  before  installing  a package, it's wise to ensure the package
-   list  is  up  to  date.  Typically, this is done by running the command
-   apt-get update.
-
-   Example #1 Debian Install Example with Apache 2
-# apt-get install php7-common libapache2-mod-php7 php7-cli
-
-   APT will automatically install the PHP 7 module for Apache 2 and all of
-   its  dependencies,  and then activate it. Apache should be restarted in
-   order for the changes take place. For example:
-
-   Example #2 Stopping and starting Apache once PHP is installed
-# /etc/init.d/apache2 stop
-# /etc/init.d/apache2 start
-
-Better control of configuration
-
-   In  the  last  section,  PHP was installed with only core modules. It's
-   very  likely  that  additional  modules will be desired, such as MySQL,
-   cURL, GD, etc. These may also be installed via the apt-get command.
-
-   Example #3 Methods for listing additional PHP 7 packages
-# apt-cache search php7
-# aptitude search php7
-# aptitude search php7 |grep -i mysql
-
-   The examples will show a lot of packages including several PHP specific
-   ones  like  php7-cgi, php7-cli and php7-dev. Determine which are needed
-   and  install  them  like any other with either apt-get or aptitude. And
-   because  Debian  performs  dependency checks, it'll prompt for those so
-   for example to install MySQL and cURL:
-
-   Example #4 Install PHP with MySQL, cURL
-# apt-get install php7-mysql php7-curl
-
-   APT  will  automatically  add  the  appropriate  lines to the different
-   php.ini      related      files     like     /etc/php7/apache2/php.ini,
-   /etc/php7/conf.d/pdo.ini,  etc. and depending on the extension will add
-   entries similar to extension=foo.so. However, restarting the web server
-   (like Apache) is required before these changes take affect.
-
-Common Problems
-
-     * If  the  PHP  scripts are not parsing via the web server, then it's
-       likely  that  PHP  was  not added to the web server's configuration
-       file,  which on Debian may be /etc/apache2/apache2.conf or similar.
-       See the Debian manual for further details.
-     * If  an  extension  was  seemingly  installed  yet the functions are
-       undefined,  be  sure  that the appropriate ini file is being loaded
-       and/or the web server was restarted after installation.
-     * There are two basic commands for installing packages on Debian (and
-       other  linux  variants):  apt-get and aptitude. However, explaining
-       the subtle differences between these commands goes beyond the scope
-       of this manual.
-     __________________________________________________________________
-     __________________________________________________________________
-     __________________________________________________________________
-
-Installation on Mac OS X
-
-Table of Contents
-
-     * Using Packages
-     * Using the bundled PHP
-     * Compiling PHP on Mac OS X
-
-   This section contains notes and hints specific to installing PHP on Mac
-   OS  X.  PHP  is bundled with Macs, and compiling is similar to the Unix
-   installation guide.
-     __________________________________________________________________
-
-Using Packages
-
-   There  are  a few pre-packaged and pre-compiled versions of PHP for Mac
-   OS  X. This can help in setting up a standard configuration, but if you
-   need to have a different set of features (such as a secure server, or a
-   different  database  driver), you may need to build PHP and/or your web
-   server yourself. If you are unfamiliar with building and compiling your
-   own  software, it's worth checking whether somebody has already built a
-   packaged version of PHP with the features you need.
-
-   The  following resources offer easy to install packages and precompiled
-   binaries for PHP on Mac OS:
-
-     * MacPorts: » http://www.macports.org/
-     * Entropy: » http://www.entropy.ch/software/macosx/php/
-     * Fink: » http://www.finkproject.org/
-     * Homebrew: » http://github.com/mxcl/homebrew
-     __________________________________________________________________
-     __________________________________________________________________
-
-Using the bundled PHP
-
-   PHP has come standard with Macs since OS X version 10.0.0. Enabling PHP
-   with  the  default  web server requires uncommenting a few lines in the
-   Apache  configuration  file  httpd.conf  whereas the CGI and/or CLI are
-   enabled by default (easily accessible via the Terminal program).
-
-   Enabling  PHP using the instructions below is meant for quickly setting
-   up  a  local development environment. It's highly recommended to always
-   upgrade  PHP  to  the  newest  version.  Like most live software, newer
-   versions  are  created to fix bugs and add features and PHP being is no
-   different.  See the appropriate MAC OS X installation documentation for
-   further  details.  The  following  instructions  are  geared  towards a
-   beginner with details provided for getting a default setup to work. All
-   users are encouraged to compile, or install a new packaged version.
-
-   The  standard  installation  type  is  using  mod_php, and enabling the
-   bundled  mod_php on Mac OS X for the Apache web server (the default web
-   server,  that  is  accessible  via  System  Preferences)  involves  the
-   following steps:
-
-    1. Locate  and  open  the  Apache  configuration file. By default, the
-       location   is  as  follows:  /private/etc/apache2/httpd.conf  Using
-       Finder  or  Spotlight  to  find this file may prove difficult as by
-       default it's private and owned by the root user.
-
-     Note:  One  way to open this is by using a Unix based text editor in
-     the  Terminal,  for  example  nano, and because the file is owned by
-     root  we'll use the sudo command to open it (as root) so for example
-     type  the  following  into  the Terminal Application (after, it will
-     prompt  for  a  password): sudo nano /private/etc/apache2/httpd.conf
-     Noteworthy  nano  commands:  ^w  (search),  ^o (save), and ^x (exit)
-     where ^ represents the Ctrl key.
-
-     Note:  Versions  of  Mac  OS X prior to 10.5 were bundled with older
-     versions  of  PHP and Apache. As such, the Apache configuration file
-     on legacy machines may be /etc/httpd/httpd.conf.
-    2. With  a  text  editor, uncomment the lines (by removing the #) that
-       look  similar  to  the  following  (these  two  lines are often not
-       together, locate them both in the file):
-# LoadModule php7_module libexec/httpd/libphp7.so
-
-# AddModule mod_php7.c
-
-       Notice  the  location/path.  When  building  PHP in the future, the
-       above files should be replaced or commented out.
-    3. Be  sure  the  desired extensions will parse as PHP (examples: .php
-       .html and .inc)
-       Due  to  the following statement already existing in httpd.conf (as
-       of   Mac  Panther),  once  PHP  is  enabled  the  .php  files  will
-       automatically parse as PHP.
-<IfModule mod_php7.c>
-    # If php is turned on, we respect .php and .phps files.
-    AddType application/x-httpd-php .php
-    AddType application/x-httpd-php-source .phps
-
-    # Since most users will want index.php to work we
-    # also automatically enable index.php
-    <IfModule mod_dir.c>
-        DirectoryIndex index.html index.php
-    </IfModule>
-</IfModule>
-
-     Note:
-     Before  OS  X  10.5 (Leopard), PHP 4 was bundled instead of PHP 5 in
-     which  case  the above instructions will differ slightly by changing
-     5's to 4's.
-    4. Be  sure  the  DirectoryIndex  loads the desired default index file
-       This  is also set in httpd.conf. Typically index.php and index.html
-       are  used. By default index.php is enabled because it's also in the
-       PHP check shown above. Adjust accordingly.
-    5. Set  the  php.ini  location  or  use  the default A typical default
-       location  on  Mac  OS  X  is  /usr/local/php/php.ini  and a call to
-       phpinfo()  will  reveal this information. If a php.ini is not used,
-       PHP  will  use  all  default  values.  See  also the related FAQ on
-       finding php.ini.
-    6. Locate  or  set the DocumentRoot This is the root directory for all
-       the  web  files.  Files  in  this directory are served from the web
-       server so the PHP files will parse as PHP before outputting them to
-       the browser. A typical default path is /Library/WebServer/Documents
-       but  this  can be set to anything in httpd.conf. Alternatively, the
-       default      DocumentRoot      for      individual     users     is
-       /Users/yourusername/Sites
-    7. Create a phpinfo() file
-       The phpinfo() function will display information about PHP. Consider
-       creating a file in the DocumentRoot with the following PHP code:
-       <?php phpinfo(); ?>
-    8. Restart  Apache,  and  load  the PHP file created above To restart,
-       either  execute  sudo apachectl graceful in the shell or stop/start
-       the "Personal Web Server" option in the OS X System Preferences. By
-       default,  loading  local files in the browser will have an URL like
-       so: http://localhost/info.php Or using the DocumentRoot in the user
-       directory  is  another  option  and  would  end  up  looking  like:
-       http://localhost/~yourusername/info.php
-
-   The  CLI  (or  CGI  in  older  versions) is appropriately named php and
-   likely  exists  as /usr/bin/php. Open up the terminal, read the command
-   line  section  of  the  PHP manual, and execute php -v to check the PHP
-   version  of  this PHP binary. A call to phpinfo() will also reveal this
-   information.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Compiling PHP on Mac OS X
-
-   Use the Unix installation guide to compile PHP on Mac OS X.
-     __________________________________________________________________
-     __________________________________________________________________
-     __________________________________________________________________
-
-Installation of PECL extensions
-
-Table of Contents
-
-     * Introduction to PECL Installations
-     * Downloading PECL extensions
-     * Installing a PHP extension on Windows
-     * Compiling shared PECL extensions with the pecl command
-     * Compiling shared PECL extensions with phpize
-     * php-config
-     * Compiling PECL extensions statically into PHP
-     __________________________________________________________________
-
-Introduction to PECL Installations
-
-   » PECL is a repository of PHP extensions that are made available to you
-   via the » PEAR packaging system. This section of the manual is intended
-   to demonstrate how to obtain and install PECL extensions.
-
-   These  instructions  assume  /your/phpsrcdir/  is  the  path to the PHP
-   source  distribution,  and  that  extname  is  the  name  of  the  PECL
-   extension.   Adjust  accordingly.  These  instructions  also  assume  a
-   familiarity with the » pear command. The information in the PEAR manual
-   for the pear command also applies to the pecl command.
-
-   To  be useful, a shared extension must be built, installed, and loaded.
-   The  methods  described  below provide you with various instructions on
-   how  to build and install the extensions, but they do not automatically
-   load  them.  Extensions can be loaded by adding an extension directive.
-   To this php.ini file, or through the use of the dl() function.
-
-   When  building  PHP modules, it's important to have known-good versions
-   of  the  required  tools  (autoconf,  automake,  libtool, etc.) See the
-   » Anonymous  Git  Instructions  for  details on the required tools, and
-   required versions.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Downloading PECL extensions
-
-   There are several options for downloading PECL extensions, such as:
-     * The  pecl  install  extname  command  downloads the extensions code
-       automatically,  so  in  this  case  there is no need for a separate
-       download.
-     * » http://pecl.php.net/ The PECL web site contains information about
-       the  different  extensions  that are offered by the PHP Development
-       Team.  The  information available here includes: ChangeLog, release
-       notes, requirements and other similar details.
-     * pecl  download extname PECL extensions that have releases listed on
-       the PECL web site are available for download and installation using
-       the » pecl command. Specific revisions may also be specified.
-     * SVN  Most  PECL extensions also reside in SVN. A web-based view may
-       be  seen at » http://svn.php.net/viewvc/pecl/. To download straight
-       from SVN, the following sequence of commands may be used:
-       $   svn  checkout  http://svn.php.net/repository/pecl/extname/trunk
-       extname
-     * Windows  downloads  At  this  time the PHP project does not compile
-       Windows binaries for PECL extensions. However, to compile PHP under
-       Windows see the chapter titled building PHP for Windows.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Installing a PHP extension on Windows
-
-   On  Windows,  you have two ways to load a PHP extension: either compile
-   it  into  PHP, or load the DLL. Loading a pre-compiled extension is the
-   easiest and preferred way.
-
-   To load an extension, you need to have it available as a ".dll" file on
-   your  system.  All  the  extensions  are automatically and periodically
-   compiled by the PHP Group (see next section for the download).
-
-   To  compile an extension into PHP, please refer to building from source
-   documentation.
-
-   To  compile  a  standalone  extension (aka a DLL file), please refer to
-   building  from  source  documentation.  If  the  DLL  file is available
-   neither with your PHP distribution nor in PECL, you may have to compile
-   it before you can start using the extension.
-
-Where to find an extension?
-
-   PHP   extensions   are  usually  called  "php_*.dll"  (where  the  star
-   represents  the  name  of the extension) and they are located under the
-   "PHP\ext" ("PHP\extensions" in PHP 4) folder.
-
-   PHP   ships  with  the  extensions  most  useful  to  the  majority  of
-   developers. They are called "core" extensions.
-
-   However,  if you need functionality not provided by any core extension,
-   you  may still be able to find one in PECL. The PHP Extension Community
-   Library  (PECL)  is  a  repository  for  PHP  Extensions,  providing  a
-   directory   of   all   known  extensions  and  hosting  facilities  for
-   downloading and development of PHP extensions.
-
-   If you have developed an extension for your own uses, you might want to
-   think  about  hosting it on PECL so that others with the same needs can
-   benefit from your time. A nice side effect is that you give them a good
-   chance  to  give you feedback, (hopefully) thanks, bug reports and even
-   fixes/patches.  Before  you  submit your extension for hosting on PECL,
-   please read http://pecl.php.net/package-new.php.
-
-Which extension to download?
-
-   Many times, you will find several versions of each DLL:
-     * Different  version  numbers  (at least the first two numbers should
-       match)
-     * Different thread safety settings
-     * Different processor architecture (x86, x64, ...)
-     * Different debugging settings
-     * etc.
-
-   You  should  keep in mind that your extension settings should match all
-   the  settings  of  the  PHP executable you are using. The following PHP
-   script will tell you all about your PHP settings:
-
-   Example #1 phpinfo() call
-   <?php
-   phpinfo();
-   ?>
-
-   Or from the command line, run:
-drive:\\path\to\php\executable\php.exe -i
-
-Loading an extension
-
-   The  most  common  way to load a PHP extension is to include it in your
-   php.ini  configuration  file.  Please  note  that  many  extensions are
-   already  present  in  your php.ini and that you only need to remove the
-   semicolon to activate them.
-;extension=php_extname.dll
-
-extension=php_extname.dll
-
-   However,  some  web  servers  are confusing because they do not use the
-   php.ini  located  alongside your PHP executable. To find out where your
-   actual php.ini resides, look for its path in phpinfo():
-Configuration File (php.ini) Path  C:\WINDOWS
-
-Loaded Configuration File   C:\Program Files\PHP\5.2\php.ini
-
-   After activating an extension, save php.ini, restart the web server and
-   check  phpinfo()  again.  The  new  extension  should  now have its own
-   section.
-
-Resolving problems
-
-   If  the  extension  does not appear in phpinfo(), you should check your
-   logs to learn where the problem comes from.
-
-   If you are using PHP from the command line (CLI), the extension loading
-   error can be read directly on screen.
-
-   If  you are using PHP with a web server, the location and format of the
-   logs  vary  depending  on  your  software.  Please read your web server
-   documentation  to  locate  the logs, as it does not have anything to do
-   with PHP itself.
-
-   Common  problems  are  the  location  of  the  DLL,  the value of the "
-   extension_dir"   setting   inside   php.ini  and  compile-time  setting
-   mismatches.
-
-   If  the  problem  lies in a compile-time setting mismatch, you probably
-   didn't download the right DLL. Try downloading again the extension with
-   the right settings. Again, phpinfo() can be of great help.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Compiling shared PECL extensions with the pecl command
-
-   PECL  makes  it  easy to create shared PHP extensions. Using the » pecl
-   command, do the following:
-
-   $ pecl install extname
-
-   This  will  download  the  source  for  extname,  compile,  and install
-   extname.so  into  your extension_dir. extname.so may then be loaded via
-   php.ini
-
-   By  default, the pecl command will not install packages that are marked
-   with  the alpha or beta state. If no stable packages are available, you
-   may install a beta package using the following command:
-
-   $ pecl install extname-beta
-
-   You may also install a specific version using this variant:
-
-   $ pecl install extname-0.1
-
-     Note:
-
-     After  enabling the extension in php.ini, restarting the web service
-     is required for the changes to be picked up.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Compiling shared PECL extensions with phpize
-
-   Sometimes,  using  the  pecl  installer is not an option. This could be
-   because  you're behind a firewall, or it could be because the extension
-   you want to install is not available as a PECL compatible package, such
-   as  unreleased  extensions  from  SVN.  If  you  need  to build such an
-   extension, you can use the lower-level build tools to perform the build
-   manually.
-
-   The  phpize  command is used to prepare the build environment for a PHP
-   extension. In the following sample, the sources for an extension are in
-   a directory named extname:
-
-$ cd extname
-$ phpize
-$ ./configure
-$ make
-# make install
-
-   A  successful  install will have created extname.so and put it into the
-   PHP  extensions directory. You'll need to and adjust php.ini and add an
-   extension=extname.so line before you can use the extension.
-
-   If  the  system is missing the phpize command, and precompiled packages
-   (like  RPM's)  are  used, be sure to also install the appropriate devel
-   version  of  the  PHP  package as they often include the phpize command
-   along   with  the  appropriate  header  files  to  build  PHP  and  its
-   extensions.
-
-   Execute phpize --help to display additional usage information.
-     __________________________________________________________________
-     __________________________________________________________________
-
-php-config
-
-   php-config is a simple shell script for obtaining information about the
-   installed PHP configuration.
-
-   When compiling extensions, if you have multiple PHP versions installed,
-   you may specify for which installation you'd like to build by using the
-   --with-php-config  option  during configuration, specifying the path of
-   the respective php-config script.
-
-   The  list of command line options provided by the php-config script can
-   be queried anytime by running php-config with the -h switch:
-Usage: /usr/local/bin/php-config [OPTION]
-Options:
-  --prefix            [...]
-  --includes          [...]
-  --ldflags           [...]
-  --libs              [...]
-  --extension-dir     [...]
-  --include-dir       [...]
-  --php-binary        [...]
-  --php-sapis         [...]
-  --configure-options [...]
-  --version           [...]
-  --vernum            [...]
-
-   CAPTION: Command line options
-
-   Option Description
-   --prefix Directory prefix where PHP is installed, e.g. /usr/local
-   --includes List of -I options with all include files
-   --ldflags LD Flags which PHP was compiled with
-   --libs Extra libraries which PHP was compiled with
-   --extension-dir Directory where extensions are searched by default
-   --include-dir Directory prefix where header files are installed by
-   default
-   --php-binary Full path to php CLI or CGI binary
-   --php-sapis Show all SAPI modules available
-   --configure-options  Configure  options  to  recreate  configuration of
-   current PHP installation
-   --version PHP version
-   --vernum PHP version as integer
-     __________________________________________________________________
-     __________________________________________________________________
-
-Compiling PECL extensions statically into PHP
-
-   You  might find that you need to build a PECL extension statically into
-   your  PHP binary. To do this, you'll need to place the extension source
-   under  the  php-src/ext/  directory  and  tell  the PHP build system to
-   regenerate its configure script.
-
-$ cd /your/phpsrcdir/ext
-$ pecl download extname
-$ gzip -d < extname.tgz | tar -xvf -
-$ mv extname-x.x.x extname
-
-   This will result in the following directory:
-
-   /your/phpsrcdir/ext/extname
-
-   From  here,  force  PHP to rebuild the configure script, and then build
-   PHP as normal:
-
-   $ cd /your/phpsrcdir
-   $ rm configure
-   $ ./buildconf --force
-   $ ./configure --help
-   $ ./configure --with-extname --enable-someotherext --with-foobar
-   $ make
-   $ make install
-
-     Note:  To  run  the  'buildconf'  script  you need autoconf 2.13 and
-     automake  1.4+  (newer  versions  of  autoconf may work, but are not
-     supported).
-
-   Whether  --enable-extname  or  --with-extname  is  used  depends on the
-   extension.  Typically  an  extension  that  does  not  require external
-   libraries uses --enable. To be sure, run the following after buildconf:
-
-   $ ./configure --help | grep extname
-     __________________________________________________________________
-     __________________________________________________________________
-     __________________________________________________________________
-
-Problems?
-
-Table of Contents
-
-     * Read the FAQ
-     * Other problems
-     * Bug reports
-     __________________________________________________________________
-
-Read the FAQ
-
-   Some  problems  are  more  common than others. The most common ones are
-   listed in the PHP FAQ, part of this manual.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Other problems
-
-   If  you  are  still stuck, someone on the PHP installation mailing list
-   may  be  able  to  help you. You should check out the archive first, in
-   case  someone already answered someone else who had the same problem as
-   you.   The   archives   are   available   from   the  support  page  on
-   » http://www.php.net/support.php.  To subscribe to the PHP installation
-   mailing list, send an empty mail to
-   » php-install-subscribe@lists.php.net.  The  mailing  list  address  is
-   » php-install@lists.php.net.
-
-   If  you  want to get help on the mailing list, please try to be precise
-   and  give the necessary details about your environment (which operating
-   system,  what  PHP  version, what web server, if you are running PHP as
-   CGI or a server module, safe mode, etc.), and preferably enough code to
-   make others able to reproduce and test your problem.
-     __________________________________________________________________
-     __________________________________________________________________
-
-Bug reports
-
-   If  you  think  you  have found a bug in PHP, please report it. The PHP
-   developers  probably  don't  know  about  it, and unless you report it,
-   chances  are  it  won't  be  fixed.  You  can  report  bugs  using  the
-   bug-tracking  system  at » http://bugs.php.net/. Please do not send bug
-   reports  in  mailing  list  or personal letters. The bug system is also
-   suitable to submit feature requests.
-
-   Read  the  » How  to  report  a  bug document before submitting any bug
-   reports!
-     __________________________________________________________________
-     __________________________________________________________________
-     __________________________________________________________________
-
-Runtime Configuration
-
-Table of Contents
-
-     * The configuration file
-     * .user.ini files
-     * Where a configuration setting may be set
-     * How to change configuration settings
-     __________________________________________________________________
-
-The configuration file
-
-   The  configuration  file  (php.ini) is read when PHP starts up. For the
-   server  module  versions  of  PHP,  this happens only once when the web
-   server  is  started.  For the CGI and CLI versions, it happens on every
-   invocation.
-
-   php.ini is searched for in these locations (in order):
-     * SAPI  module specific location (PHPIniDir directive in Apache 2, -c
-       command  line  option  in  CGI and CLI)
-     * The  PHPRC environment variable. Before PHP 5.2.0, this was checked
-       after the registry key mentioned below.
-     * As  of  PHP  5.2.0, the location of the php.ini file can be set for
-       different versions of PHP. The following registry keys are examined
-       in          order:         [HKEY_LOCAL_MACHINE\SOFTWARE\PHP\x.y.z],
-       [HKEY_LOCAL_MACHINE\SOFTWARE\PHP\x.y] and
-       [HKEY_LOCAL_MACHINE\SOFTWARE\PHP\x],  where x, y and z mean the PHP
-       major,  minor  and  release  versions.  If  there  is  a  value for
-       IniFilePath  in any of these keys, the first one found will be used
-       as the location of the php.ini (Windows only).
-     * [HKEY_LOCAL_MACHINE\SOFTWARE\PHP],  value  of  IniFilePath (Windows
-       only).
-     * Current working directory (except CLI).
-     * The  web server's directory (for SAPI modules), or directory of PHP
-       (otherwise in Windows).
-     * Windows  directory  (C:\windows  or  C:\winnt)  (for  Windows),  or
-       --with-config-file-path compile time option.
-
-   If php-SAPI.ini exists (where SAPI is the SAPI in use, so, for example,
-   php-cli.ini or php-apache.ini), it is used instead of php.ini. The SAPI
-   name can be determined with php_sapi_name().
-
-     Note:
-
-     The  Apache  web  server  changes  the directory to root at startup,
-     causing  PHP  to attempt to read php.ini from the root filesystem if
-     it exists.
-
-   The  php.ini  directives  handled  by  extensions are documented on the
-   respective  pages  of  the  extensions  themselves.  A list of the core
-   directives  is  available  in  the appendix. Not all PHP directives are
-   necessarily   documented  in  this  manual:  for  a  complete  list  of
-   directives  available  in  your  PHP  version,  please  read  your well
-   commented  php.ini  file.  Alternatively,  you  may  find  » the latest
-   php.ini from Git helpful too.
-
-   Example #1 php.ini example
-; any text on a line after an unquoted semicolon (;) is ignored
-[php] ; section markers (text within square brackets) are also ignored
-; Boolean values can be set to either:
-;    true, on, yes
-; or false, off, no, none
-register_globals = off
-track_errors = yes
-
-; you can enclose strings in double-quotes
-include_path = ".:/usr/local/lib/php"
-
-; backslashes are treated the same as any other character
-include_path = ".;c:\php\lib"
-
-   Since  PHP  5.1.0,  it  is possible to refer to existing .ini variables
-   from   within  .ini  files.  Example:  open_basedir  =  ${open_basedir}
-   ":/new/dir".
-     __________________________________________________________________
-     __________________________________________________________________
-
-.user.ini files
-
-   Since  PHP 5.3.0, PHP includes support for .htaccess-style INI files on
-   a   per-directory   basis.  These  files  are  processed  only  by  the
-   CGI/FastCGI  SAPI.  This  functionality  obsoletes  the  PECL htscanner
-   extension.  If  you  are using Apache, use .htaccess files for the same
-   effect.
-
-   In  addition  to the main php.ini file, PHP scans for INI files in each
-   directory,  starting  with the directory of the requested PHP file, and
-   working   its   way  up  to  the  current  document  root  (as  set  in
-   $_SERVER['DOCUMENT_ROOT']).  In  case  the  PHP  file  is  outside  the
-   document root, only its directory is scanned.
-
-   Only  INI  settings with the modes PHP_INI_PERDIR and PHP_INI_USER will
-   be recognized in .user.ini-style INI files.
-
-   Two   new  INI  directives,  user_ini.filename  and  user_ini.cache_ttl
-   control the use of user INI files.
-
-   user_ini.filename  sets  the  name  of  the  file PHP looks for in each
-   directory;  if  set  to  an  empty string, PHP doesn't scan at all. The
-   default is .user.ini.
-
-   user_ini.cache_ttl  controls  how often user INI files are re-read. The
-   default is 300 seconds (5 minutes).
-     __________________________________________________________________
-     __________________________________________________________________
-
-Where a configuration setting may be set
-
-   These  modes determine when and where a PHP directive may or may not be
-   set, and each directive within the manual refers to one of these modes.
-   For  example,  some  settings  may  be  set  within  a PHP script using
-   ini_set(), whereas others may require php.ini or httpd.conf.
-
-   For  example,  the output_buffering setting is PHP_INI_PERDIR therefore
-   it  may  not  be  set  using  ini_set().  However,  the  display_errors
-   directive  is  PHP_INI_ALL  therefore it may be set anywhere, including
-   with ini_set().
-
-   CAPTION: Definition of PHP_INI_* modes
-
-   Mode Meaning
-   PHP_INI_USER Entry can be set in user scripts (like with ini_set()) or
-   in the Windows registry. Since PHP 5.3, entry can be set in .user.ini
-   PHP_INI_PERDIR  Entry  can  be set in php.ini, .htaccess, httpd.conf or
-   .user.ini (since PHP 5.3)
-   PHP_INI_SYSTEM Entry can be set in php.ini or httpd.conf
-   PHP_INI_ALL Entry can be set anywhere
-     __________________________________________________________________
-     __________________________________________________________________
-
-How to change configuration settings
-
-Running PHP as an Apache module
-
-   When   using  PHP  as  an  Apache  module,  you  can  also  change  the
-   configuration  settings  using directives in Apache configuration files
-   (e.g.  httpd.conf)  and  .htaccess  files. You will need "AllowOverride
-   Options" or "AllowOverride All" privileges to do so.
-
-   There  are  several  Apache directives that allow you to change the PHP
-   configuration from within the Apache configuration files. For a listing
-   of which directives are PHP_INI_ALL, PHP_INI_PERDIR, or PHP_INI_SYSTEM,
-   have a look at the List of php.ini directives appendix.
-
-   php_value name value
-          Sets the value of the specified directive. Can be used only with
-          PHP_INI_ALL  and  PHP_INI_PERDIR  type  directives.  To  clear a
-          previously set value use none as the value.
-
-     Note:  Don't  use  php_value  to  set  boolean values. php_flag (see
-     below) should be used instead.
-
-   php_flag name on|off
-          Used  to set a boolean configuration directive. Can be used only
-          with PHP_INI_ALL and PHP_INI_PERDIR type directives.
-
-   php_admin_value name value
-          Sets  the value of the specified directive. This can not be used
-          in  .htaccess files. Any directive type set with php_admin_value
-          can  not  be  overridden  by  .htaccess or ini_set(). To clear a
-          previously set value use none as the value.
-
-   php_admin_flag name on|off
-          Used  to  set a boolean configuration directive. This can not be
-          used   in   .htaccess   files.   Any  directive  type  set  with
-          php_admin_flag can not be overridden by .htaccess or ini_set().
-
-   Example #1 Apache configuration example
-<IfModule mod_php7.c>
-  php_value include_path ".:/usr/local/lib/php"
-  php_admin_flag engine on
-</IfModule>
-<IfModule mod_php4.c>
-  php_value include_path ".:/usr/local/lib/php"
-  php_admin_flag engine on
-</IfModule>
-
-   Caution
-
-   PHP  constants  do not exist outside of PHP. For example, in httpd.conf
-   you  can  not  use  PHP  constants such as E_ALL or E_NOTICE to set the
-   error_reporting  directive  as  they  will  have  no  meaning  and will
-   evaluate  to  0.  Use  the  associated  bitmask  values  instead. These
-   constants can be used in php.ini
-
-Changing PHP configuration via the Windows registry
-
-   When  running  PHP on Windows, the configuration values can be modified
-   on  a per-directory basis using the Windows registry. The configuration
-   values  are  stored in the registry key HKLM\SOFTWARE\PHP\Per Directory
-   Values,  in  the sub-keys corresponding to the path names. For example,
-   configuration  values  for  the  directory  c:\inetpub\wwwroot would be
-   stored      in      the     key     HKLM\SOFTWARE\PHP\Per     Directory
-   Values\c\inetpub\wwwroot.  The  settings  for  the  directory  would be
-   active  for  any script running from this directory or any subdirectory
-   of  it.  The  values  under  the  key  should  have the name of the PHP
-   configuration  directive  and  the  string  value. PHP constants in the
-   values are not parsed. However, only configuration values changeable in
-   PHP_INI_USER can be set this way, PHP_INI_PERDIR values can not.
-
-Other interfaces to PHP
-
-   Regardless of how you run PHP, you can change certain values at runtime
-   of  your  scripts  through  ini_set().  See  the  documentation  on the
-   ini_set() page for more information.
-
-   If  you  are interested in a complete list of configuration settings on
-   your  system  with  their current values, you can execute the phpinfo()
-   function, and review the resulting page. You can also access the values
-   of  individual  configuration  directives at runtime using ini_get() or
-   get_cfg_var().
-     __________________________________________________________________
-     __________________________________________________________________
-     __________________________________________________________________
-
-Installation
-
-   This  section  holds common questions about the way to install PHP. PHP
-   is available for almost any OS (except maybe for MacOS before OSX), and
-   almost any web server.
-
-   To install PHP, follow the instructions in Installing PHP.
-    1. Why  shouldn't  I  use  Apache2 with a threaded MPM in a production
-       environment?
-    2. Unix/Windows: Where should my php.ini file be located?
-    3. Unix:  I installed PHP, but every time I load a document, I get the
-       message 'Document Contains No Data'! What's going on here?
-    4. Unix:  I  installed PHP using RPMS, but Apache isn't processing the
-       PHP pages! What's going on here?
-    5. Unix:  I  patched  Apache  with the FrontPage extensions patch, and
-       suddenly  PHP  stopped working. Is PHP incompatible with the Apache
-       FrontPage extensions?
-    6. Unix/Windows:  I have installed PHP, but when I try to access a PHP
-       script file via my browser, I get a blank screen.
-    7. Unix/Windows:  I  have  installed PHP, but when try to access a PHP
-       script file via my browser, I get a server 500 error.
-    8. Some  operating  systems:  I have installed PHP without errors, but
-       when  I  try  to  start  Apache  I  get  undefined  symbol  errors:
-       [mybox:user   /src/php7]   root#  apachectl  configtest  apachectl:
-       /usr/local/apache/bin/httpd     Undefined     symbols:    _compress
-       _uncompress
-    9. Windows:  I  have  installed  PHP,  but  when I try to access a PHP
-       script  file  via  my  browser,  I  get  the  error: cgi error: The
-       specified  CGI  application  misbehaved by not returning a complete
-       set of HTTP headers. The headers it did return are:
-   10. Windows:  I've  followed  all the instructions, but still can't get
-       PHP and IIS to work together!
-   11. When  running  PHP as CGI with IIS, OmniHTTPD or Xitami, I get
-       the  following  error:  Security  Alert! PHP CGI cannot be accessed
-       directly..
-   12. How  do I know if my php.ini is being found and read? It seems like
-       it isn't as my changes aren't being implemented.
-   13. How do I add my PHP directory to the PATH on Windows?
-   14. How do I make the php.ini file available to PHP on windows?
-   15. Is  it  possible  to  use  Apache  content  negotiation (MultiViews
-       option) with PHP?
-   16. Is PHP limited to process GET and POST request methods only?
-
-   Why shouldn't I use Apache2 with a threaded MPM in a production
-          environment?
-          PHP  is glue. It is the glue used to build cool web applications
-          by sticking dozens of 3rd-party libraries together and making it
-          all  appear as one coherent entity through an intuitive and easy
-          to  learn  language  interface. The flexibility and power of PHP
-          relies  on  the  stability  and  robustness  of  the  underlying
-          platform.  It  needs  a  working  OS,  a  working web server and
-          working  3rd-party libraries to glue together. When any of these
-          stop  working  PHP  needs  ways to identify the problems and fix
-          them  quickly.  When  you  make  the  underlying  framework more
-          complex  by  not  having  completely separate execution threads,
-          completely  separate  memory  segments  and a strong sandbox for
-          each  request to play in, further weaknesses are introduced into
-          PHP's system.
-
-          If   you  want  to  use  a  threaded  MPM,  look  at  a  FastCGI
-          configuration where PHP is running in its own memory space.
-
-   Unix/Windows: Where should my php.ini file be located?
-          By  default  on  Unix  it  should  be in /usr/local/lib which is
-          <install-path>/lib.  Most  people  will  want  to change this at
-          compile-time  with  the --with-config-file-path flag. You would,
-          for example, set it with something like:
-
---with-config-file-path=/etc
-
-          And   then   you   would   copy   php.ini-development  from  the
-          distribution  to  /etc/php.ini  and  edit  it  to make any local
-          changes you want.
-
---with-config-file-scan-dir=PATH
-
-          On  Windows the default path for the php.ini file is the Windows
-          directory.  If  you're  using  the  Apache webserver, php.ini is
-          first searched in the Apaches install directory, e.g. c:\program
-          files\apache  group\apache.  This  way  you  can  have different
-          php.ini  files  for  different  versions  of  Apache on the same
-          machine.
-
-          See also the chapter about the configuration file.
-
-   Unix: I installed PHP, but every time I load a document, I get the
-          message 'Document Contains No Data'! What's going on here?
-          This  probably means that PHP is having some sort of problem and
-          is core-dumping. Look in your server error log to see if this is
-          the  case,  and  then  try to reproduce the problem with a small
-          test case. If you know how to use 'gdb', it is very helpful when
-          you  can  provide  a  backtrace with your bug report to help the
-          developers  pinpoint  the  problem.  If  you are using PHP as an
-          Apache module try something like:
-
-          + Stop your httpd processes
-          + gdb httpd
-          + Stop your httpd processes
-          + > run -X -f /path/to/httpd.conf
-          + Then fetch the URL causing the problem with your browser
-          + > run -X -f /path/to/httpd.conf
-          + If  you are getting a core dump, gdb should inform you of this
-            now
-          + type: bt
-          + You  should  include  your  backtrace in your bug report. This
-            should be submitted to » http://bugs.php.net/
-
-          If   your   script   uses   the   regular  expression  functions
-          (preg_match()  and  friends),  you  should  make  sure  that you
-          compiled  PHP  and  Apache  with  the  same  regular  expression
-          package.  This  should  happen automatically with PHP and Apache
-          1.3.x
-
-   Unix: I installed PHP using RPMS, but Apache isn't processing the PHP
-          pages! What's going on here?
-          Assuming  you  installed  both Apache and PHP from RPM packages,
-          you  need to uncomment or add some or all of the following lines
-          in your httpd.conf file:
-
-# Extra Modules
-AddModule mod_php.c
-AddModule mod_perl.c
-
-# Extra Modules
-LoadModule php_module         modules/mod_php.so
-LoadModule php7_module        modules/libphp7.so
-LoadModule perl_module        modules/libperl.so
-
-          And add:
-
-AddType application/x-httpd-php .php
-
-          ...  to  the  global  properties,  or  to  the properties of the
-          VirtualDomain you want to have PHP support added to.
-
-   Unix: I patched Apache with the FrontPage extensions patch, and
-          suddenly PHP stopped working. Is PHP incompatible with the
-          Apache FrontPage extensions?
-          No, PHP works fine with the FrontPage extensions. The problem is
-          that  the  FrontPage  patch  modifies several Apache structures,
-          that  PHP relies on. Recompiling PHP (using 'make clean ; make')
-          after the FP patch is applied would solve the problem.
-
-   Unix/Windows: I have installed PHP, but when I try to access a PHP
-          script file via my browser, I get a blank screen.
-          Do a 'view source' in the web browser and you will probably find
-          that  you can see the source code of your PHP script. This means
-          that  the  web  server  did  not  send  the  script  to  PHP for
-          interpretation. Something is wrong with the server configuration
-          -   double  check  the  server  configuration  against  the  PHP
-          installation instructions.
-
-   Unix/Windows: I have installed PHP, but when try to access a PHP script
-          file via my browser, I get a server 500 error.
-          Something went wrong when the server tried to run PHP. To get to
-          see  a  sensible error message, from the command line, change to
-          the directory containing the PHP executable (php.exe on Windows)
-          and run php -i. If PHP has any problems running, then a suitable
-          error message will be displayed which will give you a clue as to
-          what  needs  to  be  done next. If you get a screen full of HTML
-          codes  (the  output  of  the  phpinfo()  function)  then  PHP is
-          working,  and  your  problem  may  be  related  to  your  server
-          configuration which you should double check.
-
-   Some operating systems: I have installed PHP without errors, but when I
-          try to start Apache I get undefined symbol errors:
-
-[mybox:user /src/php7] root# apachectl configtest
- apachectl: /usr/local/apache/bin/httpd Undefined symbols:
-  _compress
-  _uncompress
-
-          This  has  actually  nothing  to do with PHP, but with the MySQL
-          client libraries. Some need --with-zlib , others do not. This is
-          also covered in the MySQL FAQ.
-
-   Windows: I have installed PHP, but when I try to access a PHP script
-          file via my browser, I get the error:
-
-cgi error:
- The specified CGI application misbehaved by not
- returning a complete set of HTTP headers.
- The headers it did return are:
-
-          This  error  message means that PHP failed to output anything at
-          all.  To  get  to see a sensible error message, from the command
-          line,  change  to  the  directory  containing the PHP executable
-          (php.exe  on  Windows)  and  run php -i. If PHP has any problems
-          running,  then  a suitable error message will be displayed which
-          will  give  you  a clue as to what needs to be done next. If you
-          get  a  screen  full  of HTML codes (the output of the phpinfo()
-          function) then PHP is working.
-
-          Once  PHP  is  working  at  the  command line, try accessing the
-          script via the browser again. If it still fails then it could be
-          one of the following:
-
-          + File  permissions  on  your  PHP  script, php.exe, php7ts.dll,
-            php.ini  or any PHP extensions you are trying to load are such
-            that  the  anonymous  internet  user ISUR_<machinename> cannot
-            access them.
-          + The  script  file  does not exist (or possibly isn't where you
-            think  it  is  relative to your web root directory). Note that
-            for  IIS  you  can  trap this error by ticking the 'check file
-            exists'  box  when  setting  up  the  script  mappings  in the
-            Internet  Services  Manager.  If  a script file does not exist
-            then the server will return a 404 error instead. There is also
-            the  additional  benefit  that  IIS will do any authentication
-            required  for  you  based  on the NTLanMan permissions on your
-            script file.
-
-   Windows: I've followed all the instructions, but still can't get PHP
-          and IIS to work together!
-          Make  sure any user who needs to run a PHP script has the rights
-          to run php.exe! IIS uses an anonymous user which is added at the
-          time  IIS is installed. This user needs rights to php.exe. Also,
-          any authenticated user will also need rights to execute php.exe.
-          And  for  IIS4  you need to tell it that PHP is a script engine.
-          Also, you will want to read this faq.
-
-   When running PHP as CGI with IIS, OmniHTTPD or Xitami, I get the
-          following error: Security Alert! PHP CGI cannot be accessed
-          directly..
-          You  must set the cgi.force_redirect directive to 0. It defaults
-          to  1  so  be sure the directive isn't commented out (with a ;).
-          Like all directives, this is set in php.ini
-
-          Because  the  default  is 1, it's critical that you're 100% sure
-          that  the  correct php.ini file is being read. Read this faq for
-          details.
-
-   How do I know if my php.ini is being found and read? It seems like it
-          isn't as my changes aren't being implemented.
-          To  be  sure  your  php.ini is being read by PHP, make a call to
-          phpinfo().  Near  the  top,  there  will  be  a  listing  called
-          Configuration  File  (php.ini).  This will tell you where PHP is
-          looking  for php.ini and whether or not it's being read. If just
-          a  directory  PATH  exists,  then  it's  not being read, and you
-          should  put  your  php.ini  in  that  directory.  If  php.ini is
-          included within the PATH, it is being read.
-
-          If  php.ini  is  being  read and you're running PHP as a module,
-          then  be sure to restart your web server after making changes to
-          php.ini
-
-          See also php_ini_loaded_file().
-
-   How do I add my PHP directory to the PATH on Windows?
-          On Windows NT+ and Windows Server 2000+:
-
-          + Go  to  Control  Panel  and  open  the  System  icon (Start ->
-            Settings  -> Control Panel -> System, or just Start -> Control
-            Panel -> System for Windows XP/2003+)
-          + Go to the Advanced tab
-          + Click on the 'Environment Variables' button
-          + Look into the 'System Variables' pane
-          + Find the Path entry (you may need to scroll to find it)
-          + Double click on the Path entry
-          + Enter  your  PHP  directory  at  the end, including ';' before
-            (e.g. ;C:\php)
-          + Press OK
-
-          On Windows 98/Me you need to edit the autoexec.bat file:
-
-          + Open the Notepad (Start -> Run and enter notepad)
-          + Open the C:\autoexec.bat file
-          + Locate  the line with PATH=C:\WINDOWS;C:\WINDOWS\COMMAND;.....
-            and add: ;C:\php to the end of the line
-          + Save the file and restart your computer
-
-     Note:  Be  sure  to reboot after following the steps above to ensure
-     that the PATH changes are applied.
-
-          The  PHP  manual  used  to promote the copying of files into the
-          Windows   system  directory,  this  is  because  this  directory
-          (C:\Windows,  C:\WINNT, etc.) is by default in the systems PATH.
-          Copying  files  into the Windows system directory has long since
-          been deprecated and may cause problems.
-
-   How do I make the php.ini file available to PHP on windows?
-          There  are  several ways of doing this. If you are using Apache,
-          read  their installation specific instructions (Apache 1, Apache
-          2), otherwise you must set the PHPRC environment variable:
-
-          On Windows NT, 2000, XP and 2003:
-
-          + Go  to  Control  Panel  and  open  the  System  icon (Start ->
-            Settings  -> Control Panel -> System, or just Start -> Control
-            Panel -> System for Windows XP/2003)
-          + Go to the Advanced tab
-          + Click on the 'Environment Variables' button
-          + Look into the 'System variables' pane
-          + Click  on 'New' and enter 'PHPRC' as the variable name and the
-            directory where php.ini is located as the variable value (e.g.
-            C:\php)
-          + Press OK and restart your computer
-
-          On Windows 98/Me you need to edit the autoexec.bat file:
-
-          + Open the Notepad (Start -> Run and enter notepad)
-          + Open the C:\autoexec.bat file
-          + Add  a  new  line  to  the  end  of the file: set PHPRC=C:\php
-            (replace  C:\php with the directory where php.ini is located).
-            Please note that the path cannot contain spaces. For instance,
-            if  you  have installed PHP in C:\Program Files\PHP, you would
-            enter C:\PROGRA~1\PHP instead.
-          + Save the file and restart your computer
-
-   Is it possible to use Apache content negotiation (MultiViews option)
-          with PHP?
-          If  links  to  PHP  files  include  extension,  everything works
-          perfect.  This  FAQ is only for the case when links to PHP files
-          don't  include extension and you want to use content negotiation
-          to  choose  PHP  files from URL with no extension. In this case,
-          replace the line AddType application/x-httpd-php .php with:
-
-AddHandler php7-script php
-AddType text/html php
-
-          This  solution  doesn't  work for Apache 1 as PHP module doesn't
-          catch php-script.
-
-   Is PHP limited to process GET and POST request methods only?
-          No,  it  is possible to handle any request method, e.g. CONNECT.
-          Proper  response  status  can be sent with header(). If only GET
-          and POST methods should be handled, it can be achieved with this
-          Apache configuration:
-
-<LimitExcept GET POST>
-Deny from all
-</LimitExcept>
+   http://php.net/install
diff --git a/win32/install.txt b/win32/install.txt
deleted file mode 100644 (file)
index 6d3a85d..0000000
+++ /dev/null
@@ -1,1610 +0,0 @@
-Installing PHP
-     __________________________________________________________________
-
-   Table of Contents
-   Preface
-   1. General Installation Considerations
-   2. Installation on Windows systems
-
-        Manual Installation Steps
-        ActiveScript
-        Microsoft IIS
-        Apache 1.3.x on Microsoft Windows
-        Apache 2.0.x on Microsoft Windows
-        Sun, iPlanet and Netscape servers on Microsoft Windows
-        OmniHTTPd Server
-        Sambar Server on Microsoft Windows
-        Xitami on Microsoft Windows
-        Installation of extensions on Windows
-
-   3. Installation of PECL extensions
-
-        Introduction to PECL Installations
-        Downloading PECL extensions
-        PECL for Windows users
-        Compiling shared PECL extensions with the pecl command
-        Compiling shared PECL extensions with phpize
-        Compiling PECL extensions statically into PHP
-
-   4. Problems?
-
-        Read the FAQ
-        Other problems
-        Bug reports
-
-   5. Runtime Configuration
-
-        The configuration file
-        How to change configuration settings
-
-   6. Installation FAQ
-     __________________________________________________________________
-
-Preface
-
-   These installation instructions were generated from the HTML version of
-   the PHP Manual so formatting and linking have been altered. See the
-   online and updated version at: http://php.net/install.windows
-     __________________________________________________________________
-
-Chapter 1. General Installation Considerations
-
-   Before starting the installation, first you need to know what do you
-   want to use PHP for. There are three main fields you can use PHP, as
-   described in the What can PHP do? section:
-
-     * Websites and web applications (server-side scripting)
-     * Command line scripting
-     * Desktop (GUI) applications
-
-   For the first and most common form, you need three things: PHP itself,
-   a web server and a web browser. You probably already have a web
-   browser, and depending on your operating system setup, you may also
-   have a web server (e.g. Apache on Linux and MacOS X; IIS on Windows).
-   You may also rent webspace at a company. This way, you don't need to
-   set up anything on your own, only write your PHP scripts, upload it to
-   the server you rent, and see the results in your browser.
-   If PHP has no module  support  for your web server, ´you can always use 
-   it as a CGI or FastCGI  processor.  This  means  you set up your server 
-   to use the  CGI executable of PHP to process all  PHP file  requests on 
-   the server.
-
-   If you are also interested to use PHP for command line scripting (e.g.
-   write scripts autogenerating some images for you offline, or processing
-   text files depending on some arguments you pass to them), you always
-   need the command line executable. For more information, read the
-   section about writing command line PHP applications. In this case, you
-   need no server and no browser.
-
-   With PHP you can also write desktop GUI applications using the PHP-GTK
-   extension. This is a completely different approach than writing web
-   pages, as you do not output any HTML, but manage Windows and objects
-   within them. For more information about PHP-GTK, please visit the site
-   dedicated to this extension. PHP-GTK is not included in the official
-   PHP distribution.
-
-   From now on, this section deals with setting up PHP for web servers on
-   Unix and Windows with server module interfaces and CGI executables. You
-   will also find information on the command line executable in the
-   following sections.
-
-   PHP source code and binary distributions for Windows can be found at
-   http://www.php.net/downloads.php. We recommend you to choose a mirror
-   nearest to you for downloading the distributions.
-     __________________________________________________________________
-
-Chapter 2. Installation on Windows systems
-
-   This section applies to Windows 98/Me and Windows NT/2000/XP/2003. PHP
-   will not work on 16 bit platforms such as Windows 3.1 and sometimes we
-   refer to the supported Windows platforms as Win32. Windows 95 is no
-   longer supported as of PHP 4.3.0.
-
-   If you have Microsoft Visual Studio, you can also build PHP from the
-   original source code.
-
-   Once you have PHP installed on your Windows system, you may also want
-   to load various extensions for added functionality.
-
-   Warning
-
-   There are several all-in-one installers over the Internet, but none of
-   those are endorsed by PHP.net, as we believe that the manual
-   installation is the best choice to have your system secure and
-   optimised.
-     __________________________________________________________________
-
-Manual Installation Steps
-
-   This install guide will help you manually install and configure PHP
-   with a web server on Microsoft Windows. To get started you'll need to
-   download the zip binary distribution from the downloads page at
-   http://www.php.net/downloads.php.
-
-   Although there are many all-in-one installation kits, we recommend you
-   take the time to setup PHP yourself as this will provide you with a
-   better understanding of the system, and enables you to install PHP
-   extensions easily when needed.
-
-     Upgrading from a previous PHP version: Previous editions of the
-     manual suggest moving various ini and DLL files into your SYSTEM
-     (i.e. C:\WINDOWS) folder and while this simplifies the installation
-     procedure it makes upgrading difficult. We advise you remove all of
-     these files (like php.ini and PHP related DLLs from the Windows
-     SYSTEM folder) before moving on with a new PHP installation. Be sure
-     to backup these files as you might break the entire system. The old
-     php.ini might be useful in setting up the new PHP as well. And as
-     you'll soon learn, the preferred method for installing PHP is to
-     keep all PHP related files in one directory and have this directory
-     available to your systems PATH.
-
-     MDAC requirements: If you use Microsoft Windows 98/NT4 download the
-     latest version of the Microsoft Data Access Components (MDAC) for
-     your platform. MDAC is available at http://msdn.microsoft.com/data/.
-     This requirement exists because ODBC is built into the distributed
-     Windows binaries.
-
-   The following steps should be completed on all installations before any
-   server specific instructions are performed:
-
-   Extract the distribution file into a directory of your choice. If you
-   are installing PHP 4, extract to C:\, as the zip file expands to a
-   foldername like php-4.3.7-Win32. If you are installing PHP 7, extract
-   to C:\php as the zip file doesn't expand as in PHP 4. You may choose a
-   different location but do not have spaces in the path (like C:\Program
-   Files\PHP) as some web servers will crash if you do.
-
-   The directory structure extracted from the zip is different for PHP
-   versions 4 and 5 and look like as follows:
-
-   Example 2-2. PHP 7 package structure
-c:\php
-   |
-   +--dev
-   |  |
-   |  |-php7ts.lib
-   |
-   +--ext                 -- extension DLLs for PHP
-   |  |
-   |  |-php_bz2.dll
-   |  |
-   |  |-php_cpdf.dll
-   |  |
-   |  |-..
-   |
-   +--extras
-   |  |
-   |  +--mibs             -- support files for SNMP
-   |  |
-   |  +--openssl          -- support files for Openssl
-   |  |
-   |  +--pdf-related      -- support files for PDF
-   |  |
-   |  |-mime.magic
-   |
-   +--pear                -- initial copy of PEAR
-   |
-   |
-   |-go-pear.bat          -- PEAR setup script
-   |
-   |-fdftk.dll
-   |
-   |-..
-   |
-   |-php-cgi.exe          -- CGI executable
-   |
-   |-php-win.exe          -- executes scripts without an opened command prompt
-   |
-   |-php.exe              -- CLI executable - ONLY for command line scripting
-   |
-   |-..
-   |
-   |-php.ini-development  -- development php.ini settings
-   |
-   |-php.ini-production   -- recommended php.ini settings for production
-   |
-   |-php5activescript.dll
-   |
-   |-php7apache2_4.dll
-   |
-   |-..
-   |
-   |-php5ts.dll           -- core PHP DLL
-   |
-   |-...
-
-   Notice the differences and similarities. Both PHP 4 and PHP 5 have a
-   CGI executable, a CLI executable, and server modules, but they are
-   located in different folders and/or have different names. While PHP 4
-   packages have the server modules in the sapi folder, PHP 5
-   distributions have no such directory and instead they're in the PHP
-   folder root. The supporting DLLs for the PHP 5 extensions are also not
-   in a separate directory.
-
-     Note: In PHP 4, you should move all files located in the dll and
-     sapi folders to the main folder (e.g. C:\php).
-
-   Here is a list of server modules shipped with PHP 5:
-
-     * php7apache2_4.dll - Apache 2.4.x module.
-
-   Server modules provide significantly better performance and additional
-   functionality compared to the CGI binary. The FastCGI is significantly
-   more stable and can be a faster module with IIS.
-   The CLI version is designed to let you use PHP for command line 
-   scripting. More information about CLI is available in the chapter 
-   about using PHP from the command line.
-
-   Warning
-
-   The SAPI modules have been significantly improved as of the 4.1
-   release, however, in older systems you may encounter server errors or
-   other server modules failing, such as ASP.
-
-   The CGI and CLI binaries, and the web server modules all require the
-   php7ts.dll file to be available to them. You have to make
-   sure that this file can be found by your PHP installation. The search
-   order for this DLL is as follows:
-
-     * The same directory from where php.exe is called, or in case you use
-       a SAPI module, the web server's directory (e.g. C:\Program
-       Files\Apache Group\Apache2\bin).
-     * Any directory in your Windows PATH environment variable.
-
-   To make php7ts.dll available you have three options: copy
-   the file to the Windows system directory, copy the file to the web
-   server's directory, or add your PHP directory, C:\php to the PATH. For
-   better maintenance, we advise you to follow the last option, add C:\php
-   to the PATH, because it will be simpler to upgrade PHP in the future.
-   Read more about how to add your PHP directory to PATH in the
-   corresponding FAQ entry (and then don't forget to restart the computer
-   - logoff isn't enough).
-
-   The next step is to set up a valid configuration file for PHP, php.ini.
-   There are two ini files distributed in the zip file, php.ini-development
-   and php.ini-production. We advise you to use php.ini-production, 
-   because we optimized the default settings in this file for performance, 
-   and security. Read this well documented file carefully because it has
-   changes from php.ini-production that will drastically affect your setup.
-   Some examples are display_errors being off and magic_quotes_gpc being off.
-   In addition to reading these, study the ini settings and set every
-   element manually yourself. If you would like to achieve the best
-   security, then this is the way for you, although PHP works fine with
-   these default ini files. Copy your chosen ini-file to a directory that
-   PHP is able to find and rename it to php.ini. PHP searches for php.ini
-   in the locations described in the Section called The configuration file
-   in Chapter 5 section.
-
-   If you are running Apache 2, the simpler option is to use the PHPIniDir
-   directive (read the installation on Apache 2 page), otherwise your best
-   option is to set the PHPRC environment variable. This process is
-   explained in the following FAQ entry.
-
-     Note: If you're using NTFS on Windows NT, 2000, XP or 2003, make
-     sure that the user running the web server has read permissions to
-     your php.ini (e.g. make it readable by Everyone).
-
-   The following steps are optional:
-
-     * Edit your new php.ini file. If you plan to use OmniHTTPd, do not
-       follow the next step. Set the doc_root to point to your web servers
-       document_root. For example:
-
-doc_root = c:\inetpub\wwwroot // for IIS
-
-doc_root = c:\apache\htdocs // for Apache
-
-     * Choose the extensions you would like to load when PHP starts. See
-       the section about Windows extensions, about how to set up one, and
-       what is already built in. Note that on a new installation it is
-       advisable to first get PHP working and tested without any
-       extensions before enabling them in php.ini.
-
-   PHP is now setup on your system. The next step is to choose a web
-   server, and enable it to run PHP. Choose a web server from the table of
-   contents.
-     __________________________________________________________________
-
-ActiveScript
-
-   This section contains notes specific to the ActiveScript installation.
-
-   ActiveScript is a Windows only SAPI that enables you to use PHP script
-   in any ActiveScript compliant host, like Windows Script Host,
-   ASP/ASP.NET, Windows Script Components or Microsoft Scriptlet control.
-
-   As of PHP 5.0.1, ActiveScript has been moved to the PECL repository.
-   The DLL for this PECL extension may be downloaded from either the PHP
-   Downloads page or from http://pecl4win.php.net/
-
-     Note: You should read the manual installation steps first!
-
-   After installing PHP, you should download the ActiveScript DLL
-   (php7activescript.dll) and place it in the main PHP folder (e.g.
-   C:\php).
-
-   After having all the files needed, you must register the DLL on your
-   system. To achieve this, open a Command Prompt window (located in the
-   Start Menu). Then go to your PHP directory by typing something like cd
-   C:\php. To register the DLL just type regsvr32 php7activescript.dll.
-
-   To test if ActiveScript is working, create a new file, named test.wsf
-   (the extension is very important) and type:
-<job id="test">
-
- <script language="PHPScript">
-  $WScript->Echo("Hello World!");
- </script>
-
-</job>
-
-   Save and double-click on the file. If you receive a little window
-   saying "Hello World!" you're done.
-
-     Note: In PHP 4, the engine was named 'ActivePHP', so if you are
-     using PHP 4, you should replace 'PHPScript' with 'ActivePHP' in the
-     above example.
-
-     Note: ActiveScript doesn't use the default php.ini file. Instead, it
-     will look only in the same directory as the .exe that caused it to
-     load. You should create php-activescript.ini and place it in that
-     folder, if you wish to load extensions, etc.
-     __________________________________________________________________
-
-Microsoft IIS
-
-   This section contains notes and hints specific to IIS (Microsoft
-   Internet Information Server).
-
-   Warning
-
-   By using the CGI setup, your server is open to several possible
-   attacks. Please read our CGI security section to learn how to defend
-   yourself from those attacks.
-     __________________________________________________________________
-
-General considerations for all installations of PHP with IIS
-
-     * First, read the Manual Installation Instructions. Do not skip this
-       step as it provides crucial information for installing PHP on
-       Windows.
-     * CGI users must set the cgi.force_redirect PHP directive to 0 inside
-       php.ini. Read the faq on cgi.force_redirect for important details.
-       Also, CGI users may want to set the cgi.redirect_status_env
-       directive. When using directives, be sure these directives aren't
-       commented out inside php.ini.
-     * The PHP 4 CGI is named php.exe while in PHP 7 it's php-cgi.exe. In
-       PHP 7, php.exe is the CLI, and not the CGI.
-     * Modify the Windows PATH environment variable to include the PHP
-       directory. This way the PHP DLL files and PHP executables can all
-       remain in the PHP directory without cluttering up the Windows
-       system directory. For more details, see the FAQ on Setting the
-       PATH.
-     * The IIS user (usually IUSR_MACHINENAME) needs permission to read
-       various files and directories, such as php.ini, docroot, and the
-       session tmp directory.
-     * Be sure the extension_dir and doc_root PHP directives are
-       appropriately set in php.ini. These directives depend on the system
-       that PHP is being installed on. In PHP 4, the extension_dir is
-       extensions while with PHP 7 it's ext. So, an example PHP 7
-       extensions_dir value is "c:\php\ext" and an example IIS doc_root
-       value is "c:\Inetpub\wwwroot".
-     * PHP extension DLL files, such as php_mysql.dll and php_curl.dll,
-       are found in the zip package of the PHP download. In PHP 7, many
-       extensions are part of PECL and can be downloaded in the
-       "Collection of PECL modules" package. Files such as php_zip.dll and
-       php_ssh2.dll. Download PHP files here.
-     * When defining the executable, the 'check that file exists' box may
-       also be checked. For a small performance penalty, the IIS
-       will check that the script file exists and sort out authentication
-       before firing up PHP. This means that the web server will provide
-       sensible 404 style error messages instead of CGI errors complaining
-       that PHP did not output any data.
-     __________________________________________________________________
-
-Windows and IIS
-
-See http://www.php.net/install.windows
-     __________________________________________________________________
-
-Apache 1.3.x on Microsoft Windows
-
-   This section contains notes and hints specific to Apache 1.3.x installs
-   of PHP on Microsoft Windows systems. There are also instructions and
-   notes for Apache 2 on a separate page.
-
-     Note: Please read the manual installation steps first!
-
-   There are two ways to set up PHP to work with Apache 1.3.x on Windows.
-   One is to use the CGI binary (php.exe for PHP 4 and php-cgi.exe for PHP
-   5), the other is to use the Apache Module DLL. In either case you need
-   to edit your httpd.conf to configure Apache to work with PHP, and then
-   restart the server.
-
-   It is worth noting here that now the SAPI module has been made more
-   stable under Windows, we recommend it's use above the CGI binary, since
-   it is more transparent and secure.
-
-   Although there can be a few variations of configuring PHP under Apache,
-   these are simple enough to be used by the newcomer. Please consult the
-   Apache Documentation for further configuration directives.
-
-   After changing the configuration file, remember to restart the server,
-   for example, NET STOP APACHE followed by NET START APACHE, if you run
-   Apache as a Windows Service, or use your regular shortcuts.
-
-     Note: Remember that when adding path values in the Apache
-     configuration files on Windows, all backslashes such as
-     c:\directory\file.ext must be converted to forward slashes, as
-     c:/directory/file.ext. A trailing slash may also be necessary for
-     directories.
-     __________________________________________________________________
-
-Installing as an Apache module
-
-   You should add the following lines to your Apache httpd.conf file:
-
-   Example 2-3. PHP as an Apache 1.3.x module
-
-   This assumes PHP is installed to c:\php. Adjust the path if this is not
-   the case.
-
-   For PHP 7:
-# Add to the end of the LoadModule section
-LoadModule php7_module "C:/php/php7apache.dll"
-
-# Add to the end of the AddModule section
-AddModule mod_php7.c
-
-   For both:
-# Add this line inside the <IfModule mod_mime.c> conditional brace
-AddType application/x-httpd-php .php
-
-# For syntax highlighted .phps files, also add
-AddType application/x-httpd-php-source .phps
-     __________________________________________________________________
-
-Installing as a CGI binary
-
-   If you unzipped the PHP package to C:\php\ as described in the Manual
-   Installation Steps section, you need to insert these lines to your
-   Apache configuration file to set up the CGI binary:
-
-   Example 2-4. PHP and Apache 1.3.x as CGI
-ScriptAlias /php/ "c:/php/"
-AddType application/x-httpd-php .php
-
-# For PHP 4
-Action application/x-httpd-php "/php/php.exe"
-
-# For PHP 7
-Action application/x-httpd-php "/php/php-cgi.exe"
-
-# specify the directory where php.ini is
-SetEnv PHPRC C:/php
-
-   Note that the second line in the list above can be found in the actual
-   versions of httpd.conf, but it is commented out. Remember also to
-   substitute the c:/php/ for your actual path to PHP.
-
-   Warning
-
-   By using the CGI setup, your server is open to several possible
-   attacks. Please read our CGI security section to learn how to defend
-   yourself from those attacks.
-
-   If you would like to present PHP source files syntax highlighted, there
-   is no such convenient option as with the module version of PHP. If you
-   chose to configure Apache to use PHP as a CGI binary, you will need to
-   use the highlight_file() function. To do this simply create a PHP
-   script file and add this code: <?php
-   highlight_file('some_php_script.php'); ?>.
-     __________________________________________________________________
-
-Apache 2.0.x on Microsoft Windows
-
-   This section contains notes and hints specific to Apache 2.0.x installs
-   of PHP on Microsoft Windows systems. We also have instructions and
-   notes for Apache 1.3.x users on a separate page.
-
-     Note: You should read the manual installation steps first!
-
-     Apache 2.2.x Support: Users of Apache 2.2.x may use the
-     documentation below except the appropriate DLL file is named
-     php7apache2_2.dll and it only exists as of PHP 7.2.0. See also
-     http://snaps.php.net/
-
-   Warning
-
-   We do not recommend using a threaded MPM in production with Apache2.
-   Use the prefork MPM instead, or use Apache1. For information on why,
-   read the related FAQ entry on using Apache2 with a threaded MPM
-
-   You are highly encouraged to take a look at the Apache Documentation to
-   get a basic understanding of the Apache 2.0.x Server. Also consider to
-   read the Windows specific notes for Apache 2.0.x before reading on
-   here.
-
-     PHP and Apache 2.0.x compatibility notes: The following versions of
-     PHP are known to work with the most recent version of Apache 2.0.x:
-
-     * PHP 4.3.0 or later available at http://www.php.net/downloads.php.
-     * the latest stable development version. Get the source code
-       http://snaps.php.net/php7-latest.tar.gz or download binaries for
-       Windows http://snaps.php.net/win32/php7-win32-latest.zip.
-     * a prerelease version downloadable from http://qa.php.net/.
-     * you have always the option to obtain PHP through SVN.
-
-     These versions of PHP are compatible to Apache 2.0.40 and later.
-
-     Apache 2.0 SAPI-support started with PHP 4.2.0. PHP 4.2.3 works with
-     Apache 2.0.39, don't use any other version of Apache with PHP 4.2.3.
-     However, the recommended setup is to use PHP 4.3.0 or later with the
-     most recent version of Apache2.
-
-     All mentioned versions of PHP will work still with Apache 1.3.x.
-
-   Warning
-
-   Apache 2.0.x is designed to run on Windows NT 4.0, Windows 2000 or
-   Windows XP. At this time, support for Windows 9x is incomplete. Apache
-   2.0.x is not expected to work on those platforms at this time.
-
-   Download the most recent version of Apache 2.0.x and a fitting PHP
-   version. Follow the Manual Installation Steps and come back to go on
-   with the integration of PHP and Apache.
-
-   There are two ways to set up PHP to work with Apache 2.0.x on Windows.
-   One is to use the CGI binary the other is to use the Apache module DLL.
-   In either case you need to edit your httpd.conf to configure Apache to
-   work with PHP and then restart the server.
-
-     Note: Remember that when adding path values in the Apache
-     configuration files on Windows, all backslashes such as
-     c:\directory\file.ext must be converted to forward slashes, as
-     c:/directory/file.ext. A trailing slash may also be necessary for
-     directories.
-     __________________________________________________________________
-
-Installing as a CGI binary
-
-   You need to insert these three lines to your Apache httpd.conf
-   configuration file to set up the CGI binary:
-
-   Example 2-5. PHP and Apache 2.0 as CGI
-ScriptAlias /php/ "c:/php/"
-AddType application/x-httpd-php .php
-
-# For PHP 4
-Action application/x-httpd-php "/php/php.exe"
-
-# For PHP 7
-Action application/x-httpd-php "/php/php-cgi.exe"
-
-   Warning
-
-   By using the CGI setup, your server is open to several possible
-   attacks. Please read our CGI security section to learn how to defend
-   yourself from those attacks.
-     __________________________________________________________________
-
-Installing as an Apache module
-
-   You need to insert these two lines to your Apache httpd.conf
-   configuration file to set up the PHP module for Apache 2.0:
-
-   Example 2-6. PHP and Apache 2.0 as Module
-
-# For PHP 7 do something like this:
-LoadModule php7_module "c:/php/php7apache2.dll"
-AddType application/x-httpd-php .php
-
-# configure the path to php.ini
-PHPIniDir "C:/php"
-
-     Note: Remember to substitute your actual path to PHP for the c:/php/
-     in the above examples. Take care to use either 
-     php5apache2.dll in your LoadModule directive and not php5apache.dll 
-     as the latter ones are designed to run with Apache 1.3.x.
-
-     Note: If you want to use content negotiation, read related FAQ.
-
-   Warning
-
-   Don't mix up your installation with DLL files from different PHP
-   versions. You have the only choice to use the DLL's and extensions that
-   ship with your downloaded PHP version.
-     __________________________________________________________________
-
-CGI setup on Sun, iPlanet and Netscape servers
-
-   To install PHP as a CGI handler, do the following:
-
-     * Copy php7ts.dll to your systemroot (the directory where you
-       installed Windows)
-     * Make a file association from the command line. Type the following
-       two lines:
-
-assoc .php=PHPScript
-ftype PHPScript=c:\php\php.exe %1 %*
-
-     * In the Netscape Enterprise Administration Server create a dummy
-       shellcgi directory and remove it just after (this step creates 5
-       important lines in obj.conf and allow the web server to handle
-       shellcgi scripts).
-     * In the Netscape Enterprise Administration Server create a new mime
-       type (Category: type, Content-Type: magnus-internal/shellcgi, File
-       Suffix:php).
-     * Do it for each web server instance you want PHP to run
-
-   More details about setting up PHP as a CGI executable can be found
-   here: http://benoit.noss.free.fr/php/install-php.html
-     __________________________________________________________________
-
-CGI environment and recommended modifications in php.ini
-
-   Important when writing PHP scripts is the fact that Sun JSWS/Sun ONE
-   WS/iPlanet/Netscape is a multithreaded web server. Because of that all
-   requests are running in the same process space (the space of the web
-   server itself) and this space has only one environment. If you want to
-   get CGI variables like PATH_INFO, HTTP_HOST etc. it is not the correct
-   way to try this in the old PHP 3.x way with getenv() or a similar way
-   (register globals to environment, $_ENV). You would only get the
-   environment of the running web server without any valid CGI variables!
-
-     Note: Why are there (invalid) CGI variables in the environment?
-
-     Answer: This is because you started the web server process from the
-     admin server which runs the startup script of the web server, you
-     wanted to start, as a CGI script (a CGI script inside of the admin
-     server!). This is why the environment of the started web server has
-     some CGI environment variables in it. You can test this by starting
-     the web server not from the administration server. Use the command
-     line as root user and start it manually - you will see there are no
-     CGI-like environment variables.
-     __________________________________________________________________
-
-Special use for error pages or self-made directory listings (PHP >= 4.3.3)
-
-   You can use PHP to generate the error pages for "404 Not Found" or
-   similar. Add the following line to the object in obj.conf for every
-   error page you want to overwrite:
-Error fn="php7_execute" code=XXX script="/path/to/script.php" [inikey=value inik
-ey=value...]
-
-   where XXX is the HTTP error code. Please delete any other Error
-   directives which could interfere with yours. If you want to place a
-   page for all errors that could exist, leave the code parameter out.
-   Your script can get the HTTP status code with $_SERVER['ERROR_TYPE'].
-
-   Another possibility is to generate self-made directory listings. Just
-   create a PHP script which displays a directory listing and replace the
-   corresponding default Service line for type="magnus-internal/directory"
-   in obj.conf with the following:
-Service fn="php7_execute" type="magnus-internal/directory" script="/path/to/scri
-pt.php" [inikey=value inikey=value...]
-
-   For both error and directory listing pages the original URI and
-   translated URI are in the variables $_SERVER['PATH_INFO'] and
-   $_SERVER['PATH_TRANSLATED'].
-     __________________________________________________________________
-
-OmniHTTPd Server
-
-   This section contains notes and hints specific to OmniHTTPd on Windows.
-
-     Note: You should read the manual installation steps first!
-
-   Warning
-
-   By using the CGI setup, your server is open to several possible
-   attacks. Please read our CGI security section to learn how to defend
-   yourself from those attacks.
-
-   You need to complete the following steps to make PHP work with
-   OmniHTTPd. This is a CGI executable setup. SAPI is supported by
-   OmniHTTPd.
-
-     Important for CGI users: Read the faq on cgi.force_redirect for
-     important details. This directive needs to be set to 0.
-
-    1. Install OmniHTTPd server.
-    2. Right click on the blue OmniHTTPd icon in the system tray and
-       select Properties
-    3. Click on Web Server Global Settings
-    4. On the 'External' tab, enter: virtual = .php | actual =
-       c:\php\php.exe (use php-cgi.exe if installing PHP 7), and use the
-       Add button.
-    5. On the Mime tab, enter: virtual = wwwserver/stdcgi | actual = .php,
-       and use the Add button.
-    6. Click OK
-
-   Repeat steps 2 - 6 for each extension you want to associate with PHP.
-
-     __________________________________________________________________
-
-Xitami on Microsoft Windows
-
-   This section contains notes and hints specific to Xitami on Windows.
-
-     Note: You should read the manual installation steps first!
-
-   This list describes how to set up the PHP CGI binary to work with
-   Xitami on Windows.
-
-     Important for CGI users: Read the faq on cgi.force_redirect for
-     important details. This directive needs to be set to 0. If you want
-     to use $_SERVER['PHP_SELF'] you have to enable the cgi.fix_pathinfo
-     directive.
-
-   Warning
-
-   By using the CGI setup, your server is open to several possible
-   attacks. Please read our CGI security section to learn how to defend
-   yourself from those attacks.
-
-     * Make sure the web server is running, and point your browser to
-       xitamis admin console (usually http://127.0.0.1/admin), and click
-       on Configuration.
-     * Navigate to the Filters, and put the extension which PHP should
-       parse (i.e. .php) into the field File extensions (.xxx).
-     * In Filter command or script put the path and name of your PHP CGI
-       executable i.e. C:\php\php-cgi.exe.
-     * Press the 'Save' icon.
-     * Restart the server to reflect changes.
-     __________________________________________________________________
-
-Installation of extensions on Windows
-
-   After installing PHP and a web server on Windows, you will probably
-   want to install some extensions for added functionality. You can choose
-   which extensions you would like to load when PHP starts by modifying
-   your php.ini. You can also load a module dynamically in your script
-   using dl().
-
-   The DLLs for PHP extensions are prefixed with php_.
-
-   Many extensions are built into the Windows version of PHP. This means
-   additional DLL files, and the extension directive, are not used to load
-   these extensions. The Windows PHP Extensions table lists extensions
-   that require, or used to require, additional PHP DLL files. Here's a
-   list of built in extensions:
-
-   In PHP 7 (updated PHP 5.0.4), the following changes exist. Built in:
-   DOM, LibXML, Iconv, SimpleXML, SPL and SQLite. And the following are no
-   longer built in: MySQL and Overload.
-
-   The default location PHP searches for extensions is C:\php7 in PHP 7.
-   To change this setting to reflect your setup of PHP edit your php.ini
-   file:
-
-     * You will need to change the extension_dir setting to point to the
-       directory where your extensions lives, or where you have placed
-       your php_*.dll files. For example:
-
-extension_dir = C:\php\extensions
-
-     * Enable the extension(s) in php.ini you want to use by uncommenting
-       the extension=php_*.dll lines in php.ini. This is done by deleting
-       the leading ; from the extension you want to load.
-
-   Example 2-8. Enable Bzip2 extension for PHP-Windows
-// change the following line from ...
-;extension=php_bz2.dll
-
-// ... to
-extension=php_bz2.dll
-
-     * Some of the extensions need extra DLLs to work. Couple of them can
-       be found in the distribution package, in in the main folder in PHP 5, 
-       but some, for example Oracle (php_oci8.dll) require DLLs which are 
-       not bundled with the distribution package.
-     * Some of these DLLs are not bundled with the PHP distribution. See
-       each extensions documentation page for details. Also, read the
-       manual section titled Installation of PECL extensions for details
-       on PECL. An increasingly large number of PHP extensions are found
-       in PECL, and these extensions require a separate download.
-
-     Note: If you are running a server module version of PHP remember to
-     restart your web server to reflect your changes to php.ini.
-
-   The following table describes some of the extensions available and
-   required additional dlls.
-
-   Table 2-1. PHP Extensions
-   Extension Description Notes
-   php_bz2.dll bzip2 compression functions None
-   php_calendar.dll Calendar conversion functions
-   php_ctype.dll ctype family functions
-   php_curl.dll CURL, Client URL library functions Requires: libeay32.dll,
-   ssleay32.dll (bundled)
-   php_dba.dll DBA: DataBase (dbm-style) Abstraction layer functions None
-   php_exif.dll EXIF functions php_mbstring.dll. And, php_exif.dll must be
-   loaded after php_mbstring.dll in php.ini.
-   php_ftp.dll FTP functions
-   php_gd2.dll GD library image functions GD2
-   php_gettext.dll Gettext functions, requires libintl-1.dll, 
-   iconv.dll (bundled).
-   php_iconv.dll ICONV characterset conversion Requires: iconv.dll
-   php_imap.dll IMAP POP3 and NNTP functions None
-   php_interbase.dll InterBase functions Requires: gds32.dll (bundled)
-   php_ldap.dll LDAP functions requires libeay32.dll, ssleay32.dll (bundled)
-   php_mbstring.dll Multi-Byte String functions None
-   php_mysql.dll MySQL functions PHP >= 5.0.0, requires libmysql.dll
-   (bundled)
-   php_mysqli.dll MySQLi functions PHP >= 5.0.0, requires libmysql.dll
-   (libmysqli.dll in PHP <= 5.0.2) (bundled)
-   php_oci8.dll Oracle 8 functions Requires: Oracle 8.1+ client libraries
-   php_openssl.dll OpenSSL functions Requires: libeay32.dll (bundled)
-   php_oracle.dll Oracle functions Requires: Oracle 7 client libraries
-   php_pgsql.dll PostgreSQL functions None
-   php_shmop.dll Shared Memory functions None
-   php_snmp.dll SNMP get and walk functions NT only!
-   php_soap.dll SOAP functions PHP >= 5.0.0
-   php_sockets.dll Socket functions None
-   php_sodium.dll Sodium cryptography library PHP >= 7.2.0
-   php_tidy.dll Tidy functions PHP >= 5.0.0
-   php_tokenizer.dll Tokenizer functions Built in since PHP 4.3.0
-   php_xmlrpc.dll XML-RPC functions PHP >= 4.2.1 requires: iconv.dll
-   (bundled)
-   php_xslt.dll XSLT requires libxslt.dll, iconv.dll (bundled).
-   php_zip.dll Zip File functions
-   php_zlib.dll ZLib compression functions
-     __________________________________________________________________
-
-Chapter 3. Installation of PECL extensions
-
-Introduction to PECL Installations
-
-   PECL is a repository of PHP extensions that are made available to you
-   via the PEAR packaging system. This section of the manual is intended
-   to demonstrate how to obtain and install PECL extensions.
-
-   These instructions assume /your/phpsrcdir/ is the path to the PHP
-   source distribution, and that extname is the name of the PECL
-   extension. Adjust accordingly. These instructions also assume a
-   familiarity with the pear command. The information in the PEAR manual
-   for the pear command also applies to the pecl command.
-
-   To be useful, a shared extension must be built, installed, and loaded.
-   The methods described below provide you with various instructions on
-   how to build and install the extensions, but they do not automatically
-   load them. Extensions can be loaded by adding an extension directive.
-   To this php.ini file, or through the use of the dl() function.
-
-   When building PHP modules, it's important to have known-good versions
-   of the required tools (autoconf, automake, libtool, etc.) See the
-   SVN Instructions for details on the required tools, and required 
-   versions.
-     __________________________________________________________________
-
-Downloading PECL extensions
-
-   There are several options for downloading PECL extensions, such as:
-
-     * http://pecl.php.net
-       The PECL web site contains information about the different
-       extensions that are offered by the PHP Development Team. The
-       information available here includes: ChangeLog, release notes,
-       requirements and other similar details.
-     * pecl download extname
-       PECL extensions that have releases listed on the PECL web site are
-       available for download and installation using the pecl command.
-       Specific revisions may also be specified.
-     * SVN 
-       Most PECL extensions also reside in SVN. A web-based view may be
-       seen at http://svn.php.net/pecl/. To download straight from SVN,
-       the following sequence of commands may be used. 
-
-$ svn  co http://svn.php.net/repository/pecl/<extname>/trunk
-
-     * Windows downloads
-       Windows users may find compiled PECL binaries by downloading the
-       Collection of PECL modules from the PHP Downloads page, or by
-       retrieving a PECL Snapshot or an extension DLL on PECL4WIN. To
-       compile PHP under Windows, read the appropriate chapter.
-     __________________________________________________________________
-
-PECL for Windows users
-
-   As with any other PHP extension DLL, installation is as simple as
-   copying the PECL extension DLLs into the extension_dir folder and
-   loading them from php.ini. For example, add the following line to your
-   php.ini:
-
-   extension=php_extname.dll
-
-   After doing this, restart the web server.
-     __________________________________________________________________
-
-Compiling shared PECL extensions with the pecl command
-
-   PECL makes it easy to create shared PHP extensions. Using the pecl
-   command, do the following:
-
-   $ pecl install extname
-
-   This will download the source for extname, compile, and install
-   extname.so into your extension_dir. extname.so may then be loaded via
-   php.ini
-
-   By default, the pecl command will not install packages that are marked
-   with the alpha or beta state. If no stable packages are available, you
-   may install a beta package using the following command:
-
-   $ pecl install extname-beta
-
-   You may also install a specific version using this variant:
-
-   $ pecl install extname-0.1
-     __________________________________________________________________
-
-Compiling shared PECL extensions with phpize
-
-   Sometimes, using the pecl installer is not an option. This could be
-   because you're behind a firewall, or it could be because the extension
-   you want to install is not available as a PECL compatible package, such
-   as unreleased extensions from SVN. If you need to build such an
-   extension, you can use the lower-level build tools to perform the build
-   manually.
-
-   The phpize command is used to prepare the build environment for a PHP
-   extension. In the following sample, the sources for an extension are in
-   a directory named extname:
-
-$ cd extname
-$ phpize
-$ ./configure
-$ make
-# make install
-
-   A successful install will have created extname.so and put it into the
-   PHP extensions directory. You'll need to and adjust php.ini and add an
-   extension=extname.so line before you can use the extension.
-
-   If the system is missing the phpize command, and precompiled packages
-   (like RPM's) are used, be sure to also install the appropriate devel
-   version of the PHP package as they often include the phpize command
-   along with the appropriate header files to build PHP and its
-   extensions.
-
-   Execute phpize --help to display additional usage information.
-     __________________________________________________________________
-
-Compiling PECL extensions statically into PHP
-
-   You might find that you need to build a PECL extension statically into
-   your PHP binary. To do this, you'll need to place the extension source
-   under the php-src/ext/ directory and tell the PHP build system to
-   regenerate its configure script.
-
-$ cd /your/phpsrcdir/ext
-$ pecl download extname
-$ gzip -d < extname.tgz | tar -xvf -
-$ mv extname-x.x.x extname
-
-   This will result in the following directory:
-
-   /your/phpsrcdir/ext/extname
-
-   From here, force PHP to rebuild the configure script, and then build
-   PHP as normal:
-
-$ cd /your/phpsrcdir
-$ rm configure
-$ ./buildconf --force
-$ ./configure --help
-$ ./configure --with-extname --enable-someotherext --with-foobar
-$ make
-$ make install
-
-     Note: To run the 'buildconf' script you need autoconf 2.13 and
-     automake 1.4+ (newer versions of autoconf may work, but are not
-     supported).
-
-   Whether --enable-extname or --with-extname is used depends on the
-   extension. Typically an extension that does not require external
-   libraries uses --enable. To be sure, run the following after buildconf:
-
-   $ ./configure --help | grep extname
-     __________________________________________________________________
-
-Chapter 4. Problems?
-
-Read the FAQ
-
-   Some problems are more common than others. The most common ones are
-   listed in the PHP FAQ, part of this manual.
-     __________________________________________________________________
-
-Other problems
-
-   If you are still stuck, someone on the PHP installation mailing list
-   may be able to help you. You should check out the archive first, in
-   case someone already answered someone else who had the same problem as
-   you. The archives are available from the support page on
-   http://www.php.net/support.php. To subscribe to the PHP installation
-   mailing list, send an empty mail to
-   php-install-subscribe@lists.php.net. The mailing list address is
-   php-install@lists.php.net.
-
-   If you want to get help on the mailing list, please try to be precise
-   and give the necessary details about your environment (which operating
-   system, what PHP version, what web server, if you are running PHP as
-   CGI or a server module, safe mode, etc...), and preferably enough code
-   to make others able to reproduce and test your problem.
-     __________________________________________________________________
-
-Bug reports
-
-   If you think you have found a bug in PHP, please report it. The PHP
-   developers probably don't know about it, and unless you report it,
-   chances are it won't be fixed. You can report bugs using the
-   bug-tracking system at http://bugs.php.net/. Please do not send bug
-   reports in mailing list or personal letters. The bug system is also
-   suitable to submit feature requests.
-
-   Read the How to report a bug document before submitting any bug
-   reports!
-     __________________________________________________________________
-
-Chapter 5. Runtime Configuration
-
-The configuration file
-
-   The configuration file (called php3.ini in PHP 3, and simply php.ini as
-   of PHP 4) is read when PHP starts up. For the server module versions of
-   PHP, this happens only once when the web server is started. For the CGI
-   and CLI version, it happens on every invocation.
-
-   php.ini is searched in these locations (in order):
-
-     * SAPI module specific location (PHPIniDir directive in Apache 2, -c
-       command line option in CGI and CLI)
-     * The PHPRC environment variable. Before PHP 5.2.0 this was checked
-       after the registry key mentioned below.
-     * As of PHP 5.2.0, the following registry locations are searched in
-       order: HKEY_LOCAL_MACHINE\SOFTWARE\PHP\x.y.z\IniFilePath,
-       HKEY_LOCAL_MACHINE\SOFTWARE\PHP\x.y\IniFilePath and
-       HKEY_LOCAL_MACHINE\SOFTWARE\PHP\x\IniFilePath, where x, y and z
-       mean the PHP major, minor and release versions.
-     * HKEY_LOCAL_MACHINE\SOFTWARE\PHP\IniFilePath (Windows Registry
-       location)
-     * Current working directory (except CLI)
-     * The web server's directory (for SAPI modules), or directory of PHP
-       (otherwise in Windows)
-     * Windows directory (C:\windows or C:\winnt) (for Windows), or
-       --with-config-file-path compile time option
-
-   If php-SAPI.ini exists (where SAPI is used SAPI, so the filename is
-   e.g. php-cli.ini or php-apache.ini), it's used instead of php.ini. SAPI
-   name can be determined by php_sapi_name().
-
-     Note: The Apache web server changes the directory to root at startup
-     causing PHP to attempt to read php.ini from the root filesystem if
-     it exists.
-
-   The php.ini directives handled by extensions are documented
-   respectively on the pages of the extensions themselves. The list of the
-   core directives is available in the appendix. Probably not all PHP
-   directives are documented in the manual though. For a complete list of
-   directives available in your PHP version, please read your well
-   commented php.ini file. Alternatively, you may find the latest
-   php.ini from SVN helpful too.
-
-   Example 5-1. php.ini example
-; any text on a line after an unquoted semicolon (;) is ignored
-[php] ; section markers (text within square brackets) are also ignored
-; Boolean values can be set to either:
-;    true, on, yes
-; or false, off, no, none
-html_errors = off
-track_errors = yes
-
-; you can enclose strings in double-quotes
-include_path = ".:/usr/local/lib/php"
-
-; backslashes are treated the same as any other character
-include_path = ".;c:\php\lib"
-
-   Since PHP 5.1.0, it is possible to refer to existing .ini variables
-   from within .ini files. Example: open_basedir = ${open_basedir}
-   ":/new/dir".
-     __________________________________________________________________
-
-How to change configuration settings
-
-Running PHP as an Apache module
-
-   When using PHP as an Apache module, you can also change the
-   configuration settings using directives in Apache configuration files
-   (e.g. httpd.conf) and .htaccess files. You will need "AllowOverride
-   Options" or "AllowOverride All" privileges to do so.
-
-   With PHP 4 and PHP 7, there are several Apache directives that allow
-   you to change the PHP configuration from within the Apache
-   configuration files. For a listing of which directives are PHP_INI_ALL,
-   PHP_INI_PERDIR, or PHP_INI_SYSTEM, have a look at the List of php.ini
-   directives appendix.
-
-     Note: With PHP 3, there are Apache directives that correspond to
-     each configuration setting in the php3.ini name, except the name is
-     prefixed by "php3_".
-
-   php_value name value
-          Sets the value of the specified directive. Can be used only with
-          PHP_INI_ALL and PHP_INI_PERDIR type directives. To clear a
-          previously set value use none as the value.
-
-     Note: Don't use php_value to set boolean values. php_flag (see
-     below) should be used instead.
-
-   php_flag name on|off
-          Used to set a boolean configuration directive. Can be used only
-          with PHP_INI_ALL and PHP_INI_PERDIR type directives.
-
-   php_admin_value name value
-          Sets the value of the specified directive. This can not be used
-          in .htaccess files. Any directive type set with php_admin_value
-          can not be overridden by .htaccess or virtualhost directives. To
-          clear a previously set value use none as the value.
-
-   php_admin_flag name on|off
-          Used to set a boolean configuration directive. This can not be
-          used in .htaccess files. Any directive type set with
-          php_admin_flag can not be overridden by .htaccess or virtualhost
-          directives.
-
-   Example 5-2. Apache configuration example
-<IfModule mod_php7.c>
-  php_value include_path ".:/usr/local/lib/php"
-  php_admin_flag engine on
-</IfModule>
-
-   Caution
-
-   PHP constants do not exist outside of PHP. For example, in httpd.conf
-   you can not use PHP constants such as E_ALL or E_NOTICE to set the
-   error_reporting directive as they will have no meaning and will
-   evaluate to 0. Use the associated bitmask values instead. These
-   constants can be used in php.ini
-     __________________________________________________________________
-
-Changing PHP configuration via the Windows registry
-
-   When running PHP on Windows, the configuration values can be modified
-   on a per-directory basis using the Windows registry. The configuration
-   values are stored in the registry key HKLM\SOFTWARE\PHP\Per Directory
-   Values, in the sub-keys corresponding to the path names. For example,
-   configuration values for the directory c:\inetpub\wwwroot would be
-   stored in the key HKLM\SOFTWARE\PHP\Per Directory
-   Values\c\inetpub\wwwroot. The settings for the directory would be
-   active for any script running from this directory or any subdirectory
-   of it. The values under the key should have the name of the PHP
-   configuration directive and the string value. PHP constants in the
-   values are not parsed. However, only configuration values changeable in
-   PHP_INI_USER can be set this way, PHP_INI_PERDIR values can not.
-     __________________________________________________________________
-
-Other interfaces to PHP
-
-   Regardless of how you run PHP, you can change certain values at runtime
-   of your scripts through ini_set(). See the documentation on the
-   ini_set() page for more information.
-
-   If you are interested in a complete list of configuration settings on
-   your system with their current values, you can execute the phpinfo()
-   function, and review the resulting page. You can also access the values
-   of individual configuration directives at runtime using ini_get() or
-   get_cfg_var().
-     __________________________________________________________________
-
-Chapter 6. Installation FAQ
-
-   This section holds common questions about the way to install PHP. PHP
-   is available for almost any OS (except maybe for MacOS before OSX), and
-   almost any web server.
-
-   To install PHP, follow the instructions in Installing PHP.
-
-   1. Why shouldn't I use Apache2 with a threaded MPM in a production
-          environment?
-
-   2. Unix/Windows: Where should my php.ini file be located?
-   3. Unix: I installed PHP, but every time I load a document, I get the
-          message 'Document Contains No Data'! What's going on here?
-
-   4. Unix: I installed PHP using RPMS, but Apache isn't processing the
-          PHP pages! What's going on here?
-
-   5. Unix: I installed PHP 3 using RPMS, but it doesn't compile with the
-          database support I need! What's going on here?
-
-   6. Unix: I patched Apache with the FrontPage extensions patch, and
-          suddenly PHP stopped working. Is PHP incompatible with the
-          Apache FrontPage extensions?
-
-   7. Unix/Windows: I have installed PHP, but when I try to access a PHP
-          script file via my browser, I get a blank screen.
-
-   8. Unix/Windows: I have installed PHP, but when try to access a PHP
-          script file via my browser, I get a server 500 error.
-
-   9. Some operating systems: I have installed PHP without errors, but
-          when I try to start apache I get undefined symbol errors:
-
-[mybox:user /src/php7] root# apachectl configtest
- apachectl: /usr/local/apache/bin/httpd Undefined symbols:
-  _compress
-  _uncompress
-
-   10. Windows: I have installed PHP, but when I to access a PHP script
-          file via my browser, I get the error:
-
-cgi error:
- The specified CGI application misbehaved by not
- returning a complete set of HTTP headers.
- The headers it did return are:
-
-   11. Windows: I've followed all the instructions, but still can't get
-          PHP and IIS to work together!
-
-   12. When running PHP as CGI with IIS, OmniHTTPD or Xitami, I get
-          the following error: Security Alert! PHP CGI cannot be accessed
-          directly..
-
-   13. How do I know if my php.ini is being found and read? It seems like
-          it isn't as my changes aren't being implemented.
-
-   14. How do I add my PHP directory to the PATH on Windows?
-   15. How do I make the php.ini file available to PHP on windows?
-   16. Is it possible to use Apache content negotiation (MultiViews
-          option) with PHP?
-
-   17. Is PHP limited to process GET and POST request methods only?
-
-   1. Why shouldn't I use Apache2 with a threaded MPM in a production
-   environment?
-
-   PHP is glue. It is the glue used to build cool web applications by
-   sticking dozens of 3rd-party libraries together and making it all
-   appear as one coherent entity through an intuitive and easy to learn
-   language interface. The flexibility and power of PHP relies on the
-   stability and robustness of the underlying platform. It needs a working
-   OS, a working web server and working 3rd-party libraries to glue
-   together. When any of these stop working PHP needs ways to identify the
-   problems and fix them quickly. When you make the underlying framework
-   more complex by not having completely separate execution threads,
-   completely separate memory segments and a strong sandbox for each
-   request to play in, feet of clay are introduced into PHP's system.
-
-   If you feel you have to use a threaded MPM, look at a FastCGI
-   configuration where PHP is running in its own memory space.
-
-   And finally, this warning against using a threaded MPM is not as strong
-   for Windows systems because most libraries on that platform tend to be
-   threadsafe.
-
-   2. Unix/Windows: Where should my php.ini file be located?
-
-   By default on Unix it should be in /usr/local/lib which is
-   <install-path>/lib. Most people will want to change this at
-   compile-time with the --with-config-file-path flag. You would, for
-   example, set it with something like:
-   --with-config-file-path=/etc
-
-   And then you would copy php.ini-production from the distribution to
-   /etc/php.ini and edit it to make any local changes you want.
-   --with-config-file-scan-dir=PATH
-
-   On Windows the default path for the php.ini file is the Windows
-   directory. If you're using the Apache webserver, php.ini is first
-   searched in the Apaches install directory, e.g. c:\program files\apache
-   group\apache. This way you can have different php.ini files for
-   different versions of Apache on the same machine.
-
-   See also the chapter about the configuration file.
-
-   3. Unix: I installed PHP, but every time I load a document, I get the
-   message 'Document Contains No Data'! What's going on here?
-
-   This probably means that PHP is having some sort of problem and is
-   core-dumping. Look in your server error log to see if this is the case,
-   and then try to reproduce the problem with a small test case. If you
-   know how to use 'gdb', it is very helpful when you can provide a
-   backtrace with your bug report to help the developers pinpoint the
-   problem. If you are using PHP as an Apache module try something like:
-
-     * Stop your httpd processes
-     * gdb httpd
-     * Stop your httpd processes
-     * > run -X -f /path/to/httpd.conf
-     * Then fetch the URL causing the problem with your browser
-     * > run -X -f /path/to/httpd.conf
-     * If you are getting a core dump, gdb should inform you of this now
-     * type: bt
-     * You should include your backtrace in your bug report. This should
-       be submitted to http://bugs.php.net/
-
-   If your script uses the regular expression functions (ereg() and
-   friends), you should make sure that you compiled PHP and Apache with
-   the same regular expression package. This should happen automatically
-   with PHP and Apache 1.3.x
-
-   4. Unix: I installed PHP using RPMS, but Apache isn't processing the
-   PHP pages! What's going on here?
-
-   Assuming you installed both Apache and PHP from RPM packages, you need
-   to uncomment or add some or all of the following lines in your
-   httpd.conf file:
-# Extra Modules
-AddModule mod_php.c
-AddModule mod_php3.c
-AddModule mod_perl.c
-
-# Extra Modules
-LoadModule php_module         modules/mod_php.so
-LoadModule perl_module        modules/libperl.so
-
-   And add:
-AddType application/x-httpd-php3 .php3    # for PHP 3
-AddType application/x-httpd-php .php      # for PHP 4
-
-   ... to the global properties, or to the properties of the VirtualDomain
-   you want to have PHP support added to.
-
-   5. Unix: I installed PHP 3 using RPMS, but it doesn't compile with the
-   database support I need! What's going on here?
-
-   Due to the way PHP 3 built, it is not easy to build a complete flexible
-   PHP RPM. This issue is addressed in PHP 4. For PHP 3, we currently
-   suggest you use the mechanism described in the INSTALL.REDHAT file in
-   the PHP distribution. If you insist on using an RPM version of PHP 3,
-   read on...
-
-   The RPM packagers are setting up the RPMS to install without database
-   support to simplify installations and because RPMS use /usr/ instead of
-   the standard /usr/local/ directory for files. You need to tell the RPM
-   spec file which databases to support and the location of the top-level
-   of your database server.
-
-   This example will explain the process of adding support for the popular
-   MySQL database server, using the mod installation for Apache.
-
-   Of course all of this information can be adjusted for any database
-   server that PHP supports. We will assume you installed MySQL and Apache
-   completely with RPMS for this example as well.
-
-     * First remove mod_php3 :
-
-rpm -e mod_php3
-
-     * Then get the source rpm and INSTALL it, NOT --rebuild
-
-rpm -Uvh mod_php3-3.0.5-2.src.rpm
-
-     * Then edit the /usr/src/redhat/SPECS/mod_php3.spec file
-       In the %build section add the database support you want, and the
-       path.
-       For MySQL you would add --with-mysql=/usr The %build section will
-       look something like this:
-
-./configure --prefix=/usr \
---with-apxs=/usr/sbin/apxs \
---with-config-file-path=/usr/lib \
---enable-debug=no \
---enable-safe-mode \
---with-exec-dir=/usr/bin \
---with-mysql=/usr \
---with-system-regex
-
-     * Once this modification is made then build the binary rpm as
-       follows:
-
-rpm -bb /usr/src/redhat/SPECS/mod_php3.spec
-
-     * Then install the rpm
-
-rpm -ivh /usr/src/redhat/RPMS/i386/mod_php3-3.0.5-2.i386.rpm
-
-   Make sure you restart Apache, and you now have PHP 3 with MySQL support
-   using RPM's. Note that it is probably much easier to just build from
-   the distribution tarball of PHP 3 and follow the instructions in
-   INSTALL.REDHAT found in that distribution.
-
-   6. Unix: I patched Apache with the FrontPage extensions patch, and
-   suddenly PHP stopped working. Is PHP incompatible with the Apache
-   FrontPage extensions?
-
-   No, PHP works fine with the FrontPage extensions. The problem is that
-   the FrontPage patch modifies several Apache structures, that PHP relies
-   on. Recompiling PHP (using 'make clean ; make') after the FP patch is
-   applied would solve the problem.
-
-   7. Unix/Windows: I have installed PHP, but when I try to access a PHP
-   script file via my browser, I get a blank screen.
-
-   Do a 'view source' in the web browser and you will probably find that
-   you can see the source code of your PHP script. This means that the web
-   server did not send the script to PHP for interpretation. Something is
-   wrong with the server configuration - double check the server
-   configuration against the PHP installation instructions.
-
-   8. Unix/Windows: I have installed PHP, but when try to access a PHP
-   script file via my browser, I get a server 500 error.
-
-   Something went wrong when the server tried to run PHP. To get to see a
-   sensible error message, from the command line, change to the directory
-   containing the PHP executable (php.exe on Windows) and run php -i. If
-   PHP has any problems running, then a suitable error message will be
-   displayed which will give you a clue as to what needs to be done next.
-   If you get a screen full of HTML codes (the output of the phpinfo()
-   function) then PHP is working, and your problem may be related to your
-   server configuration which you should double check.
-
-   9. Some operating systems: I have installed PHP without errors, but
-   when I try to start apache I get undefined symbol errors:
-[mybox:user /src/php7] root# apachectl configtest
- apachectl: /usr/local/apache/bin/httpd Undefined symbols:
-  _compress
-  _uncompress
-
-   This has actually nothing to do with PHP, but with the MySQL client
-   libraries. Some need --with-zlib, others do not. This is also covered
-   in the MySQL FAQ.
-
-   10. Windows: I have installed PHP, but when I to access a PHP script
-   file via my browser, I get the error:
-cgi error:
- The specified CGI application misbehaved by not
- returning a complete set of HTTP headers.
- The headers it did return are:
-
-   This error message means that PHP failed to output anything at all. To
-   get to see a sensible error message, from the command line, change to
-   the directory containing the PHP executable (php.exe on Windows) and
-   run php -i. If PHP has any problems running, then a suitable error
-   message will be displayed which will give you a clue as to what needs
-   to be done next. If you get a screen full of HTML codes (the output of
-   the phpinfo() function) then PHP is working.
-
-   Once PHP is working at the command line, try accessing the script via
-   the browser again. If it still fails then it could be one of the
-   following:
-
-     * File permissions on your PHP script, php.exe, php7ts.dll, php.ini
-       or any PHP extensions you are trying to load are such that the
-       anonymous internet user ISUR_<machinename> cannot access them.
-     * The script file does not exist (or possibly isn't where you think
-       it is relative to your web root directory). Note that for IIS you
-       can trap this error by ticking the 'check file exists' box when
-       setting up the script mappings in the Internet Services Manager. If
-       a script file does not exist then the server will return a 404
-       error instead. There is also the additional benefit that IIS will
-       do any authentication required for you based on the NTLanMan
-       permissions on your script file.
-
-   11. Windows: I've followed all the instructions, but still can't get
-   PHP and IIS to work together!
-
-   Make sure any user who needs to run a PHP script has the rights to run
-   php.exe! IIS uses an anonymous user which is added at the time IIS is
-   installed. This user needs rights to php.exe. Also, any authenticated
-   user will also need rights to execute php.exe. And for IIS4 you need to
-   tell it that PHP is a script engine. Also, you will want to read this
-   faq.
-
-   12. When running PHP as CGI with IIS, OmniHTTPD or Xitami, I get
-   the following error: Security Alert! PHP CGI cannot be accessed
-   directly..
-
-   You must set the cgi.force_redirect directive to 0. It defaults to 1 so
-   be sure the directive isn't commented out (with a ;). Like all
-   directives, this is set in php.ini
-
-   Because the default is 1, it's critical that you're 100% sure that the
-   correct php.ini file is being read. Read this faq for details.
-
-   13. How do I know if my php.ini is being found and read? It seems like
-   it isn't as my changes aren't being implemented.
-
-   To be sure your php.ini is being read by PHP, make a call to phpinfo()
-   and near the top will be a listing called Configuration File (php.ini).
-   This will tell you where PHP is looking for php.ini and whether or not
-   it's being read. If just a directory PATH exists than it's not being
-   read and you should put your php.ini in that directory. If php.ini is
-   included within the PATH than it is being read.
-
-   If php.ini is being read and you're running PHP as a module, then be
-   sure to restart your web server after making changes to php.ini
-
-   14. How do I add my PHP directory to the PATH on Windows?
-
-   On Windows NT, 2000, XP and 2003:
-
-     * Go to Control Panel and open the System icon (Start -> Settings ->
-       Control Panel -> System, or just Start -> Control Panel -> System
-       for Windows XP/2003)
-     * Go to the Advanced tab
-     * Click on the 'Environment Variables' button
-     * Look into the 'System Variables' pane
-     * Find the Path entry (you may need to scroll to find it)
-     * Double click on the Path entry
-     * Enter your PHP directory at the end, including ';' before (e.g.
-       ;C:\php)
-     * Press OK and restart your computer
-
-   On Windows 98/Me you need to edit the autoexec.bat file:
-
-     * Open the Notepad (Start -> Run and enter notepad)
-     * Open the C:\autoexec.bat file
-     * Locate the line with PATH=C:\WINDOWS;C:\WINDOWS\COMMAND;..... and
-       add: ;C:\php to the end of the line
-     * Save the file and restart your computer
-
-     Note: Be sure to reboot after following the steps above to ensure
-     that the PATH changes are applied.
-
-   The PHP manual used to promote the copying of files into the Windows
-   system directory, this is because this directory (C:\Windows, C:\WINNT,
-   etc.) is by default in the systems PATH. Copying files into the Windows
-   system directory has long since been deprecated and may cause problems.
-
-   15. How do I make the php.ini file available to PHP on windows?
-
-   There are several ways of doing this. If you are using Apache, read
-   their installation specific instructions (Apache 1, Apache 2),
-   otherwise you must set the PHPRC environment variable:
-
-   On Windows NT, 2000, XP and 2003:
-
-     * Go to Control Panel and open the System icon (Start -> Settings ->
-       Control Panel -> System, or just Start -> Control Panel -> System
-       for Windows XP/2003)
-     * Go to the Advanced tab
-     * Click on the 'Environment Variables' button
-     * Look into the 'System variables' pane
-     * Click on 'New' and enter 'PHPRC' as the variable name and the
-       directory where php.ini is located as the variable value (e.g.
-       C:\php)
-     * Press OK and restart your computer
-
-   On Windows 98/Me you need to edit the autoexec.bat file:
-
-     * Open the Notepad (Start -> Run and enter notepad)
-     * Open the C:\autoexec.bat file
-     * Add a new line to the end of the file: set PHPRC=C:\php (replace
-       C:\php with the directory where php.ini is located). Please note
-       that the path cannot contain spaces. For instance, if you have
-       installed PHP in C:\Program Files\PHP, you would enter
-       C:\PROGRA~1\PHP instead.
-     * Save the file and restart your computer
-
-   16. Is it possible to use Apache content negotiation (MultiViews
-   option) with PHP?
-
-   If links to PHP files include extension, everything works perfect. This
-   FAQ is only for the case when links to PHP files don't include
-   extension and you want to use content negotiation to choose PHP files
-   from URL with no extension. In this case, replace the line AddType
-   application/x-httpd-php .php with:
-# PHP 4
-AddHandler php-script php
-AddType text/html php
-
-# PHP 7
-AddHandler php7-script php
-AddType text/html php
-
-   This solution doesn't work for Apache 1 as PHP module doesn't catch
-   php-script.
-
-   17. Is PHP limited to process GET and POST request methods only?
-
-   No, it is possible to handle any request method, e.g. CONNECT. Proper
-   response status can be sent with header(). If only GET and POST methods
-   should be handled, it can be achieved with this Apache configuration:
-<LimitExcept GET POST>
-Deny from all
-</LimitExcept>