• IIS部署php项目——discuz论坛


      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_global.php

      编辑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');
    
    ?>
    config_ucenter.php

      同时,将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安装是否完善等等,这就是后台操作的东西了:

      

        

  • 相关阅读:
    决定迁移过来,深耕于此。。。
    一篇搞定MongoDB
    一篇搞定vue请求和跨域
    自定义全局组件
    一篇搞定vue-router
    一篇搞定Vuex
    vue系列
    .Vue.js大全
    一篇搞定spring Jpa操作数据库
    自定义admin
  • 原文地址:https://www.cnblogs.com/shanfeng1000/p/12342372.html
Copyright © 2020-2023  润新知