首页 > 编程技术 > php

windows下IIS配置PHP环境图文方法

发布时间:2016-11-25 15:28

本文章来给各位同学介绍在windows系统中iis7配置php环境的几种方法,有需要了解的朋友可参考,这里我以PHP5.2.17和PHP5.3.5 为实例,iis7配置PHP5.3.5和PHP5.2.17方法。

先到官网下载

PHP5.2.17 官方下载: http://windows.php.net/downloads/releases/php-5.2.17-Win32-VC6-x86.zip
PHP5.3.5 官方下载:http://windows.php.net/downloads/releases/php-5.3.5-Win32-VC9-x86.zip

注意了,必须都是线程安全版的了,如果是百安全测试版本的大家不要用,在服务器就要做安全版的。

在php.ini文件配置是我们如果是开发版就可随便使用那个php.ini文件了,如果是产品或服务器版本我们需要使用php.ini-production但在php5.2.17对应用文件是php.ini-recommended哦。

php.ini-production对应于php.ini-recommended
php.ini-development对应于php.ini-dist

好了注意事项都讲了,下面我来看图文教程。

首先安装好IIS7 安装的时候 要注意三个地方打得勾

IIS7安装扩展

注: CGI 会在IIS7+PHP_5.3.5的环境中用到

ISAPI扩展和ISAPI筛选器 用在IIS7+PHP_5.2.17

下面开始添加IIS的PHP支持

IIS7+PHP_5.3.5

1. 将下载回来的php_5.3.5解压到 C:php目录(也可以放在其他地方,但是后面应该做相应修改)

2. 将php.ini-development改名为php.ini

3. 修改php.ini 查找data.timezone 修改为date.timezone = “Asia/Shanghai”(这里必须改,不然会出警告) 找到Windows Extensions开启 所需模块,如:php_curl.dll php_mysql.dll php_mysqli.dll php_xmlrpc.dll php_curl.dll 只要去掉前面的 分号 保存就可以了

4. 添加<模块映射>

IIS7添加映射

IIS7添配置PHP

 

这里的路径按你的实际情况填写.

5. 在网站根目录新建一个phpinfo.php的文本文件 内容为:

<?php
phpinfo();
?>

6. 测试,打开浏览器看结果:localhost/phpinfo.php,如果能看到类似下面的页面就说明你成功了:

IIS7配置PHP

好了,到现在 已经可以成功的运行PHP程序了.

IIS7+PHP_5.2.17

于之前安装IIS的时候已经选上了isapi扩展和isapi筛选,这里就不用另外再添加角色服务了,直接开始

先修改php.ini文件..

把c:php下的php.ini-dist (需先设置显示扩展名)改名成php.ini,用记事本打开 找到extension_dir = “./”,然后把里面的./改成c:php(根据自己的实际情况修改路径)

1. 添加应用程序池

IIS7配置PHP图解

2. 添加isapi和cgi限制

3. 添加isapi筛选器

IIS7配置PHP图解

4. 添加脚本映射

5. 测试(之前已经创建了phpinfo.php) 跟之前一样 打开localhost/phpinfo.php 查看效果:

IIS7配置PHP图解

 

下面补充一下在apache+php配置方法

1.Apache配置PHP个人认为首先要注意的是Apache和PHP的版本信息,不同的版本之间所要进行设置的参数是不同的,开始的盲目让自己受尽了苦头。
2.选择版本:Apache 2.2.14  PHP:5.2.5 具体细节不再赘述。。。
3.验证Apache和PHP是否安装成功:
  (1) Apache: http://localhost
 (2)PHP:在dos窗口下运行php -i
4.PHP配置文件php.ini
  (1)修改:

 代码如下 复制代码
extension_dir = “./”
    extension_dir = "C:/Program Files/PHP/ext" (自己安装PHP的实际目录下ext子目录的路径)

  (2)取消注释以支持mysql数据库

 代码如下 复制代码
     extension=php_mysql.dll
     extension=php_mysqli.dll

  (3)环境变量:

 代码如下 复制代码
PHPRC: C:Program FilesPHP
Path中添加:C:Program FilesPHP

将文件liblibmysql.dll 拷贝入C:WINDOWSsystem32
  (这一步不进行可能会报Httpd.exe错误)
5.Apache配置文件httpd.conf
 (1)添加对php的支持
 

 代码如下 复制代码
  LoadModule php5_module "C:/Program Files/PHP/php5apache2_2.dll"
   PHPIniDir "C:/Program Files/PHP"

 (2)实际工作的目录:

 代码如下 复制代码
    DocumentRoot "F:/ApcheWork"
   <Directory "F:/ApcheWork">
   <Directory "F:/WWW" >
    Options FollowSymLinks
    AllowOverride None
    Order deny,allow
    allow from all
</Directory>

 (3)添加对index.php的支持

 代码如下 复制代码
    <IfModule dir_module>
    DirectoryIndex index.php index.html
</IfModule>

  (4) 添加类型支持

 代码如下 复制代码

    AddType application/x-httpd-php .php
    AddType application/x-httpd-php .html
    AddType application/x-httpd-php .php .phtml .php3 .php4
AddType application/x-httpd-php-source .phps


友情提示,根据我们经验如果你是iis7就使用PHP5.3.5 vc9编译的,如果你是apache2.2就使用php2.1.7使用vc6编译的吧,关于这个具体可到官网去下载,

在php中不管是在linux系统还是windows系统mbstring模块默认都是不可以使用的,下面我来介绍在不同系统中安装mbstring方法。


Centos下:

用SSH登录Centos后执行以下命令:
1.执行
yum install php-mbstring

2.修改php.ini
vi /etc/php.ini #将下面内容前面的分号去掉,如果没有这一行,直接加入一行extension=mbstring.so
;extension=mbstring.so

3.重启web service
service httpd restart

Windows下:

1.修改php.ini
将下面内容前面的分号去掉,如果没有这一行,直接加入一行extension=php_mbstring.dll

;extension=php_mbstring.dll

如果上述修改重启web服务器后没效果,请把 X:/PHP/EXT 文件夹下的 php_mbstring.dll 复制到系统 X:/WINDOWS/system32 文件夹下

重新启动web服务器就可了。

今天把自己的环境安装了最新的PHP5.4.8,结果在与Memcache时出现了不兼容问题,结过反复调度总结了不兼容的原因与解决办法。

emcache(sudo pecl install memcache)PHP扩展,编译后memcache.so在/usr/lib/php5/20090626/中,在PHP.ini添加好extension,重启phpfpm(不是重启nginx),出现下面的错误信息:

 代码如下 复制代码

Gracefully shutting down php-fpm . done
Starting php-fpm [25-Oct-2012 12:04:02] NOTICE:
PHP message: PHP Warning:  PHP Startup: memcache: Unable to initialize module
Module compiled with module API=20090626
PHP    compiled with module API=20100525
These options need to match

编译PHP使用的PHP核心版本是20100525,而Pecl里面的Memcache是使用20090626版本编译的,版本不一致导致PHP无法启用memcache.so库。解决方法是卸载掉Pecl方式安装的Memcache,去pecl.php.net/package/memcache下载源码包自己编译。

 代码如下 复制代码

##卸载memcache
sudo pecl uninstall memcache
 
phpize
./configure --enable-memcache --with-php-conf=/usr/local/php/bin/php-config
make
make install

启动memcached服务:memcached -d -m 256 -p 11211。测试脚本:OK。

 代码如下 复制代码

$mem = new Memcache;
$mem->connect('127.0.0.1',11211);
$mem->set('feiyan','blog');
var_dump( $mem->get('feiyan') );

本文章来给各位同学详细介绍ZendOptimizer-3.3.9最新版的安装步骤,这是一篇安装笔记有需要了解的朋友可参考此文章来操作。

ZendOptimizer-3.3.9-linux-glibc23-x86_64

我只是翻译一下,嘎嘎…

1. Extract the Zend Optimizer package.

解压安装包 tar -zxf ZendOptimizer-3.3.9-linux-glibc23-x86_64.tar.gz

2. Locate the ZendOptimizer.so (Unix) or ZendOptimizer.dll (Windows) file in the directory which
corresponds to your version of PHP (4.3.x, 4.4.x, 5.0.x, 5.1.x, 5.2.x).

在data文件夹找到你的版本的ZendOptimizer.so
将他复制到你预定的文件夹下

3. Add the following line to your php.ini file:

Linux and Mac OS X:     zend_extension=<full_path_to_ZendOptimizer.so>
Windows:                zend_extension_ts=<full_path_to_ZendOptimizer.dll>
Windows non-thread safe: zend_extension=<full_path_to_ZendOptimizer.dll>
(*) The Windows non-thread safe binary is only used with Zend Core 2.0.


根据你的系统修改php.ini 增加zend_extension=xxx(你预定的文件目加上ZendOptimizer.so)

4. Restart your Web server.

重启你的apache。

本文章来给大家介绍浏览器Basic Auth方式认证的phpMyAdmin自动登录,有需要了解的同学可进入参考。

一、需求
自动登录 phpMyAdmin。最终能够解决自动登录所有使用 Basic Auth 方式认证的网页。

.
二、phpMyAdmin 的四种认证登陆方式
1.config 配置文件。直接将允许登录的用户名和密码写在 config.inc.php 配置文件中。
2.cookie。最常用的方式,通过填写首页表单进行登录。
3.http。HTTP Basic Authentication 方式,使用浏览器的弹出式对话框进行登录。与 cookie 方式的区别主要在于用户体验。
4.signon。单点登录,适用于系统集成。用户登录了某系统后,不必再输用户名密码即可以一键登录 phpMyAdmin。
参考:http://wiki.phpmyadmin.net/pma/Auth_types

按道理 signon 方式应该是满足需求的首选方案,只不过项目开发总是有妥协和迁就,要尽量少干预现有系统的运行。另外,在实现 signon 方式登录的同时,还需要保留原有的用户输用户名密码的登录方式,即备用登录方案。这就将问题复杂化了。

三、什么是 Basic Auth
现有系统使用了 Basic Auth 方式,于是我研究了怎样能够在这种情况下也一键登录。

在访问一个需要 HTTP Basic Authentication 的 URL 时,如果你没有提供用户名和密码,服务器就会返回 401,这时浏览器会提示你输入用户名和密码。例子如下:

 代码如下 复制代码
<?php
if (!isset($_SERVER['PHP_AUTH_USER'])) {
    header('WWW-Authenticate: Basic realm="My Realm"');
    header('HTTP/1.1 401 Unauthorized');
} else {
    echo "<p>Hello {$_SERVER['PHP_AUTH_USER']}.</p>";
    echo "<p>You entered {$_SERVER['PHP_AUTH_PW']} as your password.</p>";
}
?>

保存为login.php,浏览 http://localhost/login.php 查看效果。


浏览器Basic Auth:IE9和Chrome的弹出式认证对话框
在浏览器弹出的窗口中输入用户名密码,如果使用 Chrome 开发者工具(或者 Firebug)查看,会发现其实它只是多发送了一个类似下面的请求头:

Authorization: Basic bXlfdXNlcm5hbWU6bXlfcGFzc3dvcmQ=
四、Basic Auth 认证的自动登录解决方案
要想通过认证,原则上有 2 种方法

•一是在请求头中添加 Authorization(可用 Javascript 来实现):
Authorization: “Basic 用户名和密码的base64加密字符串”
•二是在 url 中添加用户名和密码(IE 不支持):
http://username:password@domain.com/login.php

用 js 添加请求头可以使用 XMLHttpRequest,实现代码如下:

 代码如下 复制代码

<html>
<head>
<title>login</title>
<script>
function login() {
    var username = document.getElementById("username").value;
    var password = document.getElementById("password").value;
 
    xhr = new XMLHttpRequest();
    xhr.open("POST", "http://localhost/login.php", false, username, password);
    xhr.send(null);
 
    return xhr.status == 200;
}
</script>
</head>
<body>
<form action="http://localhost/login.php" method="post" onsubmit="return login();">
    <fieldset>
    <legend>Login</legend>
    <label for="username">username:</label>
    <input type="text" id="username" name="username">
 
    <label for="password">password:</label>
    <input type="password" id="password" name="password">
 
    <input type="submit" value="subject">
    </fieldset>
</form>
</body>
</html>

Basic Auth 认证的自动登录解决方案,总结下——

1、用户名密码直接写在 URL 里。

缺点:不够安全,且 IE 不支持。

2、写一个登陆表单,php 将用户名密码填到表单中,然后页面 onload 时 js 生成 Authorization 请求头提交

缺点:本系统和 phpMyAdmin 必须在同一个域。例如本系统在 admin.domain.com,而 phpMyAdmin 在 phpmyadmin.domain.com 这种情况 js 是无法跨域提交的。

3、本系统将用户名密码 post 到 phpMyAdmin 所在域的一个表单,那个表单再拿来用 js 登陆。

缺点:需要到 phpMyAdmin 所在域新增一个页面实现跨域。

标签:[!--infotagslink--]

您可能感兴趣的文章: