1、安装CgiModule模块
首先,IIS要部署php项目,需要CgiModule模块的支持,所以首先我们要确认这个模块是否存在
打开IIS管理器:
我这里是存在的:
如果不存在,可以自行在控制面板=》程序与功能=》启用或者关闭windows功能:
2、下载安装PHP和discuz
PHP和discuz可以前往官网下载
PHP官网:https://www.php.net/downloads
discuz应用中心:https://addon.dismall.com/
discuz包下载地址:https://www.dismall.com/thread-73-1-1.html
百度云:https://pan.baidu.com/s/1HvkBASRkNDR4idppCHSbMw (提取码: yff2)(这个是本文用到的版本)
注:貌似这个地址会被百度网盘和谐掉,我不知道为什么,如果这个下载不了,那就只能去上面的discuz包下载地址去下载x3.4版本的包,如果discuz包下载地址也进不去,那就只能通过上面的discuz应用中心地址页面最下面的Discuz程序下载链接去Discuz官方论坛找了。
3、准备工作
mysql:
地址:192.168.18.129
端口:3306
用户:root
密码:123456
数据库:ultrax(论坛)、ucenter(用户中心)这两个数据库实现创建好
redis:
地址:192.168.18.129
端口:6379
通过上面的百度云下载php和discuz的压缩包,将php-5.6.38-nts-Win32-VC11-x64.zip解压到D:php,作为php的安装目录,进入安装目录,复制一份php.ini-production,重命名为php.ini,使用文本打开后,修改配置并启用一下模块(去掉前面的分号):
#取消以下配置参数前面的分号和修改值
extension_dir = "D:phpext" #设置php模块路径为同目录下ext文件夹
date.timezone = Asia/Shanghai #设置时区为中国时区
cgi.force_redirect= 0 #开启以CGI方式运行php
fastcgi.impersonate= 1
extension=php_mysql.dll
extension=php_mysqli.dll
extension=php_pdo_mysql.dll
discuz压缩包中upload的就是discuz的项目文件,将它解压出来,我这里的解压目录是C:inetpubwwwrootdiscuz
使用文本编辑打开config中的config_global_default.php和config_ucenter_default.php,然后分别配置数据库信息和redis
编辑config_global_default.php,并重命名为config_global.php:
<?php /** * [Discuz!] (C)2001-2099 Comsenz Inc. * This is NOT a freeware, use is subject to license terms * * $Id: config_global_default.php 36362 2017-02-04 02:02:03Z nemohou $ */ $_config = array(); // ---------------------------- CONFIG DB ----------------------------- // // ---------------------------- 数据库相关设置---------------------------- // /** * 数据库主服务器设置, 支持多组服务器设置, 当设置多组服务器时, 则会根据分布式策略使用某个服务器 * @example * $_config['db']['1']['dbhost'] = 'localhost'; // 服务器地址 * $_config['db']['1']['dbuser'] = 'root'; // 用户 * $_config['db']['1']['dbpw'] = 'root';// 密码 * $_config['db']['1']['dbcharset'] = 'gbk';// 字符集 * $_config['db']['1']['pconnect'] = '0';// 是否持续连接 * $_config['db']['1']['dbname'] = 'x1';// 数据库 * $_config['db']['1']['tablepre'] = 'pre_';// 表名前缀 * * $_config['db']['2']['dbhost'] = 'localhost'; * ... * */ $_config['db'][1]['dbhost'] = '192.168.18.129'; $_config['db'][1]['dbuser'] = 'root'; $_config['db'][1]['dbpw'] = '123456'; $_config['db'][1]['dbcharset'] = 'utf8'; $_config['db'][1]['pconnect'] = 0; $_config['db'][1]['dbname'] = 'ultrax'; $_config['db'][1]['tablepre'] = 'pre_'; /** * 数据库从服务器设置( slave, 只读 ), 支持多组服务器设置, 当设置多组服务器时, 系统根据每次随机使用 * @example * $_config['db']['1']['slave']['1']['dbhost'] = 'localhost'; * $_config['db']['1']['slave']['1']['dbuser'] = 'root'; * $_config['db']['1']['slave']['1']['dbpw'] = 'root'; * $_config['db']['1']['slave']['1']['dbcharset'] = 'gbk'; * $_config['db']['1']['slave']['1']['pconnect'] = '0'; * $_config['db']['1']['slave']['1']['dbname'] = 'x1'; * $_config['db']['1']['slave']['1']['tablepre'] = 'pre_'; * $_config['db']['1']['slave']['1']['weight'] = '0'; //权重:数据越大权重越高 * * $_config['db']['1']['slave']['2']['dbhost'] = 'localhost'; * ... * */ $_config['db']['1']['slave'] = array(); //启用从服务器的开关 $_config['db']['slave'] = false; /** * 数据库 分布部署策略设置 * * @example 将 common_member 部署到第二服务器, common_session 部署在第三服务器, 则设置为 * $_config['db']['map']['common_member'] = 2; * $_config['db']['map']['common_session'] = 3; * * 对于没有明确声明服务器的表, 则一律默认部署在第一服务器上 * */ $_config['db']['map'] = array(); /** * 数据库 公共设置, 此类设置通常对针对每个部署的服务器 */ $_config['db']['common'] = array(); /** * 禁用从数据库的数据表, 表名字之间使用逗号分割 * * @example common_session, common_member 这两个表仅从主服务器读写, 不使用从服务器 * $_config['db']['common']['slave_except_table'] = 'common_session, common_member'; * */ $_config['db']['common']['slave_except_table'] = ''; /** * 内存服务器优化设置 * 以下设置需要PHP扩展组件支持,其中 memcache 优先于其他设置, * 当 memcache 无法启用时,会自动开启另外的两种优化模式 */ //内存变量前缀, 可更改,避免同服务器中的程序引用错乱 $_config['memory']['prefix'] = 'discuz_'; /* reids设置, 需要PHP扩展组件支持, timeout参数的作用没有查证 */ $_config['memory']['redis']['server'] = '192.168.18.129'; $_config['memory']['redis']['port'] = 6379; $_config['memory']['redis']['pconnect'] = 1; $_config['memory']['redis']['timeout'] = 0; $_config['memory']['redis']['requirepass'] = ''; /** * 是否使用 Redis::SERIALIZER_IGBINARY选项,需要igbinary支持,windows下测试时请关闭,否则会出>现错误Reading from client: Connection reset by peer * 支持以下选项,默认使用PHP的serializer * [重要] 该选项已经取代原来的 $_config['memory']['redis']['igbinary'] 选项 * Redis::SERIALIZER_IGBINARY =2 * Redis::SERIALIZER_PHP =1 * Redis::SERIALIZER_NONE =0 //则不使用serialize,即无法保存array */ $_config['memory']['redis']['serializer'] = 1; $_config['memory']['memcache']['server'] = ''; // memcache 服务器地址 $_config['memory']['memcache']['port'] = 11211; // memcache 服务器端口 $_config['memory']['memcache']['pconnect'] = 1; // memcache 是否长久连接 $_config['memory']['memcache']['timeout'] = 1; // memcache 服务器连接超时 $_config['memory']['apc'] = 0; // 启动对 APC 的支持 $_config['memory']['apcu'] = 0; // 启动对 APCu 的支持 $_config['memory']['xcache'] = 0; // 启动对 xcache 的支持 $_config['memory']['eaccelerator'] = 0; // 启动对 eaccelerator 的支持 $_config['memory']['wincache'] = 0; // 启动对 wincache 的支持 $_config['memory']['yac'] = 0; //启动对 YAC 的支持 $_config['memory']['file']['server'] = ''; // File 缓存存放目录,如设置为 data/cache/filecache ,设置后启动 File 缓存 // 服务器相关设置 $_config['server']['id'] = 1; // 服务器编号,多webserver的时候,用于标识当前服务器的ID // 附件下载相关 // // 本地文件读取模式; 模式2为最节省内存方式,但不支持多线程下载 // 1=fread 2=readfile 3=fpassthru 4=fpassthru+multiple $_config['download']['readmod'] = 2; // 是否启用 X-Sendfile 功能(需要服务器支持)0=close 1=nginx 2=lighttpd 3=apache $_config['download']['xsendfile']['type'] = 0; // 启用 nginx X-sendfile 时,论坛附件目录的虚拟映射路径,请使用 / 结尾 $_config['download']['xsendfile']['dir'] = '/down/'; // 页面输出设置 $_config['output']['charset'] = 'utf-8'; // 页面字符集 $_config['output']['forceheader'] = 1; // 强制输出页面字符集,用于避免某些环境乱码 $_config['output']['gzip'] = 0; // 是否采用 Gzip 压缩输出 $_config['output']['tplrefresh'] = 1; // 模板自动刷新开关 0=关闭, 1=打开 $_config['output']['language'] = 'zh_cn'; // 页面语言 zh_cn/zh_tw $_config['output']['staticurl'] = 'static/'; // 站点静态文件路径,“/”结尾 $_config['output']['ajaxvalidate'] = 0; // 是否严格验证 Ajax 页面的真实性 0=关闭,1=打开 $_config['output']['iecompatible'] = 0; // 页面 IE 兼容模式 // COOKIE 设置 $_config['cookie']['cookiepre'] = 'discuz_'; // COOKIE前缀 $_config['cookie']['cookiedomain'] = ''; // COOKIE作用域 $_config['cookie']['cookiepath'] = '/'; // COOKIE作用路径 // 站点安全设置 $_config['security']['authkey'] = 'asdfasfas'; // 站点加密密钥 $_config['security']['urlxssdefend'] = true; // 自身 URL XSS 防御 $_config['security']['attackevasive'] = 0; // CC 攻击防御 1|2|4|8 $_config['security']['querysafe']['status'] = 1; // 是否开启SQL安全检测,可自动预防SQL注入攻击 $_config['security']['querysafe']['dfunction'] = array('load_file','hex','substring','if','ord','char'); $_config['security']['querysafe']['daction'] = array('@','intooutfile','intodumpfile','unionselect','(select', 'unionall', 'uniondistinct'); $_config['security']['querysafe']['dnote'] = array('/*','*/','#','--','"'); $_config['security']['querysafe']['dlikehex'] = 1; $_config['security']['querysafe']['afullnote'] = 0; $_config['security']['creditsafe']['second'] = 0; // 开启用户积分信息安全,可防止并发刷分,满足 times(次数)/second(秒) 的操作无法提交 $_config['security']['creditsafe']['times'] = 10; $_config['admincp']['founder'] = '1'; // 站点创始人:拥有站点管理后台的最高权限,每个站点可以设置 1名或多名创始人 // 可以使用uid,也可以使用用户名;多个创始人之间请使用逗号“,”分开; $_config['admincp']['forcesecques'] = 0; // 管理人员必须设置安全提问才能进入系统设置 0=否, 1=是[安全] $_config['admincp']['checkip'] = 1; // 后台管理操作是否验证管理员的 IP, 1=是[安全], 0=否。仅在管理员无法登陆后台时设置 0。 $_config['admincp']['runquery'] = 0; // 是否允许后台运行 SQL 语句 1=是 0=否[安全] $_config['admincp']['dbimport'] = 1; // 是否允许后台恢复论坛数据 1=是 0=否[安全] /** * 系统远程调用功能模块 */ // 远程调用: 总开关 0=关 1=开 $_config['remote']['on'] = 0; // 远程调用: 程序目录名. 出于安全考虑,您可以更改这个目录名, 修改完毕, 请手工修改程序的实际目录 $_config['remote']['dir'] = 'remote'; // 远程调用: 通信密钥. 用于客户端和本服务端的通信加密. 长度不少于 32 位 // 默认值是 $_config['security']['authkey'] 的 md5, 您也可以手工指定 $_config['remote']['appkey'] = md5($_config['security']['authkey']); // 远程调用: 开启外部 cron 任务. 系统内部不再执行cron, cron任务由外部程序激活 $_config['remote']['cron'] = 0; // $_GET|$_POST的兼容处理,0为关闭,1为开启;开启后即可使用$_G['gp_xx'](xx为变量名,$_GET和$_POST集合的所有变量名),值为已经addslashes()处理过 $_config['input']['compatible'] = 1; // Addon Setting //$_config['addonsource'] = 'xx1'; //$_config['addon'] = array( // 'xx1' => array( // 'website_url' => 'http://127.0.0.1/AppCenter', // 'download_url' => 'http://127.0.0.1/AppCenter/index.php', // 'download_ip' => '', // 'check_url' => 'http://127.0.0.1/AppCenter/?ac=check&file=', // 'check_ip' => '' // ) //); ?>
编辑config_ucenter_default.php并重命名为config_ucenter.php:
<?php /** * [Discuz!] (C)2001-2099 Comsenz Inc. * This is NOT a freeware, use is subject to license terms * * $Id: config_ucenter_default.php 11023 2010-05-20 02:23:09Z monkey $ */ // ============================================================================ define('UC_CONNECT', 'mysql'); // 连接 UCenter 的方式: mysql/NULL, 默认为空时为 fscoketopen(), mysql 是直接连接的数据库, 为了效率, 建议采用 mysql // 数据库相关 (mysql 连接时) define('UC_DBHOST', '192.168.18.129'); // UCenter 数据库主机 define('UC_DBUSER', 'root'); // UCenter 数据库用户名 define('UC_DBPW', '123456'); // UCenter 数据库密码 define('UC_DBNAME', 'ucenter'); // UCenter 数据库名称 define('UC_DBCHARSET', 'utf8'); // UCenter 数据库字符集 define('UC_DBTABLEPRE', '`ucenter`.uc_'); // UCenter 数据库表前缀 define('UC_DBCONNECT', '0'); // UCenter 数据库持久连接 0=关闭, 1=打开 // 通信相关 define('UC_KEY', 'yeN3g9EbNfiaYfodV63dI1j8Fbk5HaL7W4yaW4y7u2j4Mf45mfg2v899g451k576'); // 与 UCenter 的通信密钥, 要与 UCenter 保持一致 define('UC_API', 'http://localhost/ucenter/branches/1.5.0/server'); // UCenter 的 URL 地址, 在调用头像时依赖此常量 define('UC_CHARSET', 'utf-8'); // UCenter 的字符集 define('UC_IP', '127.0.0.1'); // UCenter 的 IP, 当 UC_CONNECT 为非 mysql 方式时, 并且当前应用服务器解析域名有问题时, 请设置此值 define('UC_APPID', '1'); // 当前应用的 ID // ============================================================================ define('UC_PPP', '20'); ?>
同时,将C:inetpubwwwrootdiscuz目录权限添加到Everyone,右键C:inetpubwwwrootdiscuz,选择【安全】选项卡,添加用户Everyone,并给予可读可写的权限;
4、IIS部署discuz
新建站点:
添加模块映射,请求路径:*.php 模块:FastCgiModule 可执行文件:D:phpphp-cgi.exe D:php是php的安装目录
添加默认文档:index.php
运行站点之后,打开浏览器输入http://localhost:82 ,就可以打开discuz的安装向导了
同意之后,进入环境检查页面,看页面是否全部都是绿的的勾勾,是的话进入下一步,不是则逐个处理:
设置运行环境,我这里选择【全新安装 Discuz! X (含 UCenter Server)】
安装数据库,这个配置是前面我们配置过了,所以只需要添加管理员账号即可:
点击下一步即开始安装:
到这里discuz安装即完成了,可以在浏览器直接输入http://localhost:82进入,我们还可以使用上面添加的管理员账号进入http://localhost:82/admin.php进入后台管理员页面,可以进行人员管理,邮件设置等等功能,还能检验discuz安装是否完善等等,这就是后台操作的东西了: