当前位置: 首页 > news >正文

[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 defaultTo 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代码

 Demo:https://github.com/Gamin-fzym/php_test_demo

注意:使用Launch Built-in web server配置运行时,需要将"localhost:0"改成其它端口,不然每次运行都会随机生成端口号,很不方便。

{"name": "Launch Built-in web server","type": "php","request": "launch","runtimeArgs": ["-dxdebug.mode=debug","-dxdebug.start_with_request=yes","-S","localhost:8080"],"program": "","cwd": "${workspaceRoot}","port": 9003,"serverReadyAction": {"pattern": "Development Server \\(http://localhost:([0-9]+)\\) started","uriFormat": "http://localhost:%s/index.html","action": "openExternally"}
}

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

PDO连接MySQL封装

<?php
$host = '127.0.0.1';
$port = 3306; // MySQL默认的是3306端口
$db = 'city_database';
$user = 'gamin';
$pass = '123456';
$charset = 'utf8mb4';$dsn = "mysql:host=$host;port=$port;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;
}?>

output.php

输出封装

<?phpclass 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 "pdoConnect.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);}}}// 改变数据 插入|更新|删除
function changeData(string $sql, array $arr) {global $pdo;$stmt = $pdo->prepare($sql);$result = $stmt->execute($arr);return $result;
}// 查询数据
function findData(string $sql, array $arr) {global $pdo;$stmt = $pdo->prepare($sql);$stmt->execute($arr);$result = $stmt->fetch();return $result;
}?>

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服务:
$ brew services start mysql
登录到MySQL:
$ mysql -u root -p
授予相应的权限:
$ GRANT PROCESS ON *.* TO 'gamin'@'localhost';
刷新权限:
$ FLUSH PRIVILEGES;
退出MySQL:
$ EXIT;导出数据库:
格式
mysqldump -u [username] -p [database_name] > [filename].sql
示例
mysqldump -u gamin -p city_database > /Users/gamin/Desktop/files/city.sql

4).导入数据库到线上MySQL

设置用户权限、创建数据库,并导入你的本地数据库数据到ECS上的MySQL实例。也可以直接选择数据库的“管理”,进入管理页直接导入。

导入报了一个错,这个错误是由于 MySQL 不识别 utf8mb4_0900_ai_ci这个字符集校对规则引起的。这通常是因为 MySQL 版本较旧,不支持该特定的字符集校对规则。

将 utf8mb4_0900_ai_ci替换为 MySQL 支持的字符集校对规则,例如 utf8mb4_general_ci或utf8mb4_unicode_ci。修改导入文件中的创建表语句,将字符集校对规则修改为合适的值。

导入成功

5).设置数据库访问权限为指定IP

7.部署PHP代码到ECS

1).配置Web服务器

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

2).更新PHP代码中的数据库连接信息

使其指向ECS实例上的MySQL

<?php
$host = '121.43.232.240';
$port = 3306; // MySQL默认的是3306端口
$db = 'php_test_demo';
$user = 'php_test_demo';
$pass = 'iaTejKANGwWb6yLd';
$charset = 'utf8mb4';$dsn = "mysql:host=$host;port=$port;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;
}?>

3).将PHP代码部署到ECS

这里我就直接在宝塔中上传PHP文件了,当然直接传这样没版本管理不怎么科学。还可以使用FTP、SCP或者Git方式,传输文件。

4).去ECS的安全组放行3306端口

8.测试远程环境

为了便于测试,我将前面写的表单页面也部署到了站点上。

访问页面,经过测试,我们能正常查询到从本地导入到MySQL的数据,也能正常连接线上数据库执行其它操作。

https://www.lnktools.com/page/index.html

确保在部署到生产环境之前,你的应用已经通过了所有必要的安全和性能测试。此外,确保对敏感信息(如数据库凭据)进行加密,并在ECS实例上配置合适的安全措施。

相关文章:

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

在Mac电脑上使用VS Code进行PHP开发并关联操作MySQL数据库&#xff0c;然后将数据库部署到ECS。 1.安装PHP和MySQL 确保你的Mac上已经安装了PHP和MySQL。你可以使用Homebrew来安装它们&#xff1a; $ brew install php $ brew install mysql 安装mysql完成后记住这一句: …...

23.11.19日总结

经过昨天的中期答辩&#xff0c;其实可以看出来项目进度太慢了&#xff0c;现在是第十周&#xff0c;预计第十四周是终级答辩&#xff0c;在这段时间要把项目写完。 前端要加上一个未登录的拦截器&#xff0c;后端加上全局的异常处理。对于饿了么项目的商品建表&#xff0c;之前…...

系列一、JVM概述

一、概述 1.1、Java发展中的重大事件 1.2、虚拟机 vs Java虚拟机 1.2.1、虚拟机 1.2.2、Java虚拟机 1.2.3、Java虚拟机的作用 Java虚拟机是二进制字节码的运行环境&#xff0c;负责装载字节码到其内部&#xff0c;解释/编译为对应平台上的机器指令指令。每一条Java指令&#…...

milvus数据管理-压缩数据

Milvus 默认支持自动数据压缩。您可以 配置 Milvus 以启用或禁用 压缩 和自动压缩。 如果自动压缩被禁用&#xff0c;您仍然可以手动压缩数据。 1.手动压缩数据 压缩请求是异步处理的&#xff0c;因为它们通常需要花费很长时间。 from pymilvus import Collection collection…...

SpringBoot项目连接linux服务器数据库两种解决方法(linux直接开放端口访问本机通过SSH协议访问,以mysql为例)

最近找个springboot脚手架重新熟悉一下springboot相关框架的东西&#xff0c;结果发现好像项目还不能直接像数据库GUI工具一样填几个SSH参数就可以了&#xff0c;于是就给他再整一下看看如何解决 linux开放3306&#xff08;可修改&#xff09;端口直接访问 此方法较为方便&am…...

【Rust】快速教程——闭包与生命周期

前言 你怎么向天生的瞎子说清颜色&#xff1f;怎么用手势向天生的聋子描述声音&#xff1f; 鲜花就在眼前&#xff0c;雷鸣就在头顶&#xff0c;对他们来说却都毫无意义 眼睛看不到&#xff0c;鼻子可以嗅闻花香&#xff0c;耳朵听不见&#xff0c;手指可以触碰窗纸的震动。 犯…...

redis高级案列case

案列一 双写一致性 案例二 双锁策略 package com.redis.redis01.service;import com.redis.redis01.bean.RedisBs; import com.redis.redis01.mapper.RedisBsMapper; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; imp…...

Vue3+Vite实现工程化,attribute属性渲染v-bind指令

想要渲染一个元素的attribute&#xff0c;应该使用v-bind指令 由于插值表达式不能直接放在标签的属性中&#xff0c;所有要渲染元素的属性就应该使用v-bindv-bind可以用于渲染任何元素的属性&#xff0c;语法为 v-bind:属性名数据名&#xff0c;可以简写为 :属性名数据名 <…...

下一代搜索引擎会什么?

现在是北京时间2023年11月18日。聊一聊搜索。 说到搜索&#xff0c;大家首先想到的肯定是谷歌&#xff0c;百度。我把这些定义成上一个时代的搜索引擎。ChatGPT已经火热了有一年的时间了&#xff0c;大家都认为Ai搜索是下一代的搜索。但是AI搜索&#xff0c;需要的是很大算力&a…...

WPF中如何在MVVM模式下关闭窗口

完全来源于十月的寒流&#xff0c;感谢大佬讲解 使用Behaviors <Window x:Class"Test_03.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:b"http://schemas.microsoft.com/xaml/behaviors"xmlns:x&quo…...

【数据结构&C++】二叉平衡搜索树-AVL树(25)

前言 大家好吖&#xff0c;欢迎来到 YY 滴C系列 &#xff0c;热烈欢迎&#xff01; 本章主要内容面向接触过C的老铁 主要内容含&#xff1a; 欢迎订阅 YY滴C专栏&#xff01;更多干货持续更新&#xff01;以下是传送门&#xff01; 目录 一.AVL树的概念二.AVL树节点的定义(代码…...

Python算法——树的最大深度和最小深度

Python中的树的最大深度和最小深度算法详解 树的最大深度和最小深度是树结构中的两个关键指标&#xff0c;它们分别表示树的从根节点到最深叶子节点的最大路径长度和最小路径长度。在本文中&#xff0c;我们将深入讨论如何计算树的最大深度和最小深度&#xff0c;并提供Python…...

46.全排列-py

46.全排列 class Solution(object):def permute(self, nums):""":type nums: List[int]:rtype: List[List[int]]"""# 结果数组0ans[]nlen(nums)# 判断是否使用state_[False]*n# 临时状态数组dp_[]def dfs (index):# 终止条件if indexn:ans.appe…...

系列三、GC垃圾回收算法和垃圾收集器的关系?分别是什么请你谈谈

一、关系 GC算法&#xff08;引用计数法、复制算法、标记清除算法、标记整理算法&#xff09;是方法论&#xff0c;垃圾收集器是算法的落地实现。 二、4种主要垃圾收集器 4.1、串行垃圾收集器&#xff08;Serial&#xff09; 它为单线程环境设计&#xff0c;并且只使用一个线程…...

WPF中的虚拟化是什么

WPF&#xff08;Windows Presentation Foundation&#xff09;中的虚拟化是一种性能优化技术&#xff0c;它主要用于提高大量数据展示的效率。在WPF中&#xff0c;如果你有一个包含大量项的ItemsControl&#xff08;例如ListBox、ListView或DataGrid等&#xff09;&#xff0c;…...

免费稳定几乎无门槛,我的ChartGPT助手免费分享给你

公众号「架构成长指南」&#xff0c;专注于生产实践、云原生、分布式系统、大数据技术分享。 概述 ChatGPT想必大家应该都不陌生了&#xff0c;大部分人或多或少都接触了&#xff0c;好多应该都是通过openAi的官方进行使用的&#xff0c;这个门槛对大部分人有点高&#xff0c;…...

奇瑞金融:汽车金融行业架构设计

拆借联合贷款abs...

milvus数据库分区管理

一、创建分区 在创建集合时&#xff0c;会默认创建分区_default。 自己手动创建如下&#xff1a; from pymilvus import Collection collection Collection("book") # Get an existing collection. collection.create_partition("novel")二、检测分…...

pytorch.nn.Conv1d详解

通读了从论文中找的代码&#xff0c;终于找到这个痛点了&#xff01; 以下详解nn.Conv1d方法 1 参数说明 in_channels(int) – 输入信号的通道。 out_channels(int) – 卷积产生的通道。 kernel_size(int or tuple) - 卷积核的尺寸&#xff0c;经测试后卷积核的大小应为in_cha…...

大数据HCIE成神之路之数学(2)——线性代数

线性代数 1.1 线性代数内容介绍1.1.1 线性代数介绍1.1.2 代码实现介绍 1.2 线性代数实现1.2.1 reshape运算1.2.2 转置实现1.2.3 矩阵乘法实现1.2.4 矩阵对应运算1.2.5 逆矩阵实现1.2.6 特征值与特征向量1.2.7 求行列式1.2.8 奇异值分解实现1.2.9 线性方程组求解 1.1 线性代数内…...

音视频学习(十八)——使用ffmepg实现视音频解码

视频解码 初始化 视频常用的编解码器id定义&#xff08;以h264和h265为例&#xff09; // 定义在ffmpeg\include\libavcodec\avcodec.h AV_CODEC_ID_H264 AV_CODEC_ID_H265查找解码器&#xff1a;根据编解码id查看解码器 AVCodec* pCodecVideo avcodec_find_decoder(codec…...

nginx的GeoIP模块

使用场景 过滤指定地区/国家的IP&#xff0c;一般是国外IP禁止请求。 使用geoip模块实现不同国家的请求被转发到不同国家的nginx服务器&#xff0c;也就是根据国家负载均衡。 前置知识 GeoIP是什么&#xff1f; 官网地址 https://www.maxmind.com/en/home包含IP地址的地理位…...

mac控制台命令小技巧

shigen日更文章的博客写手&#xff0c;擅长Java、python、vue、shell等编程语言和各种应用程序、脚本的开发。记录成长&#xff0c;分享认知&#xff0c;留住感动。 hello伙伴们&#xff0c;作为忠实的mac骨灰级别的粉丝&#xff0c;它真的给我带来了很多效率上的提升。那作为接…...

Postman:API测试之Postman使用完全指南

Postman是一个可扩展的API开发和测试协同平台工具&#xff0c;可以快速集成到CI/CD管道中。旨在简化测试和开发中的API工作流。 Postman工具有Chrome扩展和独立客户端&#xff0c;推荐安装独立客户端。 Postman有个workspace的概念&#xff0c;workspace分personal和team类型…...

Flume学习笔记(3)—— Flume 自定义组件

前置知识&#xff1a; Flume学习笔记&#xff08;1&#xff09;—— Flume入门-CSDN博客 Flume学习笔记&#xff08;2&#xff09;—— Flume进阶-CSDN博客 Flume 自定义组件 自定义 Interceptor 需求分析&#xff1a;使用 Flume 采集服务器本地日志&#xff0c;需要按照日志…...

go的字符切片和字符串互转

Go 1.21 // 返回一个Slice&#xff0c;它的底层数组自ptr开始&#xff0c;长度和容量都是len func Slice(ptr *ArbitraryType, len IntegerType) []ArbitraryType // 返回一个指针&#xff0c;指向底层的数组 func SliceData(slice []ArbitraryType) *ArbitraryType // 生成一…...

所见即所得的动画效果:Animate.css

我们可以在集成Animate.css来改善界面的用户体验&#xff0c;省掉大量手写css动画的时间。 官网&#xff1a;Animate.css 使用 1、安装依赖 npm install animate.css --save2、引入依赖 import animate.css;3、在项目中使用 在class类名上animate__animated是必须的&#x…...

ERR:Navicat连接Sql Server报错

错误信息&#xff1a;报错&#xff1a;未发现数据源名称并且未指定默认驱动程序。 原因&#xff1a;Navicat没有安装Sqlserver驱动。 解决方案&#xff1a;在Navicat安装目录下找到sqlncli_x64.msi安装即可。 一键安装即可。 Navicat链接SQL Server配置 - MarchXD - 博客园 …...

python算法例10 整数转换为罗马数字

1. 问题描述 给定一个整数&#xff0c;将其转换为罗马数字&#xff0c;要求返回结果的取值范围为1~3999。 2. 问题示例 4→Ⅳ&#xff0c;12→Ⅻ&#xff0c;21→XⅪ&#xff0c;99→XCIX。 3. 代码实现 def int_to_roman(num):val [1000, 900, 500, 400,100, 90, 50, 40…...

springboot引入第三方jar包放到项目目录中,添加web.xml

参考博客&#xff1a;https://www.cnblogs.com/mask-xiexie/p/16086612.html https://zhuanlan.zhihu.com/p/587605618 1、在resources目录下新建lib文件夹&#xff0c;将jar包放到lib文件夹中 2、修改pom.xml文件 <dependency><groupId>com.lanren312</grou…...