[PHP]关联和操作MySQL数据库然后将数据库部署到ECS

在Mac电脑上使用VS Code进行PHP开发并关联操作MySQL数据库,然后将数据库部署到ECS。

1.安装PHP和MySQL

确保你的Mac上已经安装了PHP和MySQL。你可以使用Homebrew来安装它们:

$ brew install php 
$ brew install mysql

安装mysql完成后记住这一句:

MySQL is configured to only allow connections from localhost by default

To connect run:
    mysql -u root

使用以下命令查询安装情况:

$ php -v
$ mysql --version

启动MySQL服务:

$ brew services start mysql

重启MySQL服务:

$ brew services restart mysql

停止MySQL服务:

$ brew services stop mysql

2.创建MySQL用户、数据库和权限

登录到MySQL:

// 无密码直接用这一句登录
$ mysql -u root
// 也可以用这指令,输密码是直接回车跳过就是
$ mysql -u root -p

创建新数据库:

$ CREATE DATABASE mydatabase;

创建新用户并设置密码(替换myuser和mypassword为你自己的设置):

$ CREATE USER'myuser'@'localhost' IDENTIFIED BY'mypassword';

授权新用户访问数据库:

$ GRANT ALL PRIVILEGES ON mydatabase.*TO'myuser'@'localhost';

刷新权限:

$ FLUSH PRIVILEGES;

退出MySQL:

$ EXIT;

3.配置PHP连接MySQL

你需要在PHP代码中使用PDO或mysqli扩展来连接MySQL数据库。

确保你的MySQL服务正在运行,并且你已经创建了相应的用户、数据库和权限。

1).PDO

<?php
$host = '127.0.0.1';
$db   = 'your_database';
$user = 'your_username';
$pass = 'your_password';
$charset = 'utf8mb4';

$dsn = "mysql:host=$host;dbname=$db;charset=$charset";
$options = [
    PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
    PDO::ATTR_EMULATE_PREPARES   => false,
];

try {
    $pdo = new PDO($dsn, $user, $pass, $options);
} catch (\PDOException $e) {
    throw new \PDOException($e->getMessage(), (int)$e->getCode());
}
?>

2).mysqli扩展

<?php

// 数据库连接配置
$host = 'localhost';
$dbname = 'mydatabase';
$username = 'myusername';
$password = 'mypassword';

// 创建 mysqli 连接对象
$conn = new mysqli($host, $username, $password, $dbname);

// 检查连接是否成功
if ($conn->connect_error) {
    die("连接失败: " . $conn->connect_error);
}

// 执行查询语句
$query = "SELECT * FROM users";
$result = $conn->query($query);

// 处理结果集
if ($result->num_rows > 0) {
    while ($row = $result->fetch_assoc()) {
        echo $row['username'] . "<br>";
    }
} else {
    echo "没有结果";
}

// 关闭数据库连接
$conn->close();

?>

4.在VS Code中编写和运行PHP代码

index.html

<!DOCTYPE html>
<html>
<head>
    <title>城市信息表单</title>
</head>
<body>
    <h1>城市信息表单</h1>
    <form action="http://localhost:8080/city.php" method="post">
        <label for="cityName">城市名称:</label>
        <input type="text" id="name" name="name" required><br><br>

        <label for="cityCode">城市编码:</label>
        <input type="text" id="code" name="code" required><br><br>

        <label for="cityCode">增删改查:</label>
        <input type="text" id="mark" name="mark" required><br><br>

        <input type="submit" value="提交">
    </form>

    <p id="jsonResponse"></p>

    <script>
        document.querySelector('form').addEventListener('submit', function (event) {
            event.preventDefault();
            // 方式一:PHP 中使用这种方式获取 $name = $_POST['name'] ?? '';
            var form = event.target;
            var formData = new FormData(form);
            fetch(form.action, {
                method: 'POST',
                body: formData
            })
            .then(response => response.json())
            .then(data => {
                document.getElementById('jsonResponse').textContent = JSON.stringify(data);
            })
            .catch(error => console.error('请求接口失败', error));

            /*
            // 方式二:PHP中用这种方式获取 $data = json_decode(file_get_contents('php://input'), true);  $name = $data['name'] ?? '';
            var form = event.target;
            var name = form.elements.name.value;
            var code = form.elements.code.value;
            var mark = form.elements.mark.value;
            var requestData = {
                name: name,
                code: code,
                mark: parseInt(mark) // mark 1:增 2:删 3:改 4:查
            };

            var xhr = new XMLHttpRequest();
            xhr.open('POST', form.action);
            xhr.setRequestHeader('Content-Type', 'application/json');
            // xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
            xhr.onload = function () {
                if (xhr.status === 200) {
                    var data = JSON.parse(xhr.responseText);
                    document.getElementById('jsonResponse').textContent = JSON.stringify(data);
                } else {
                    console.error('请求接口失败');
                }
            };
            xhr.send(JSON.stringify(requestData));
            */
        });
    </script>
</body>
</html>

pdoConnect.php

<?php
$host = '127.0.0.1';
$db = 'city_database';
$user = 'gamin';
$pass = '123456';
$charset = 'utf8mb4';

$dsn = "mysql:host=$host;dbname=$db;charset=$charset";
$options = [
    PDO::ATTR_ERRMODE            => PDO::ERRMODE_EXCEPTION,
    PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC,
    PDO::ATTR_EMULATE_PREPARES   => false,
];

// 连接数据库
try {
    $pdo = new PDO($dsn, $user, $pass, $options);
    createCitiesTable();
} catch (\PDOException $e) {
    throw new \PDOException($e->getMessage(), (int)$e->getCode());
}

// 创建城市表
function createCitiesTable() {
    $tb_name = "cities";
    // 检查表是否已存在
    $isTableExists = checkTableExists($tb_name);
    if (!$isTableExists) { 
        // 创建表
        $sql = "CREATE TABLE $tb_name (
            id INT AUTO_INCREMENT PRIMARY KEY,
            name VARCHAR(255) NOT NULL,
            code INT NOT NULL
        )";
        global $pdo;
        $pdo->exec($sql);
    } else {
         
    }
}

// 检查表是否存在
function checkTableExists($tableName) {
    global $pdo;
    $stmt = $pdo->query("SHOW TABLES LIKE '$tableName'");
    return $stmt->rowCount() > 0;
}

?>

sqlOperation.php

<?php
require "pdoConnect.php";

function pdo() {
    global $pdo;
    if (isset($pdo)) {
        return $pdo;
    } else {
        // 处理 $pdo 未初始化的情况
        return null;
    }
}

// 改变数据 插入|更新|删除
function changeData(string $sql, array $arr) {
    $stmt = pdo()?->prepare($sql);
    $result = $stmt?->execute($arr);
    return $result;
}

// 查询数据
function findData(string $sql, array $arr) {
    $stmt = pdo()?->prepare($sql);
    $stmt?->execute($arr);
    $result = $stmt?->fetch();
    return $result;
}

?>

output.php

<?php

class ErrorCode {
    const FAILURE = -1;
    const SUCCESS = 0;
    const INVALID_INPUT = 100;
    const MISSING_PARAMETER = 101;
    const DATABASE_ERROR = 200;
    const FILE_NOT_FOUND = 201;
    const METHOD_NOT_ALLOW = 405;
    const INTERNAL_SERVER_ERROR = 500;
    const DATA_NOT_FOUND = 1000;

    public static function getErrorMessage($errorCode) {
        switch ($errorCode) {
            case self::FAILURE:
                return "Operation failed.";
            case self::SUCCESS:
                return "Operation succeeded.";
            case self::INVALID_INPUT:
                return "Invalid input provided.";
            case self::MISSING_PARAMETER:
                return "Required parameter is missing.";
            case self::DATABASE_ERROR:
                return "Database error occurred.";
            case self::FILE_NOT_FOUND:
                return "File not found.";
            case self::METHOD_NOT_ALLOW:
                return "Method not allowed.";   
            case self::INTERNAL_SERVER_ERROR:
                return "Internal Server Error.";   
            case self::DATA_NOT_FOUND:
                return "No matching data found.";  
            default:
                return "Unknown error occurred.";
        }
    }
}

function outputJSON(int $errorCode, $data = []) {
    // 构建要返回的数据
    $response = [
        'code' => $errorCode,
        'message' => ErrorCode::getErrorMessage($errorCode),
        'data' => $data
     ];
    
    // 设置响应内容为 JSON 格式
    header('Content-Type: application/json');

    // 将数据转换为 JSON 字符串
    $json = json_encode($response);

    // 输出 JSON 字符串
    echo $json;
}

?>

city.php

<?php
require "sqlOperation.php";
require "output.php";

$tb_name = "cities";

// 检查POST数据
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
    /* 方式一: */
    // 获取数据并验证
    $name = $_POST['name'] ?? '';
    $code = $_POST['code'] ?? '';
    $mark = $_POST['mark'] ?? 0;

    /* 方式二:表单中Content-Type用'application/json'时,用这种方式获取传参 
    // 获取 JSON 数据并解析
    $data = json_decode(file_get_contents('php://input'), true);
    // 获取数据并验证
    $name = $data['name'] ?? '';
    $code = $data['code'] ?? '';
    $mark = $data['mark'] ?? 0;
    */

    if (empty($name) || empty($code) || $mark == 0) {
        outputJSON(ErrorCode::MISSING_PARAMETER);
        return;
    }

    // mark 1:增 2:删 3:改 4:查
    if ($mark == 1) {
        // 插入数据
        $result = changeData("INSERT INTO $tb_name (name, code) VALUES (:name, :code)", ['name' => $name, 'code' => $code]);
        if ($result) {
            outputJSON(errorCode::SUCCESS);
        } else {
            outputJSON(errorCode::FAILURE);
        }
    } else if ($mark == 2) {
        // 删除数据
        $result = changeData("DELETE FROM $tb_name WHERE code = :code", ['code' => $code]);
        if ($result) {
            outputJSON(errorCode::SUCCESS);
        } else {
            outputJSON(errorCode::FAILURE);
        }
    } else if ($mark == 3) {
        // 更新数据
        $result = changeData("UPDATE $tb_name SET name = :name WHERE code = :code", ['name' => $name, 'code' => $code]);
        if ($result) {
            outputJSON(errorCode::SUCCESS);
        } else {
            outputJSON(errorCode::FAILURE);
        }
    } else if ($mark == 4) {
        // 查询数据
        $result = findData("SELECT * FROM $tb_name WHERE code = :code", ['code' => $code]);
        if ($result) {
            // 查询成功,至少有一条匹配的数据
            outputJSON(errorCode::SUCCESS,$result);
        } else {
            // 查询失败,没有匹配的数据
            outputJSON(ErrorCode::DATA_NOT_FOUND);
        }
    }

    exit;
}

?>

cityList.php

<?php
require("pdoConnect.php");
require("output.php");

// 检查POST数据
if ($_SERVER['REQUEST_METHOD'] === 'POST') { 
    try {
        // 获取数据并验证
        $page = isset($_POST['page']) ? intval($_POST['page']) : 1; // 当前页码,默认为第一页
        $pageSize = isset($_POST['pageSize']) ? intval($_POST['pageSize']) : 10; // 每页数据条数,默认为 10

        // 对页码进行有效性检查
        $page = max(1, intval($page)); ;
        // 确保每页记录数为正整数
        $pageSize = max(1, intval($pageSize)); ;

        // 表名
        $tb_name = "cities";

        // 查询总记录数
        $countSql = "SELECT COUNT(*) AS total FROM $tb_name";
        $countStmt = $pdo->prepare($countSql);
        $countStmt->execute();
        $totalItems = $countStmt->fetchColumn();
        // 计算总页数
        $totalPages = ceil($totalItems / $pageSize);

        // 对页码进行有效性检查
        $page = min($page, $totalPages);
        // 计算偏移量
        $offset = ($page - 1) * $pageSize;

        // 查询当前页的数据
        $sql = "SELECT * FROM $tb_name LIMIT :offset, :pageSize";
        $stmt = $pdo->prepare($sql);
        $stmt->bindValue(':offset', $offset, PDO::PARAM_INT);
        $stmt->bindValue(':pageSize', $pageSize, PDO::PARAM_INT);
        $stmt->execute();

        $pagedData = $stmt->fetchAll(PDO::FETCH_ASSOC);

        // 构建要返回的数据
        $response = [
            'page' => $page,
            'pageSize' => $pageSize,
            'totalPages' => $totalPages,
            'totalItems' => $totalItems,
            'data' => array_map(function ($item) {
                return $item;
            }, $pagedData)
        ];
        outputJSON(ErrorCode::SUCCESS, $response);
    } catch (Exception $e) {
        // 发生错误时返回错误响应
        outputJSON(ErrorCode::INTERNAL_SERVER_ERROR);
    }
} else {
    // 非 POST 请求返回错误响应
    outputJSON(ErrorCode::METHOD_NOT_ALLOW);
}

?>

5.测试本地开发环境

在本地开发环境中测试你的PHP脚本,确保它可以正确地与MySQL数据库进行交互。

6.将MySQL数据库部署到ECS

1).创建ECS实例:登录到阿里云管理控制台,创建一个ECS实例。

2).安装MySQL:通过SSH连接到你的ECS实例,使用相应的包管理器安装MySQL。

3).配置MySQL:设置用户权限、创建数据库,并导入你的本地数据库数据到ECS上的MySQL实例。

4).更新你的PHP代码中的数据库连接信息,使其指向ECS实例上的MySQL。

7.部署PHP代码到ECS

1).将你的PHP代码上传到ECS实例。你可以使用FTP、SCP或者Git来传输文件。

2).配置Web服务器:在ECS上安装和配置Nginx或Apache作为Web服务器来处理PHP请求。

3).确保ECS的安全组规则允许访问MySQL和Web服务器的端口。

8.测试远程环境

在浏览器中访问你的ECS实例的公网IP地址,确保你的PHP应用能够正确地运行并连接到MySQL数据库。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/159426.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

opencv(4):颜色空间

文章目录 颜色空间RGB 人眼的色彩空间HSV 色彩空间HSLYUVYUV420&#xff1a;YUV422&#xff1a;YUV444&#xff1a; 颜色空间转换代码示例 颜色空间 不同色彩空间显示效果是不一样的。 RGB 人眼的色彩空间 HSV 色彩空间 HSV 代表色相&#xff08;Hue&#xff09;、饱和度&a…

电子学会C/C++编程等级考试2021年09月(一级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:数字判断 输入一个字符,如何输入的字符是数字,输出yes,否则输出no 输入 一个字符 输出 如何输入的字符是数字,输出yes,否则输出no 样例1输入 样例1输入 5样例1输出 yes样例2输入 A 样例2输出 …

软件质量保护与测试(第2版)学习总结第十一章 白盒测试

错误隐藏在角落里、集聚在边界处 ----Boris Beizer 白盒测试是看源代码的&#xff0c;静态分析和动态分析 11.2 控制流测试 程序结构主要有3种 顺序结构、分支结构、循环结构 #include "stdafx.h" …

今天遇到Windows 10里安装的Ubuntu(WSL)的缺点

随着技术的发展&#xff0c;越来越多开发者转向使用 Windows Subsystem for Linux&#xff08;WSL&#xff09;在 Windows 10 上进行开发&#xff0c;也就是说不用虚拟机&#xff0c;不用准备多一台电脑&#xff0c;只需要在Windows 10/11 里安装 WSL 就能体验 Linux 系统。因此…

CTFhub-RCE-过滤目录分隔符 /

根据源代码信息可知&#xff0c;过滤掉了/ <?php $res FALSE; if (isset($_GET[ip]) && $_GET[ip]) { $ip $_GET[ip]; $m []; if (!preg_match_all("/\//", $ip, $m)) { $cmd "ping -c 4 {$ip}"; exec($cmd,…

使用vant list实现订单列表,支持下拉加载更多

在公司项目开发时&#xff0c;有一个需求是实现可以分页的订单列表&#xff0c;由于是移动端项目&#xff0c;所以最好的解决方法是做下拉加载更多。 1.在页面中使用vant组件 <van-listv-model"loading":finished"finished"finished-text"没有更…

SpringMVC 进阶

SpringMVC 进阶 一、拦截器 SpringMVC 中 Interceptor 拦截器的主要作⽤是拦截⽤⼾的请求并进⾏相应的处理。⽐如通过它来进⾏权限验证&#xff0c;或者是来判断⽤⼾是否登陆等操作。对于 SpringMVC 拦截器的定义⽅式有两种&#xff1a; 实现接⼝&#xff1a;org.springfram…

C语言——冒泡排序

一、冒泡排序是什么 冒泡排序&#xff1a; 冒泡排序(Bubble Sort)&#xff0c;又被称为气泡排序或泡沫排序。升序时&#xff1a;它会遍历若干次需要排序的数列&#xff0c;每次遍历时&#xff0c;它都会从前往后依次的比较相邻两个数的大小&#xff1b;如果前者比后者大&#x…

黔院长 | 何为风邪?

中医上所说的风&#xff0c;也称风邪&#xff0c;是指受到外界侵犯&#xff08;外邪&#xff09;而感得风寒、风热、风湿等症状&#xff0c;导致人的免疫力下降。寒、湿、燥、暑、热等都属于外邪&#xff0c;多依附于风而入侵人体&#xff0c;因此风邪更多的是指一种致病因素。…

pythom导出mysql指定binlog文件

要求 要求本地有py环境和全局环境变量 先测试直接执行binlog命令执行命令 Windows 本地直接执行命令 # E:\output>E:\phpstudy_pro\Extensions\MySQL5.7.26\bin\mysqlbinlog binglog文件地址 # --no-defaults 不限制编码 # -h mysql链接地址 # -u mysql 链接名称 # -p m…

如何制作keil5的Device pack

概述&#xff1a; 作为一名嵌入式芯片相关行业人员&#xff0c;我们经常需要使用到Device pack, 比如STM32的pack如下图所示&#xff1a; 名词DFP&#xff1a; 设备家族包 DFP Pack组成&#xff1a; Boards (板级支持)Device &#xff08;芯片设备级支持&#xff09;Docum…

CI/CD 持续集成与持续交付(1)

git Git git使用 [rootserver1 ~]# yum install -y git [rootserver1 ~]# mkdir demo [rootserver1 ~]# cd demo/初始化版本库 [rootserver1 demo]# git init查看状态 [rootserver1 demo]# git status [rootserver1 demo]# git status -s #简化输出[rootserver1 demo]# echo…

第十一周任务总结

本周任务总结 本周物联网方面主要继续进行网关的二次开发与规则引擎实现设备联动的实现 非物联网方面主要复习了docker的使用与算法的学习 1.网关的二次开发&#xff0c;本周将实现debug调试输出的文件下载到了网关&#xff0c;但网关出了问题无法连接&#xff0c;最终跟客服…

SmartX 超融合 5.1 版本有哪些新特性和技术提升?

近日&#xff0c;SmartX 正式发布了超融合产品组合 SmartX HCI 5.1 版本&#xff0c;以全面升级的超融合软件、分布式块存储、容器管理与服务、软件定义的网络与安全等组件&#xff0c;为虚拟化和容器负载在计算、存储、网络和管理层面提供统一的架构和生产级别的能力支持。本期…

ArcGIS Maps SDK for JS:监听图层的visible属性

文章目录 1 问题描述2 解决方案3 拓展 1 问题描述 近期有这么一个需求。在 ArcGIS Maps SDK for JavaScript 中&#xff0c;使用图层的visible属性同步显示某个组件&#xff0c;即打开图层时显示组件&#xff0c;关闭图层时隐藏组件。 首先想到的是&#xff0c;通过点击图层列…

B站批量取消关注

找到关注页面&#xff1a; 右键检查或者按F12进入开发者界面 然后选console&#xff0c;在页面下面输入下面jQuery代码&#xff0c;然后按回车。复制粘贴两次这一页的博主就能全部取消大概20个 然后刷新页面&#xff0c;接着粘贴两边代码&#xff0c;循环如此即可。 $(".…

kubernetes集群编排——k8s高可用集群

实验环境 主机名 IP 角色 k8s1 192.168.92.11 harbor k8s2 192.168.92.12 control-plane k8s3 192.168.92.13 control-plane k8s4 192.168.92.14 control-plane k8s5 192.168.92.15 haproxy,pacemaker k8s6 192.168.92.16 haproxy,pacemaker k8s7 192.16…

duplicate复制数据库单个数据文件复制失败报错rman-03009 ora-03113

duplicate复制数据库单个数据文件复制失败报错rman-03009 ora-03113 搭建dg过程中&#xff0c;发现有一个数据文件在复制过程中没有复制过来&#xff0c;在备库数据文件目录找不到这个数据文件 处理方法&#xff1a; 第一步&#xff1a;主库备份86#数据文件 C:\Users\Admi…

【0235】修改私有内存(private memory)中的MyBEEntry时,st_changecount值前后变化

上一篇: 【0234】PgBackendStatus 记录当前postgres进程的活动状态 1. pg_stat_activity中xxx实时信息如何实现? 客户端(eg:psql)在连接上postmaster之后,postmaster守护进程会fork()一个后端进场(backend process),之后此客户端的所有操作、交互均有此对应的Backen…

实验七 状态机及键盘输入 chisel

题目 请设计一个区别两种特定时序的有限状态机FSM&#xff1a;该有限状态机有一个输入w和一个输出z。当w是4个连续的0或4个连续的1时&#xff0c;输出z1&#xff0c;否则z0&#xff0c;时序允许重叠。即&#xff1a;若w是连续的5个1时&#xff0c;则在第4个和第5个时钟之后&am…