首頁  >  文章  >  後端開發  >  Windows+Apache建置php開發環境

Windows+Apache建置php開發環境

伊谢尔伦
伊谢尔伦原創
2016-11-24 14:22:091249瀏覽

第一步:下載已安裝的檔案

1. Apache 版本 httpd-2.2.21-win32-x86-no_ssl.msi
2. MySQL 版本 mysql-5.5.19-win32.msi
3. MySQL 版本 mysql-5.5.19-win32.msi
3. MySQL 版本 mysql-5.5.19-win32.msi

3. PHP 版本 -5. .5-Win32-VC6-x86.zip

4. phpMyadmin 版本 phpMyAdmin-3.4.9-all-languages.zip

提示:
1. 建議選擇無SSL功能的Apache版本來完成開發,因此我們在這裡使用了Apache 2.2.21-win32-x86-no ssl.msi。
2. Windows下安裝MySQL就選擇.msi安裝包格式,我們選擇了mysql-5.5.19-win32.msi ,雙擊根據嚮導安裝即可,簡單方便。
3. PHP我們選擇用Windows的.zip版本,php-5.3.5-Win32-VC6-x86.zip。從安全性和效能來說,都是zip版本的好,一般伺服器也都是安裝這個版本的。

    不要下載NTS版本或VC9版本的,因為VC9是專門為IIS定制的,而VC6 是為Apache或其他WEB服務軟體提供的。

4. phpMyAdmin是以PHP為基礎的線上MySQL管理工具,在進行phpMyAdmin3 安裝時所需的PHP環境至少為PHP5.2,MySQL5 以上的版本,我們這裡都符合要求。

第二步:安裝檔案

1. 在要安裝的磁碟建立一個資料夾。為了管理方便我們在D碟的根目錄下建立一個WAMP資料夾。 D:WAMP(WAMP是 windows+apache+mysql+php的縮寫)。
2. 在WAMP資料夾下建立一個WWW資料夾,用來存放你的PHP網站程式。 D:WAMPWWW。
3. 安裝Apache伺服器,把Apache伺服器安裝到 D:WAMPApache 資料夾。具體Apache安裝過程可以參考文件 Apache安裝圖解。
4. 把下載的php-5.3.5-Win32-VC6-x86解壓縮到 D:WAMPPHP 資料夾。

5. 安裝MySql資料庫,把MySQL安裝到 D:WAMPMySQL資料夾。具體MySQL安裝過程可以參考文件MySQL安裝圖解。

6. 解壓縮phpMyAdmin-3.4.9-all-languages.zip,然後重新命名為phpMyAdmin,將其複製到PHP網站程式目錄。結果為 D:WAMPWWWphpMyAdmin。

第三步:設定Apache

首先使用文字編輯工具(建議 EditPlus )開啟 D:WAMPApacheconfhttpd.conf 文件,這個檔案是Apache的設定文件,下面幾步都是在修改這個文件的內容。

要注意的是修改完 httpd.conf 檔案要重新啟動Apache服務,新設定才會生效。

1. 設定監聽埠

開啟httpd.conf 檔案後,找到Listen(大概在第46行),將它後面的數字改為8080,如下:

 Listen 8080

這個參數用來設定Apache伺服器的監聽埠,一般預設為80。修改為8080 是為了避免和Windows 2003系統的IIS連接埠號碼衝突,如果你沒有啟用IIS,也可以使用預設的80連接埠號碼。

2. 讓Apache載入PHP模組

找到#LoadModule vhost_alias_module modules/mod_vhost_alias.so (大概在第128行),在這行的後面加上以下內容:

LoadModule php5_module "D:/WAMP/PHP/php5apache2_2.dll"
AddType application/x-httpd-php .php
PHPIniDir "D:/WAMP/PHP"
php5apache2_2.dll"
這句話意思是以module方式載入PHP5模組。
AddType application/x-httpd-php .php
這句話意思是將.php副檔名的檔案當作php腳本來執行。你可以使用你喜歡的任何其他副檔名,如 .html、.php5 甚至是 .txt  來執行PHP。
PHPIniDir "D:/WAMP/PHP"
這句話用來指定PHP的設定檔php.ini 所在的目錄。

如果是Apache 2 以module模組方式運行php5的話,就可以使用 PHPIniDir 指令。

3. 修改網站存放目錄


我們知道Apache預設的網站存放目錄為Apache安裝目錄下的htdocs資料夾。當你更改網站存放目錄,就必須修改對應的Apache配置。

在設定檔 httpd.conf 中尋找 DocumentRoot(大概是182行),將其修改為指向網站目錄的正確資料夾。我們在這裡改為

DocumentRoot "D:/WAMP/www"

同時,查找 This should be changed to whatever you set DocumentRoot to(大概在207行),在它下面有行 ,將其修改為你自己配置的DocumentRoot 路徑。我們在這裡修改為:

<Directory "D:/WAMP/www">

4. 修改目錄首頁檔案

 在設定檔 httpd.conf 中尋找 DirectoryIndex index.html (大概在244行)將其修改成:🎜
DirectoryIndex index.html index.htm index.php

DirectoryIndex 指的是当客户浏览器访问的路径是一个目录时,Apache默认执行的文件。
以我们所修改的为例:当客户浏览器访问一个目录时,Apache会去找该目录下的index.html,如果没有再找index.htm,还没有再找 index.php。都找不到则默认显示该目录下的文件列表。参考文档:如果防止Apache显示文件列表

第四步:配置PHP

打开PHP安装目录,即D:\WAMP\PHP,我们可以看到目录下有两个这样的文件 php.ini-development 和 php.ini-production,第一个是开发使用的配置文件,第二个是生产环境的配置,因为我们是在本机做开发,所以选择前者。将php.ini-development复制一份到同目录下,并改名为 php.ini。这个php.ini 就是当前使用的配置文件,以下几步都是在修改这个php.ini文件的内容。要注意的是,修改php.ini文件后需重新启动Apache服务,新设置才会生效。

1. 指定PHP扩展库的存放目录

在Windows下PHP的扩展库通常以 DLL 形式存放在PHP的ext目录中。
使用文本工具打开php.ini文件,查找extension_dir = "ext"(大概在809行),也就是在 On windows 下面那一行。把它前面的分号“;”去除掉,改为如下:

 extension_dir = "D:/WAMP/PHP/ext"

extension_dir 表示PHP扩展库的具体目录,以便调用相应的DLL文件。

2. 开启相应的扩展库

默认情况下许多PHP的扩展库都是关闭的,比如默认PHP不支持连接Mysql数据库,需开启相应的扩展库。
这里我们开启一些常用的扩展库。
查找 ; Windows Extensions(大概在941行),在它的下面是extension列表。
找到如下扩展:

           ;extension=php_curl.dll
        ;extension=php_gd2.dll
        ;extension=php_mbstring.dll
        ;extension=php_exif.dll
        ;extension=php_mysql.dll
        ;extension=php_mysqli.dll
        ;extension=php_pdo_mysql.dll
        ;extension=php_pdo_odbc.dll
        ;extension=php_sockets.dll
        ;extension=php_xmlrpc.dll
        ;extension=php_xsl.dll

把以上extension 前面的分号 “;” 去掉。如果你希望加载其它扩展模块,方法相同,只要去掉前面的分号即可。
提示1:重启Apache提示 “unable to load dynamic library......php_curl.dll”,加载php_curl.dll错误。解决方法是拷贝 PHP 目录下的 libeay32.dll 和 ssleay32.dll 到 windows 目录或 windows/system32 目录下,只要是系统 Path 环境变量里包含的路径就可以。如果不想拷贝,你也可以直接把 PHP 路径放到系统 Path 环境变量里。 右击我的电脑=>属性=>高级=>环境变量=>系统变量里有个Path,双击打开,把你的PHP路径加个分号“;”再前面( ;D:\WAMP\PHP ),添加进去就OK了。重启Apache不再提示该错误。
提示2:Exif 扩展是用来显示图片的 exif 信息的,因为该扩展需要 mbstring.dll 支持,所以必须将 extension=php_exif.dll 这一行写到extension=php_mbstring.dll 的后面。
提示3:如果PHP自带的扩展库不能满足你的需要,你可以去 pecl.php.net 查找并下载你需要的库。windows用户可以去 pecl4win.php.net 或者 http://downloads.php.net/pierre/ 下载已经编译好的DLL文件,也可以去http://museum.php.net/php5/ 载PECL集合压缩包。
提示4:很多人在找php_zip.dll,其实从php5.3开始已经集成了zip扩展,直接使用就行了。你可以用e19378ad842b694e1b5442cf4ce21ead 找到zip扩展的说明。

3. 让PHP支持短标签

在 php.ini 配置文件查找 short_open_tag = Off (大概在266行)把它修改成:short_open_tag = On 让其支持短标签。
php的代码一般包含在79184d89c68e7248f3e40700b013c63b的标签内,设置 short_open_tag = On 之后,可以写成更简洁的形式:46eda650838d8b66cc68279407ec1898。

4. 配置PHP的Session功能

在使用session功能时,我们必须配置session文件在服务器上的保存目录。我们需要为session建立一个可读写的目录,这个目录最好独立于网站目录之外。
这里把目录上建在了D:\WAMP\sessiontmp,然后在 php.ini 配置文件中找 ;session.save_path = "/tmp" (大概在1467行),去掉前面的分号“;” ,改为如下:

session.save_path = "D:/WAMP/sessiontmp"

5. 配置PHP的文件上传功能

同session一样,在使用PHP文件上传功能时,我们必须要指定一个临时文件夹以完成文件上传功能,否则文件上传功能会失败。
我们建立一个可读写的目录文件夹 D:\WAMP\fileuploadtmp,然后在 php.ini 配置文件中找到 ;upload_tmp_dir = (大概875行),修改为:

upload_tmp_dir = "D:/WAMP/fileuploadtmp"

PHP默认上传文件大小不超过2M,要想上传大于2M的文件,请参考文档  配置php.ini实现文件上传功能。

6. 设置时区

在 php.ini 配置文件查找 ;date.timezone = (大概在993行),去掉前面的分号“;” 改为如下:

date.timezone = PRC

date.timezone是PHP5.1开始新增加的配置参数,用来设置时区。默认date.timezone是被注释掉的,也就是默认时区是UTC格林威治标准时间。
我们这里改为 date.timezone = PRC(PRC,People’s Republic of China,中华人民共和国),也就是日期使用中国的时区。这样可以解决时间相差八小时的问题。

第五步:配置phpMyAdmin

打开phpMyAdmin目录,即D:\WAMP\WWW\phpMyAdmin,我们可以看到目录下有一个config.sample.inc.php 文件,将这个文件复制一份到同目录下,并改名为 config.inc.php。这个config.inc.php 就是phpMyAdmin的配置文件,以下几步都是在修改这个config.inc.php 文件的内容。

1. 设置phpMyAdmin登录方式

打开config.inc.php文件,查找 $cfg['Servers'][$i]['auth_type'] ,设置如下:

   $cfg[&#39;Servers&#39;][$i][&#39;auth_type&#39;] = &#39;cookie&#39;;

这个参数的值设置为cookie,每次登录phpMyAdmin需要输入用户名密码。这也是phpMyAdmin的默认设置。

然后找到  $cfg['blowfish_secret'],设置如下:

$cfg[&#39;blowfish_secret&#39;] = &#39;admin10000.com&#39;;

此参数用于Cookies的加密,这是设置为admin10000.com,你可以改成自己的密码。

这里介绍一下phpMyAdmin 的四种登录方式:
cookie:这是phpMyAdmin配置默认的登录方式。需在登录界面输入MySQL的管理账号和密码。
           当选择cookie登录方式,还需要设置短语密码 $cfg['blowfish_secret'] ,这个密码用于Cookies的加密。
           例如:$cfg['blowfish_secret'] = 'admin10000.com';
           如果没有设置,登录phpMyAdmin会提示 “配置文件现在需要一个短语密码” 的错误。
config:直接在地浏览器地址栏输入phpMyAdmin登录地址即可登录,任何人都可以访问。用户名和密码提前在配置文件中设定好。
           此登录方式必须在配置文件中增加下面2行参数:
           $cfg['Servers'][$i]['user'] = '你的MySQL登录账号';
           $cfg['Servers'][$i]['password'] = '你的MySQL登陆密码;
           如果只是在本机器做开发,可以设置为config登录方式,省去每次输入密码的麻烦。
http:弹出一个对话框,输入用户名和密码后进入。
signon:类似于页面跳转的登录方式,同时需要设定$cfg['Servers'][$i]['SignonURL'],当你输入phpMyAdmin登录地址后会自动跳转到signonURL设定的网址。

2. 开启phpMyAdmin 高级功能

登录phpMyAdmin 后,在首页面的最下方会提示:“phpMyAdmin 高级功能未全部设置,部分功能不可用”。
现在我们来解决这个问题。使用phpMyAdmin的导入功能,导入phpMyAdmin/scripts/create_tables.sql 这个文件,从而建立必要的数据表。
接下来还需要新建一个MySQL用户,并授予其访问上一步操作建立的数据表的权限,这个MYSQL用户称为控制用户,为 phpMyAdmin 高级功能提供支持。
我们这里使用 pma 作为控制用户以及 pmapass 作为控制用户的密码。你可以自行更改。
在phpMyAdmin的SQL查询功能框中输入以下SQL代码:

  GRANT USAGE ON mysql.* TO &#39;pma&#39;@&#39;localhost&#39; IDENTIFIED BY &#39;pmapass&#39;;
    GRANT SELECT (
        Host, User, Select_priv, Insert_priv, Update_priv, Delete_priv,
        Create_priv, Drop_priv, Reload_priv, Shutdown_priv, Process_priv,
        File_priv, Grant_priv, References_priv, Index_priv, Alter_priv,
        Show_db_priv, Super_priv, Create_tmp_table_priv, Lock_tables_priv,
        Execute_priv, Repl_slave_priv, Repl_client_priv
        ) ON mysql.user TO &#39;pma&#39;@&#39;localhost&#39;;
    GRANT SELECT ON mysql.db TO &#39;pma&#39;@&#39;localhost&#39;;
    GRANT SELECT ON mysql.host TO &#39;pma&#39;@&#39;localhost&#39;;
    GRANT SELECT (Host, Db, User, Table_name, Table_priv, Column_priv)
        ON mysql.tables_priv TO &#39;pma&#39;@&#39;localhost&#39;;

接着我们在 config.inc.php 中找到 User used to manipulate with storage 这一行。把它下面的2行参数注释(双斜杠“//”)去掉。结果为:

 $cfg[&#39;Servers&#39;][$i][&#39;controluser&#39;] = &#39;pma&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;controlpass&#39;] = &#39;pmapass&#39;;

这两行分别是控制用户和控制用户密码。也就是上边我们创建的那个用户。

接着找到 Storage database and tables 这一行,把下面的几个参数的注释去掉。结果为:

   $cfg[&#39;Servers&#39;][$i][&#39;pmadb&#39;] = &#39;phpmyadmin&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;bookmarktable&#39;] = &#39;pma_bookmark&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;relation&#39;] = &#39;pma_relation&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;table_info&#39;] = &#39;pma_table_info&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;table_coords&#39;] = &#39;pma_table_coords&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;pdf_pages&#39;] = &#39;pma_pdf_pages&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;column_info&#39;] = &#39;pma_column_info&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;history&#39;] = &#39;pma_history&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;tracking&#39;] = &#39;pma_tracking&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;designer_coords&#39;] = &#39;pma_designer_coords&#39;;
        $cfg[&#39;Servers&#39;][$i][&#39;userconfig&#39;] = &#39;pma_userconfig&#39;;

第六步:测试

将如下代码保存为index.php文件,放到D:\WAMP\WWW目录下面。



       


                       if(!$link) echo "MySQL資料庫連線失敗!";
        mysql_close();
           ?>

           

           
      1phpinfo(); ?>
      1 php”.



陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
上一篇:PDO單例模型下一篇:PDO單例模型