win7系统搭建PHP+Mysql+Apache环境+部署ecshop项目

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 这篇文章介绍了如何在Windows 7系统上搭建PHP、MySQL和Apache环境,并部署ECShop项目,包括安装配置步骤、解决常见问题以及使用XAMPP集成环境的替代方案。

安装环境背景:Win7 x64位系统,搭建PHP+MySQL+Apache环境,实现ECshop项目开发。
1、下载php最新安装包php-7.0.10RC1-Win32-VC14-x64;提示:需要vc++14 运行库 才能运行php.exe

2、下载并安装mysql,用户名root;密码root。这里不作过多说明;

3、下载Apache_HTTP_Server_2.4.12_JiSuXia,解压即可,运行httpd.exe会报错;修改conf/httpd.conf文件;

主要注意以下几点(安装文件目录中间不要携带空格):

3.1、Define SRVROOT “D:\httpd” ServerRoot “${SRVROOT}” 设置默认路径:SRVROOT “D:/…”

3.2、设置路径(绝对路径),例如:LoadModule actions_module D:/httpd/modules/mod_actions.so

3.3、需要注意3.1设置的SRVROOT 路径在配置文件中的引用${SRVROOT}

4、以上步骤就准备好了编译php文件的环境,但是apache和php还没有完全配置正确,接下来需要配置两边的配置文件;

  • 4.1、Apache配置httpd.conf文件,在conf文件最下添加如下配置信息,主要说明:PHPIniDir 指向php安装目录;LoadModule加载php运行#BEGIN PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL
    #END PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL
    #php\_flag display\_errors on
    #php\_value error\_reporting 2039
    #END PHP INSTALLER EDITS - REMOVE ONLY ON UNINSTALL
    

4.2、复制php安装目录下的php.ini-development文件,更名:php.ini 并编辑,设置

extension_dir <绝对路径>= “D:/php7/ext” and date.timezone = prc;去掉下图的注释即可;php_mysql.dll

5、OK,以上php+mysql+apache环境已经搭建起来了。接下来下载ecshop源码包;解压只需upload部分;

httpd启动服务会默认打开项目文件htdocs,将解压的upload放置htdocs目录下并更名ecshop即可;

6、cmd命令窗口添加httpd.exe服务到services列表,先cd到apache/bin目录:httpd.exe -k install

7、http://localhost:80/ecshop/index.php 即可安装部署ecshop项目;sc delete 服务名<删除services服务>

8、安装ecshop到第二步检查环境,提示:mysql不支持、jpg不支持(涉及ecshop文件lib_installer、cls_image、cls_ecshop)top上方提示:lib_installer提示第31行: return cls_image::gd_version(); Non-static gd_version(),在php语法中:: 运算需要设置静态方法;网上找到解决方案:置换这一块内容;我没有成功!是在cls_image文件中将gd_version()方法申明static静态方法;jpg不支持是在lib_installer jpeg_enabled = (gd_info[‘JPG Support’] 改成 jpeg_enabled = (gd_info[‘JPEG Support’];

9、以上问题,在网上找答案均未成功!

Strict Standards: Non-static method cls_image::gd_version() should not be called statically in E:\web\shopex\includes\lib_base.php on line 346

PHP 5.3版本以上会出现这个错误。

在346行里面,发现gd_version()方法未声明静态static,所以会出错:

return cls_image::gd_version();

改成:

$p = new cls_image();

return $p->gd_version();

目录权限检测 一片红 不可写 是ecshop项目目录权限不够 chmod -R 777 ecshop 即可

10、下载xampp软件集成php+tomcat+apache+mysql;一键安装,ecshop没有报错!

http://localhost:80/ecshop/index.php 安装完成!数据库mysql+管理员xup2012+商品种类+关闭留言验证码;

http://localhost/ecshop/admin 后台管理登录

11、集成的mysql+tomcat,想要把原来的安装的软件全部复制到xampp对应的mysql+tomcat目录;

注意tomcat的环境变量,改变路径;mysql需要注意保留C:\ProgramData\MySQL\MySQL server 5.5\data这些数据;

在mysql/bin目录下修改basedir=“D:\xampp\MySQL\”及datadir=“C:\ProgramData\MySQL\MySQL server 5.5\data”

12、Ecshop 2.7 报错原因是cls_template.php在php高版本5.3以上导致的:

  • Deprecated: preg_replace(): The /e modifier is deprecated, use preg_replace_callback instead …line:288编辑找到cls_template.php页面修改第288行,换成下面这还代码:

    return preg\_replace\_callback("/{(\[^\\}\\{\\n\]\*)}/", function($r) { return t h i s − > s e l e c t ( this->select( this−\>select(r\[1\]); }, $surce
    
  • Strict Standards: Only variables should be passed by reference in D:\xampp…7C0D8828A2FA23C669A5614F73F3AE8A

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
12天前
|
开发框架 前端开发 中间件
开源PHP项目
【9月更文挑战第2天】开源PHP项目
25 4
|
20天前
|
应用服务中间件 Linux 网络安全
【Azure 应用服务】PHP应用部署在App Service for Linux环境中,上传文件大于1MB时,遇见了413 Request Entity Too Large 错误的解决方法
【Azure 应用服务】PHP应用部署在App Service for Linux环境中,上传文件大于1MB时,遇见了413 Request Entity Too Large 错误的解决方法
|
20天前
|
Linux PHP
【Azure 应用服务】PHP项目部署到App Service for Linux环境中,如何修改上传文件大小的限制呢?
【Azure 应用服务】PHP项目部署到App Service for Linux环境中,如何修改上传文件大小的限制呢?
|
21天前
|
存储 关系型数据库 Linux
【Azure 应用服务】App Service For Linux 部署PHP Laravel 项目,如何修改首页路径为 wwwroot\public\index.php
【Azure 应用服务】App Service For Linux 部署PHP Laravel 项目,如何修改首页路径为 wwwroot\public\index.php
|
23天前
|
应用服务中间件 Linux PHP
Linux搭建tengine2.0<Nginx>+php7环境
本文介绍了在Linux系统上搭建Tengine 2.0(一个Nginx的增强版本)和PHP 7环境的详细步骤,包括创建安装目录、下载源码包及依赖库、编译安装Nginx、配置Nginx、安装PHP及其依赖、设置PHP-FPM、配置环境变量、安装Git和Composer,以及服务管理和日志查看等。
49 0
|
23天前
|
SQL 关系型数据库 MySQL
【揭秘】MySQL binlog日志与GTID:如何让数据库备份恢复变得轻松简单?
【8月更文挑战第22天】MySQL的binlog日志记录数据变更,用于恢复、复制和点恢复;GTID为每笔事务分配唯一ID,简化复制和恢复流程。开启binlog和GTID后,可通过`mysqldump`进行逻辑备份,包含binlog位置信息,或用`xtrabackup`做物理备份。恢复时,使用`mysql`命令执行备份文件,或通过`innobackupex`恢复物理备份。GTID模式下的主从复制配置更简便。
107 2
|
18天前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!点击阅读原文完成实验就可获得一本日历哦~
|
22天前
|
关系型数据库 MySQL 数据库
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
RDS MySQL灾备服务协同解决方案构建问题之数据库备份数据的云上云下迁移如何解决
|
19天前
|
人工智能 小程序 关系型数据库
【MySQL】黑悟空都掌握的技能,数据库隔离级别全攻略
本文以热门游戏《黑神话:悟空》为契机,深入浅出地解析了数据库事务的四种隔离级别:读未提交、读已提交、可重复读和串行化。通过具体示例,展示了不同隔离级别下的事务行为差异及可能遇到的问题,如脏读、不可重复读和幻读等。此外,还介绍了在MySQL中设置隔离级别的方法,包括全局和会话级别的调整,并通过实操演示了各隔离级别下的具体效果。本文旨在帮助开发者更好地理解和运用事务隔离级别,以提升数据库应用的一致性和性能。
96 2
【MySQL】黑悟空都掌握的技能,数据库隔离级别全攻略
|
24天前
|
数据可视化 关系型数据库 MySQL
Mysql8 如何在 Window11系统下完成跳过密钥校验、完成数据库密码的修改?
这篇文章介绍了如何在Windows 11系统下跳过MySQL 8的密钥校验,并通过命令行修改root用户的密码。
Mysql8 如何在 Window11系统下完成跳过密钥校验、完成数据库密码的修改?

推荐镜像

更多