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

day06-前后端项目上传到gitee、后端多方式登录接口、发送短信功能、发送短信封装、短信验证码接口、短信登录接口

1 前后端项目上传到gitee

2 后端多方式登录接口

2.1 序列化类
2.2 视图类
2.3 路由

3 发送短信功能

4 发送短信封装
4.0 目录结构
4.1 settings.py
4.2 sms.py

5 短信验证码接口

6 短信登录接口
6.1 视图类
6.2 序列化类

1 前后端项目上传到gitee

# 我们看到好多开源项目,前后端都在一个仓库中---》为了方便
# 正常咱们开发代码,一个项目一个仓库  # 1 后端仓库创建好了,提交过了---》继续提交git add .git commit -m '完成手机号校验功能'git push origin master# 2 前端创建远程仓库本地按上面命令,提交上即可(配置远程remote地址)

2 后端多方式登录接口

# 分析前端携带的数据:{username:用户名,手机号,邮箱,password:md5(密码)}注册的时候:密码也是md5加密后带过来的我们登录的时候,带的密码是md5加密的---》后端校验通不过# 后端:-request.data中取出来-校验用户名密码是否正确---》逻辑写到 序列类中-配合序列化类---》全局钩子中写逻辑,签发token-返回给前端# 总结:1 序列化类实例化得到对象时要ser=UserLoginSerializer(data=request.data)    data=request.data  不能传给第一个位置2 被 APIResponse 序列化的数据类型,必须是 数字,字符串,列表,字典,不能是其他对象类型3 配置文件中写了个 后台项目地址

2.1 序列化类

from .models import User
from rest_framework import serializers
import re
from rest_framework.exceptions import ValidationError
from rest_framework_jwt.serializers import jwt_payload_handler, jwt_encode_handler
from django.conf import settings# 只用来做校验
class UserLoginSerializer(serializers.Serializer):# 字段自己的校验规则会限制,不通过,因为是unique的username = serializers.CharField()password = serializers.CharField()def validate(self, attrs):# 1 校验用户名密码是否正确user = self._get_user(attrs)# 2 签发tokentoken = self._get_token(user)# 3 把签发的token和username放到context中self.context['username'] = user.usernameself.context['token'] = tokenself.context['icon'] = settings.BACKEND_URL + '/media/' + str(user.icon)# 4 返回attrsreturn attrsdef _get_user(self, attrs):username = attrs.get('username')password = attrs.get('password')if re.match(r'^1[3-9][0-9]{9}$', username):# 因为这个password是明文---》在数据库中存了密文,必须要使用  user.check_password校验用户秘钥# user=User.objects.filter(mobile=username,password=password)user = User.objects.filter(mobile=username).first()elif re.match(r'^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$', username):user = User.objects.filter(email=username).first()else:user = User.objects.filter(username=username).first()if user and user.check_password(password):return userelse:raise ValidationError('用户名或密码错误')def _get_token(self, user):payload = jwt_payload_handler(user)token = jwt_encode_handler(payload)return token

2.2 视图类

class UserLoginView(GenericViewSet):serializer_class = UserLoginSerializer# 没有用,就不需要写# queryset = None@action(methods=['POST'], detail=False)def mul_login(self, request, *args, **kwargs):ser = self.get_serializer(data=request.data)# ser=UserLoginSerializer(data=request.data)ser.is_valid(raise_exception=True)username = ser.context.get('username')token = ser.context.get('token')icon = ser.context.get('icon')# icon 必须是字符串形式,不能是对象形式# {code:100,msg:成功,token:asdfasf,icon:asdfasdf,username:asdfasd}return APIResponse(username=username, token=token, icon=icon)# {code:100,msg:成功,token:asdfasf,user:{id:1,username:xxx,icon:ssss}}# return APIResponse(token=token, user=ser.data) # 如果执行ser.data,就会走序列化

2.3 路由

# 127.0.0.1:8000/api/v1/user/login/mul_login/   ---post 请求
router.register('login', UserLoginView, 'login')

3 发送短信功能

# 需要借助于第三方---》腾讯云# python 脚本测试,能够成功发送短信# API和sdk的区别-API: 网络地址,有请求方式,向这个地址按照规则发送请求,就能完成某些操作---》以后只要使用第三方服务,大概率会提供给你api-sdk:集成开发工具包,第三方平台,用不同语言对api接口进行封装---》只要按照它的使用规则---》直接导入使用接口-可能没提供所有语言的sdk,不同语言要单独写-python的形式就是一个 包,把包下载下来-以后使用第三方,如果有sdk,优先用sdk,如果没有,只能用api# 下载sdk
pip install --upgrade tencentcloud-sdk-python

在这里插入图片描述

# -*- coding: utf-8 -*-
from tencentcloud.common import credential
from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
# 导入对应产品模块的client models。
from tencentcloud.sms.v20210111 import sms_client, models# 导入可选配置类
from tencentcloud.common.profile.client_profile import ClientProfile
from tencentcloud.common.profile.http_profile import HttpProfiletry:# 必要步骤:# 实例化一个认证对象,入参需要传入腾讯云账户密钥对secretId,secretKey。# 这里采用的是从环境变量读取的方式,需要在环境变量中先设置这两个值。# 您也可以直接在代码中写死密钥对,但是小心不要将代码复制、上传或者分享给他人,# 以免泄露密钥对危及您的财产安全。# SecretId、SecretKey 查询: https://console.cloud.tencent.com/cam/capicred = credential.Credential("", "")# 实例化一个http选项,可选的,没有特殊需求可以跳过。httpProfile = HttpProfile()# 如果需要指定proxy访问接口,可以按照如下方式初始化hp(无需要直接忽略)# httpProfile = HttpProfile(proxy="http://用户名:密码@代理IP:代理端口")httpProfile.reqMethod = "POST"  # post请求(默认为post请求)httpProfile.reqTimeout = 30  # 请求超时时间,单位为秒(默认60秒)httpProfile.endpoint = "sms.tencentcloudapi.com"  # 指定接入地域域名(默认就近接入)clientProfile = ClientProfile()client = sms_client.SmsClient(cred, "ap-guangzhou", clientProfile)req = models.SendSmsRequest()req.SmsSdkAppId = "1400861098"# 短信签名内容: 使用 UTF-8 编码,必须填写已审核通过的签名# 签名信息可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-sign) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-sign) 的签名管理查看req.SignName = "RoyHuang公众号"# 模板 ID: 必须填写已审核通过的模板 ID# 模板 ID 可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-template) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-template) 的正文模板管理查看req.TemplateId = "1951470"# 模板参数: 模板参数的个数需要与 TemplateId 对应模板的变量个数保持一致,,若无模板参数,则设置为空req.TemplateParamSet = ["8888",'10']req.PhoneNumberSet = ["+8613221296955"]# 用户的 session 内容(无需要可忽略): 可以携带用户侧 ID 等上下文信息,server 会原样返回req.SessionContext = ""# 短信码号扩展号(无需要可忽略): 默认未开通,如需开通请联系 [腾讯云短信小助手]req.ExtendCode = ""# 国内短信无需填写该项;国际/港澳台短信已申请独立 SenderId 需要填写该字段,默认使用公共 SenderId,无需填写该字段。注:月度使用量达到指定量级可申请独立 SenderId 使用,详情请联系 [腾讯云短信小助手](https://cloud.tencent.com/document/product/382/3773#.E6.8A.80.E6.9C.AF.E4.BA.A4.E6.B5.81)。req.SenderId = ""resp = client.SendSms(req)# 输出json格式的字符串回包print(resp.to_json_string(indent=2))except TencentCloudSDKException as err:print(err)

4 发送短信封装

4.0 目录结构

tx_sms__init__.pysettings.pysms.py

4.1 settings.py

	SECRET_ID=''SECRET_KEY=''APPID=''SIGN_NAME=''TEMPLATE_ID=''

4.2 sms.py

import random
from tencentcloud.common import credential
from tencentcloud.common.exception.tencent_cloud_sdk_exception import TencentCloudSDKException
from tencentcloud.sms.v20210111 import sms_client, models
from tencentcloud.common.profile.client_profile import ClientProfile
from tencentcloud.common.profile.http_profile import HttpProfile
from . import settingsimport json# 1 生成一个 固定长度的随机验证码(数字)
def get_code(number=4):code = ''for i in range(number):r = random.randint(0, 9)code += str(r)return code# 2 传入手机号和验证,发送短信功能函数
def send_sms(code, mobile):try:cred = credential.Credential(settings.SECRET_ID, settings.SECRET_KEY)httpProfile = HttpProfile()httpProfile.reqMethod = "POST"  # post请求(默认为post请求)httpProfile.reqTimeout = 30  # 请求超时时间,单位为秒(默认60秒)httpProfile.endpoint = "sms.tencentcloudapi.com"  # 指定接入地域域名(默认就近接入)clientProfile = ClientProfile()client = sms_client.SmsClient(cred, "ap-guangzhou", clientProfile)req = models.SendSmsRequest()req.SmsSdkAppId = settings.APPIDreq.SignName = settings.SIGN_NAMEreq.TemplateId = settings.TEMPLATE_IDreq.TemplateParamSet = [code, '1']req.PhoneNumberSet = ["+86" + mobile]resp = client.SendSms(req)print(resp.to_json_string(indent=2))response_data_dict = json.loads(resp.to_json_string(indent=2))if response_data_dict.get('SendStatusSet')[0].get('Code')=='Ok':return Trueelse:# 失败了,可以拿出message---》正常发送失败return Falseexcept Exception as err:# 发送过程中出了错误,失败return Falseif __name__ == '__main__':print(get_code())

5 短信验证码接口

class MobileView(ViewSet):@action(methods=['POST'], detail=False)def send_sms(self, request, *args, **kwargs):# 1 给谁发,手机号是从前端传入的,{mobile:18923434,code:'验证码'}  ---》我们的:{mobile:18923434}mobile = request.data.get('mobile')# 2 生成数字验证码code = get_code()# 3 数字验证码保存---》保存到哪?后续还能拿到---》放到缓存中---》默认放在内存中cache.set('cache_mobile_%s' % mobile, code)  # key 一定要唯一,后续还能取出来,就用手机号# 4 同步 发送短信---》同步发送--》可能前端会一直等待,耗时# res = send_sms_mobile(code, mobile)# if res:#     return APIResponse(msg='发送成功')# else:#     return APIResponse(code=101, msg='发送失败,请稍后再试')## 5 发送短信--》异步操作,使用多线程,无法知道短信是否成功了,不需要关注是否成功t=Thread(target=send_sms_mobile,args=[code,mobile])t.start()return APIResponse(msg='发送已发送')

6 短信登录接口

# 分析:前端携带的数据---{mobile:11111,code:8888}后端:-取出手机号验证码,验证验证码是否正确,如果正确-签发token-返回给前端

6.1 视图类

class UserLoginView(GenericViewSet):serializer_class = UserLoginSerializer# 没有用,就不需要写# queryset = None@action(methods=['POST'], detail=False)def mul_login(self, request, *args, **kwargs):return self._login(request, *args, **kwargs)@action(methods=['POST'], detail=False)def sms_login(self, request, *args, **kwargs):return self._login(request, *args, **kwargs)def get_serializer_class(self):# 判断,如果是sms_login,返回  短信登录的序列化类,其他情况就返回UserLoginSerializerif self.action == 'sms_login':return SMSLoginSerializerelif self.action == 'mul_login':return UserLoginSerializerelse:return super().get_serializer_class()def _login(self, request, *args, **kwargs):ser = self.get_serializer(data=request.data)  # 序列化类不一样,重写某个方法,实现,不同的请求action,返回的序列化类不一样ser.is_valid(raise_exception=True)username = ser.context.get('username')token = ser.context.get('token')icon = ser.context.get('icon')return APIResponse(username=username, token=token, icon=icon)

6.2 序列化类

class LoginSerializer(serializers.Serializer):def validate(self, attrs):# 1 校验用户名密码是否正确user = self._get_user(attrs)# 2 签发tokentoken = self._get_token(user)# 3 把签发的token和username放到context中self.context['username'] = user.usernameself.context['token'] = tokenself.context['icon'] = settings.BACKEND_URL + '/media/' + str(user.icon)# 4 返回attrsreturn attrsdef _get_user(self, attrs):passdef _get_token(self, user):payload = jwt_payload_handler(user)token = jwt_encode_handler(payload)return token# 只用来做校验
class UserLoginSerializer(LoginSerializer):# 字段自己的校验规则会限制,不通过,因为是unique的username = serializers.CharField()password = serializers.CharField()def _get_user(self, attrs):username = attrs.get('username')password = attrs.get('password')if re.match(r'^1[3-9][0-9]{9}$', username):# 因为这个password是明文---》在数据库中存了密文,必须要使用  user.check_password校验用户秘钥# user=User.objects.filter(mobile=username,password=password)user = User.objects.filter(mobile=username).first()elif re.match(r'^[a-zA-Z0-9_-]+@[a-zA-Z0-9_-]+(.[a-zA-Z0-9_-]+)+$', username):user = User.objects.filter(email=username).first()else:user = User.objects.filter(username=username).first()if user and user.check_password(password):return userelse:raise ValidationError('用户名或密码错误')class SMSLoginSerializer(LoginSerializer):mobile = serializers.CharField()code = serializers.CharField()def _get_user(self, attrs):mobile = attrs.get('mobile')code = attrs.get('code')# 1 校验code是否正确old_code = cache.get('cache_mobile_%s' % mobile)if old_code == code:# 2 根据手机号,取到用户user = User.objects.filter(mobile=mobile).first()if user:return userelse:raise ValidationError('手机号不存在')else:raise ValidationError('验证码错误')

相关文章:

day06-前后端项目上传到gitee、后端多方式登录接口、发送短信功能、发送短信封装、短信验证码接口、短信登录接口

1 前后端项目上传到gitee 2 后端多方式登录接口 2.1 序列化类 2.2 视图类 2.3 路由 3 发送短信功能 4 发送短信封装 4.0 目录结构 4.1 settings.py 4.2 sms.py 5 短信验证码接口 6 短信登录接口 6.1 视图类 6.2 序列化类 1 前后端项目上传到gitee # 我们看到好多开源项目…...

【SA8295P 源码分析 (一)】83 - SA8295P HQNX + Android 完整源代码下载方法介绍

【SA8295P 源码分析 一】83 - SA8295P HQNX + Android 完整源代码下载方法介绍 一、高通官网 Chipcode 下载步骤介绍1.1 高通Chipcode 下载步骤1.2 高通 ReleaseNote 下载方法二、高通 HQX 代码介绍2.1 完整的 HQX 代码结构:sa8295p-hqx-4-2-4-0_hlos_dev_qnx.tar.gz2.2 sa829…...

文献阅读快速法-ChatPDF

如题,直接提供给大家一款能够快速阅读文档的好工具——iTextMaster。 iTextMaster是一款免费的pdf阅读浏览器,上传pdf文档后等待几秒钟,AI就会自动反馈给用户关于文档的摘要总结。十分的方便且实用。 ChatPDF为您提供简洁的文档摘要。对于那…...

Jenkins 内存占用

查看内存占用 # ps aux | grep 9090 root 130854 0.0 0.0 8900 708 pts/1 S 16:23 0:00 grep --colorauto 9090 root 4010748 0.2 30.7 5826500 2502884 ? Ssl Oct13 8:55 /usr/bin/java -Djava.awt.headlesstrue -jar /usr/share/java/jenkins…...

1. vue-sy-admin: 基于vue3+TypeScript的全局过滤器(filters) 封装及示例

在vue3中使用全局filters已经不是必须,有很多种替代方案(直接定义函数即可)。如果项目中使用了unplugin-auto-import插件完全可以将filters导出函数使其在全局自动引入/声明。当然在这里就不说插件的使用了。下面就详细说说如何实现 题外话: 强烈推荐使用 vueuse&a…...

操作系统监控:守护您的计算机系统稳定运行的坚实防线

在数字化时代,计算机系统已成为各行业的关键支撑。为了保证系统的稳定运行,操作系统监控成为了不可或缺的技术手段。监控易运维管理软件,作为一款全面的监控解决方案,能够监控各类Windows、Linux、UNIX等操作系统,包括…...

PostgreSQL | CTE | 使用with子句的通用表达式

CTE(Common Table Expressions) 简单讲,CTE就是日常SQL中出现的with语句,其原理就是通过提前将数据查询出来后作为临时结果集使用,可以与SELECT \ INSERT \ UPDATE \ DELETE的SQL连用。 优点 可读性强 CTE 允许你将…...

A Close Look into the Calibration of Pre-trained Language Models

本文是LLM系列文章,针对《A Close Look into the Calibration of Pre-trained Language Models》的翻译。 预训练语言模型的校准研究 摘要1 引言2 背景3 评测指标4 PLM是否学会了校准?5 现有方法的效果如何?6 结论局限性与未来工作 摘要 预…...

【控制台】报错:Uncaught ReferenceError: process is not defined

文章目录 报错示例: 解决方法参考文献:https://github.com/vfile/vfile/issues/38...

Android自定义AppGlideModule,DataFetcher ,ModelLoaderFactory,ModelLoader,Kotlin(1)

Android自定义AppGlideModule,DataFetcher ,ModelLoaderFactory,ModelLoader,Kotlin(1) 假设实现一个简单的功能,对传入要加载的path路径增加一定的筛选、容错或“重定向”,需要自定义一个模型,基于这个模型,让Glide自动匹配模型…...

uni-app--》基于小程序开发的电商平台项目实战(五)

🏍️作者简介:大家好,我是亦世凡华、渴望知识储备自己的一名在校大学生 🛵个人主页:亦世凡华、 🛺系列专栏:uni-app 🚲座右铭:人生亦可燃烧,亦可腐败&#xf…...

新型的终端复用器 tmux

以前遇到长时间执行任务时,一般是使用nohup加后台运行,但是涉及到少量代码编写。 同事介绍了一个screen命令,根据文档,此命令已经过时,最新的命令是tmux。 tmux的介绍文档,RedHat的这一篇非常不错。 在文…...

标准化后端向前端传来的Json数据

后端响应固定格式给前端: 1,创建一个专门存储数据的类;分别存储响应状态码code,响应数据,传输的消息。 public class CommonData {int code;Object data;String message;public CommonData(int code, String message…...

java 两个list比较,删除相同的元素

概述 在Java开发中,经常需要比较两个List并删除相同的元素。本文将介绍整个流程,并提供相应的代码示例,帮助新手开发者完成这个任务。 流程 下面是比较两个List并删除相同元素的流程: 代码示例 创建两个List 我们首先需要创建两…...

7-3 zust-sy4-10 回文诗

7-3 zust-sy4-10 回文诗 分数 10 作者 张银南 单位 浙江科技学院 回文诗是汉语特有的一种使用词序回环往复的修辞方法,正着读反着读都可以。明末浙江才女吴绛雪作《四时山水诗》,如夏景诗:香莲碧水动风凉,水动风凉夏日长。长日夏凉风动水&…...

【数据结构】排序--插入排序(希尔排序)

目录 一 基本思想 二 直接插入排序 三 希尔排序 一 基本思想 把待排序的记录按其关键码值的大小逐个插入到一个已经排好序的有序序列中,直到所有的记录插入完为 止,得到一个新的有序序列 。 实际中我们玩扑克牌时,就用了插入排序的思想 二…...

“探寻服务器的无限潜能:从创意项目到在线社区,你会做什么?”

文章目录 每日一句正能量前言什么是服务器?服务器能做什么?服务器怎么用?部署创意项目,还是在线社区亦或做其他的?后记 每日一句正能量 未知的下一秒,千万不要轻言放弃。 前言 在数字化时代,服…...

5年经验之谈 —— 深入了解性能测试:方法、工具和最佳实践!

性能测试是软件开发生命周期中至关重要的一部分,它有助于确保应用程序在不同负载条件下都能够高效运行。在竞争激烈的市场中,性能问题可能导致用户流失,损害声誉,并损害业务。本文将深入探讨性能测试的方法、工具和最佳实践&#…...

动态加载sprite是multiple模式(即该sprite包含了很多小图)里的小图

在Unity中,Resources.Load()方法可以用来加载资源。如果要加载Sprite下的multiple模式的图片,你需要知道这些图片的路径。 首先,你需要把你想要加载的资源放在一个名为"Resources"的文件夹内。然后,你可以使用以下代码…...

大数据 DataX 详细安装教程

目录 一、环境准备 二、安装部署 2.1 二进制安装 2.2 python 3 支持 三、Data X 初体验 3.1 配置示例 3.1.1. 生成配置模板 3.1.2 创建配置文件 3.1.3 运行 DataX 3.1.4 结果显示 3.2 动态传参 3.2.1. 动态传参的介绍 3.2.2. 动态传参的案例 3.3 迸发设置 …...

2025届毕业生推荐的AI辅助写作平台推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 能协助研究者完成文献检索、框架构建以及语言润色的人工智能论文工具,是基于自然…...

Transformer原理探讨

Transformer模型自2017年Google提出以来,已成为深度学习领域最核心的架构之一,推动了自然语言处理、计算机视觉等领域的革命性发展。本教程将系统性地从零开始解析Transformer的原理与架构,帮助您深入理解这一改变AI格局的模型。 核心学习路径: 掌握序列建模背景知识与Tra…...

基于下垂控制的光储直流微电网模型 1.模型由光伏和储能以及直流负载组成 2.光伏采用扰动观测法...

基于下垂控制的光储直流微电网模型1.模型由光伏和储能以及直流负载组成 2.光伏采用扰动观测法实现最大功率输出,储能刚开始采用恒定电压控制,电压稳定在额定电压附近,2s之后采用下垂控制,母线电压降低,达到目标光伏板在…...

Locust模拟真实用户并发及优化建议

第一部分:为什么要压测?因为生产环境不会跟你商量 你可以把API想象成一家餐厅的后厨。本地跑通,就像你一个人在后厨炒菜,流水线得很顺。但突然来了一百个客人同时点餐,后厨就乱套了——锅不够、灶不够、配菜来不及切。…...

新手必看:在快马平台体验openclaw切换模型的入门实践

今天想和大家分享一个特别适合AI开发新手的实践项目——在InsCode(快马)平台体验openclaw切换模型的操作。作为一个刚接触AI开发不久的人,我发现这个平台真的能让人快速理解模型切换的核心概念,下面就把我的实践过程记录下来。 项目背景理解 刚开始接触A…...

abaqus constraint 中,tie和coupling的区别

通过AI整理相关问题回答 tie和coupling的区别 在 Abaqus 中,Tie (绑定) 和 Coupling (耦合) 是最常用的两种连接约束,但它们在力学逻辑、自由度限制和应用场景上有着本质的区别。1. Tie Constraint (绑定约束) Tie 的核心逻辑是“胶合”。它将两个表面&a…...

BiliTools AI视频总结:让B站学习效率提升300%的智能解决方案

BiliTools AI视频总结:让B站学习效率提升300%的智能解决方案 【免费下载链接】BiliTools A cross-platform bilibili toolbox. 跨平台哔哩哔哩工具箱,支持下载视频、番剧等等各类资源 项目地址: https://gitcode.com/GitHub_Trending/bilit/BiliTools …...

告别系统资源占用困扰:sguard_limit智能优化工具实现性能提升全指南

告别系统资源占用困扰:sguard_limit智能优化工具实现性能提升全指南 【免费下载链接】sguard_limit 限制ACE-Guard Client EXE占用系统资源,支持各种腾讯游戏 项目地址: https://gitcode.com/gh_mirrors/sg/sguard_limit 在数字生活中&#xff0c…...

Python自动化脚本:高效实现CSV到Little_R格式的批量转换

1. 为什么需要CSV到Little_R格式的转换? 在日常数据处理工作中,我们经常会遇到需要将数据从一种格式转换为另一种格式的需求。特别是对于气象研究人员和数据工程师来说,CSV和Little_R这两种格式的转换尤为常见。CSV(Comma-Separat…...

VS2019下C++与MinIO实战:文件上传下载避坑指南(附编译包)

VS2019下C与MinIO深度集成:从环境配置到高效文件管理的完整实践 最近在重构一个企业级文件管理系统时,我面临将Java文件服务迁移到C的技术挑战。经过多轮技术选型,MinIO以其轻量级、高性能的特性成为理想选择。但在实际集成过程中&#xff0c…...