win7+apache+php+mysql环境配置操作详解


Posted in PHP onJune 10, 2013

1.php版本简介
php各版本之间的区别,php版本后面一般有VC6和VC9、Thread Safe和Non Thread Safe的区别,VC6就是legacy Visual Studio 6 compiler,就
是使用这个编译器编译的,VC9就是the Visual Studio 2008 compiler,就是用微软的VS编辑器编译的,如果你选用的是Apache或者其他服务软
件,那么选择VC6,选用的是IIS的话,那么请下载VC9 的。Thread Safe 是线程安全,而Non Thread Safe就是非线程安全, 官方并不建议你将
Non Thread Safe 应用于生产环境,所以一般选择Thread Safe版本的下载就可以了。下载Zip包就可以了。

2.php下载,选择哪个版本
下载地址http://windows.php.net/download/,笔者选择的是php-5.3.16-Win32-VC9-x86.zip
(1)如果用的是apache1或apache2,请选择vc6版的php
(2)如果用的是IIS,你应该选择VC9版的PHP
VC6的版本是用Visual Studio 6编译的,VC9是用Visual Studio 2008编译的,提升了性能和稳定性,VC9版本需要安装Microsoft 2008 C++ 
Runtime,下载地址http://www.microsoft.com/en-us/download/details.aspx?id=29,或者安装VC10,下载地址 
http://www.microsoft.com/download/en/details.aspx?id=8328

3.下载和安装apache
(1)下载地址http://httpd.apache.org/download.cgi,笔者下载的是httpd-2.2.22-win32-x86-openssl-0.9.8t.msi
(2)apache安装:
在这里主要配置
Network Domain:yourdomain.com
Server Name:www.yourdomain.com
Email:username@126.com
Apache服务的占用端口,默认为80端口,你可以根据需要配置在其他端口,Apache的安装目录你可以使用默认目录或根据需要自行选择安装目录
在完成apache服务的安装后,在游览器中输入http://localhost/,出现It's work!字样,说明Apache服务安装成功了。
(3)如果启动apache时,报了“(OS 10013)以一种访问权限不允许的方式做了一个访问套接字的尝试。 : make_sock: could not bind to 
address 0.0.0.0:80”的错误。
用netstat -ano查看80端口已被占用,通常80端口会被IIS占用。
(4)解决方法:打开Apache安装目录\conf\httpd.conf文件,需要修改listen 80--》listent 88
(5)在浏览器里输入http://localhost:88即可
(6)如果启动apache出错“httpd.exe: Could not reliably determine the server's fully qualified domain name, using 192.168.1.111 
for ServerName”是因为DNS没配置好. 如果不想配置DNS, 就在httpd.conf中去掉ServerName前的#,修改为 ServerName 127.0.0.1:88

4.php的安装和配置
(1)将php-5.3.16-Win32-VC9-x86.zip解压至d:\php
(2)php.ini-development配置文件重命名为php.ini
(3)打开php.ini文件,找到如下文本
; On windows:
; extension_dir = "ext"
去掉extension_dir前的“;”,修改为extension_dir = "D:/php/ext" 表示指定PHP扩展包的具体目录,以便调用相应的DLL文件。
(4)由于默认PHP并不支持自动连接Mysql,需开启相应的扩展库功能,比如php_mysql.dll等,找到如下dll文本,去掉前面的";"
extension=php_curl.dll
extension=php_gd2.dll
extension=php_mbstring.dll
extension=php_mysql.dll
extension=php_mysqli.dll
extension=php_pdo_mysql.dll
extension=php_pdo_odbc.dll
extension=php_xmlrpc.dll
(5)配置php的session功能
在使用session功能时,我们必须配置session文件在服务器上的保存目录,否则无法使用session,我们需要在Windows 7上新建一个可读写的目
录文件夹,此目录最好独立于WEB主程序目录之外,此处我在D盘根目录上建立了phpsessiontmp目录,然后在php.ini配置文件中找到
;session.save_path = "/tmp"
修改为
session.save_path = "D:/phpsessiontmp"
(6)配置PHP的文件上传功能
同session一样,在使用PHP文件上传功能时,我们必须要指定一个临时文件夹以完成文件上传功能,否则文件上传功能会失败,我们仍然需要在
Windows 7上建立一个可读写的目录文件夹,此处我在D盘根目录上建立了phpfileuploadtmp目录,然后在php.ini配置文件中找到
;upload_tmp_dir =
修改为

upload_tmp_dir = "D:/phpfileuploadtmp"
php默认上传文件大小为2M,
upload_max_filesize = 2M,可以根据自己的要求将其修改为
upload_max_filesize = 8M

(7)时区设置
修改date.timezone,否则在执行phpinfo时date部分会报错:Warning: phpinfo() [function.phpinfo]…,在php.ini配置文件中找到
;date.timezone =
修改为
date.timezone = Asia/Shanghai

5.配置Apache支持PHP,所以还需要在Apache配置文件中完成相应的PHP配置
(1)打开d:/apache/modules/mod_vhost_alias.so
在#LoadModule vhost_alias_module 下添加
LoadModule php5_module "c:/php/php5apache2_2.dll"
PHPIniDir "c:/php"
AddType application/x-httpd-php .php .html .htm
我们在PHP目录下可以看到多个php5apache的DLL文件,由于我们使用的是Apache2.2.15,所以我们当然需要使用php5apache2_2.dll,接着指定
PHP的安装目录以及执行的程序扩展名。
(2)再次打开apache的httpd.conf 修改DocumentRoot
DocumentRoot "C:/Program Files/Apache Software Foundation/Apache2.2/htdocs"
修改为
DocumentRoot "D:/PHPWeb"
(3)修改Directory
<Directory "C:/Program Files/Apache Software Foundation/Apache2.2/htdocs">
修改为
<Directory "D:/PHPWeb">
(4)修改具体的index文件先后顺序,由于配置了PHP功能,当然需要index.php优先执行
DirectoryIndex index.html
修改为
DirectoryIndex index.php index.html
(5)开启支持rewrite module
#LoadModule rewrite_module modules/mod_rewrite.so 去掉前面#,
修改为 LoadModule rewrite_module modules/mod_rewrite.so

6、重启Apache服务器
至此,在Apache服务器上PHP环境配置工作就完成了,你只需要在D:/PHPWeb目录下新建一个PHP文件,写入

<?php
phpinfo();
?>

然后在浏览器中输入http://localhost:88,就可以看到PHP的具体配置页面了,代表在Window 7上PHP环境配置工作就算完成了。

7.测试数据库连接
新建testdb.php

<?php
$connect=mysql_connect("127.0.0.1","root","**");
if(!$connect) 
echo "Mysql Connect Error!";
else 
echo "db connect 你好";
mysql_close();
?>

若出现中文乱码,修改php.ini配置 default_charset = "utf-8"

8.如果你的如上配置太复杂,那么可以用wamp傻瓜化安装包,下载地址http://www.wampserver.com
因为WAMPSERVER (32 BITS & PHP 5.3) 2.2E里就包含了

Apache 2.2.22 ? Mysql 5.5.24 ? PHP 5.3.13 XDebug 2.1.2 XDC 1.5 PhpMyadmin 3.4.10.1 SQLBuddy 1.3.3 webGrind 1.0

笔者在自己电脑上用wamp发现虽然在PhpMyadmin建数据库和表时设置里UTF-8还是出现乱码,解决办法是在mysql_connect()之后加入

mysql_query("set names utf8");

即可解决中文乱码
PHP 相关文章推荐
初探PHP5
Oct 09 PHP
PHP调用MySQL的存储过程的实现代码
Aug 12 PHP
PHP Ajax中文乱码问题解决方法
Feb 27 PHP
php+ajax做仿百度搜索下拉自动提示框(有实例)
Aug 21 PHP
PHP基础教程(php入门基础教程)一些code代码
Jan 06 PHP
深入探讨:PHP使用数据库永久连接方式操作MySQL的是与非
Jun 05 PHP
利用curl抓取远程页面内容的示例代码
Jul 23 PHP
Drupal读取Excel并导入数据库实例
Mar 02 PHP
PHP使用CURL获取302跳转后的地址实例
May 04 PHP
Laravel 5框架学习之路由、控制器和视图简介
Apr 07 PHP
PHP代码维护,重构变困难的4种原因分析
Jan 25 PHP
PHP实现微信模拟登陆并给用户发送消息的方法【文字,图片,图文】
Jun 29 PHP
浅谈php中mysql与mysqli的区别分析
Jun 10 #PHP
探讨php中防止SQL注入最好的方法是什么
Jun 10 #PHP
php防注入,表单提交值转义的实现详解
Jun 10 #PHP
PHP获取当前页面完整URL的实现代码
Jun 10 #PHP
如何判断php数组的维度
Jun 10 #PHP
joomla jce editor 解决上传中文名文件失败问题
Jun 09 #PHP
php缩放图片(根据宽高的等比例缩放)实例介绍
Jun 09 #PHP
You might like
PHP产生随机字符串函数
2006/12/06 PHP
Yii框架获取当前controlle和action对应id的方法
2014/12/03 PHP
PHP中list方法用法示例
2016/12/01 PHP
thinkPHP框架动态配置用法实例分析
2018/06/14 PHP
为jQuery增加join方法的实现代码
2010/11/28 Javascript
利用webqq协议使用python登录qq发消息源码参考
2013/04/08 Javascript
jQuery ReferenceError: $ is not defined 错误的处理办法
2013/05/10 Javascript
js简单的表格添加行和删除行操作示例
2014/03/31 Javascript
jquery单选框radio绑定click事件实现方法
2015/01/14 Javascript
JS简单限制textarea内输入字符数量的方法
2015/10/14 Javascript
jQuery实现的仿百度分页足迹效果代码
2015/10/30 Javascript
基于JQuery打造无缝滚动新闻步骤详解
2016/03/31 Javascript
jquery单击文字或图片内容放大并居中显示
2017/06/23 jQuery
如何理解Vue的.sync修饰符的使用
2017/08/17 Javascript
js时间戳与日期格式之间相互转换
2017/12/11 Javascript
响应式框架Bootstrap栅格系统的实例
2017/12/19 Javascript
Vue+ElementUI实现表单动态渲染、可视化配置的方法
2018/03/07 Javascript
vue搜索和vue模糊搜索代码实例
2019/05/07 Javascript
微信小程序云开发使用方法新手初体验
2019/05/16 Javascript
前端Vue项目详解--初始化及导航栏
2019/06/24 Javascript
JS面向对象之多选框实现
2020/01/17 Javascript
Python类的基础入门知识
2008/11/24 Python
用python实现的可以拷贝或剪切一个文件列表中的所有文件
2009/04/30 Python
使用wxpython实现的一个简单图片浏览器实例
2014/07/10 Python
详解Python中的正则表达式的用法
2015/04/09 Python
Python实现PS图像抽象画风效果的方法
2018/01/23 Python
python 实现数组list 添加、修改、删除的方法
2018/04/04 Python
python画图——实现在图上标注上具体数值的方法
2019/07/08 Python
python3 实现爬取TOP500的音乐信息并存储到mongoDB数据库中
2019/08/24 Python
python如何快速生成时间戳
2020/07/21 Python
appium+python自动化配置(adk、jdk、node.js)
2020/11/17 Python
css3动画过渡实现鼠标跟随导航效果
2018/02/08 HTML / CSS
统计每一学生的平均成绩
2014/06/06 面试题
复兴之路观后感
2015/06/02 职场文书
如何书写先进事迹材料?
2019/07/02 职场文书
python自动化操作之动态验证码、滑动验证码的降噪和识别
2021/08/30 Python