[福游宝——AI智能旅游信息查询平台]全栈AI项目-阶段二:聊天咨询业务组件开发
简言
本项目旨在构建一个以AI智能体
为核心的福建省旅游信息查询系统,聚焦景点推荐、路线规划、交通天气查询等功能,为游客提供智能化、便捷化的旅游信息服务。项目采用前后端分离架构,前端基于Vite + TypeScript + Vue3技术栈,搭配轻量级移动端UI库Vant实现高效开发与响应式布局;后端采用SpringBoot框架构建RESTful API,通过MySQL进行数据存储与管理,将集成DeepSeekAI
实现自然语言处理与智能推荐能力。
项目地址
- gitCode平台:https://gitcode.com/Var_ya/varWisdomModelBody
脚手架明细表
前端:
技术 | 版本 | 官网地址 |
---|---|---|
Vite | ^6.2.0 | https://cn.vitejs.dev/ |
node.js | ^22.14.0 | https://nodejs.org/zh-cn |
npm | ^10.9.2 | https://www.npmjs.com/ |
vue-router | ^4.5.0 | https://router.vuejs.org/zh/ |
Vue3 | ^3.5.13 | https://vuejs.org/ |
Vant | ^4.9.18 | https://vant-ui.github.io/vant/#/zh-CN |
postcss | ^8.5.3 | https://github.com/cuth/postcss-pxtorem |
postcss-pxtorem | ^6.1.0 | |
待补充… |
当前进度预览
- 已完成聊天咨询页各个组件开发:
- 标题组件
- 默认问题组件
- 多模态类型布局组件
- 自定义加载组件
- 火车票查询组件
- 天气查询组件
- 旅游套餐查询组件
九、聊天咨询界面顶部布局
新增组件:
src\components\foreword\index.vue
修改页面:
src\page\home\index.vue
- 实现效果图
- foreword组件内容
<template><div class="main-header" ><div class="main-header-left"><p class="candy-text handwriting-effect "><span style="font-size: 18px;">🍃</span><i>Hi</i>~我是福游宝<span class="cute-bubble">🌱</span></p><p class="tip gradient-text cute-bubble">🌿你的专属旅游助手,可以帮助你规划行程和解答出游问题哦!</p></div><div class="main-headr-right"><img src="@/assets/foreword.jpeg" alt=""></div></div>
</template>
<script lang="ts"></script><style lang="less" scoped>
.main-header{display: grid;grid-template-columns: repeat(2,1fr);padding:30px 0;img{width:100%;object-fit: fill;border-radius: 50%;overflow: hidden;box-shadow: 1px 1px 0 #e8f5e9,2px 2px 4px rgba(46, 204, 113, 0.3),0 0 8px rgba(76, 175, 80, 0.3);}.name{font-size: 20px;color: #0f9380;font-style: italic;font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;}.tip{font-weight: bold;line-height: 2;text-indent: 2em;}}// 修改后的绿色主题可爱字体样式
.cute-text-base {font-family: cursive;font-weight: 600;letter-spacing: 0.08em;line-height: 1.4;color: #28a745; // 主绿色
}// 青苹果泡泡字
.cute-bubble {.cute-text-base();text-shadow: 1px 1px 0 #e8f5e9,2px 2px 4px rgba(46, 204, 113, 0.3),0 0 8px rgba(76, 175, 80, 0.3);
}// 森林立体字
.candy-text {.cute-text-base();text-shadow: 0 1px 0 #e8f5e9,0 2px 0 #c8e6c9,0 3px 0 #a5d6a7,0 4px 8px rgba(46, 204, 113, 0.4);
}// 渐变绿叶效果
.gradient-text {background: linear-gradient(45deg, #34d399, #10b981);-webkit-background-clip: text;background-clip: text;-webkit-text-fill-color: transparent;
}// 手写装饰线(改为青绿色)
.handwriting-effect::before {background: repeating-linear-gradient(90deg,transparent,transparent 3px,#66bb6a 3px,#66bb6a 6px);
}</style>
- 将foreword组件引入到聊天咨询页面
<template><!-- 标题栏 --><!-- <van-nav-bartitle=""
/> -->
<van-nav-bar title="福游宝" ><template #right><van-icon name="ellipsis" size="18"/></template>
</van-nav-bar><div class="content"><!-- 头部信息 --><foreWord></foreWord></div></template>
<script setup lang="ts">import foreWord from"@/components/foreword/index.vue"</script><style lang="less" scoped>
.content{padding:0 15px;
}
</style>
十、默认问题区域布局
新增组件:
src\components\defaultQuestion\index.vue
修改页面:
src\page\home\index.vue
- 实现效果图
- defaultquestion组件内容
<!-- 默认问题 -->
<template><div class="default-question"><div class="customer-service"><img src="@/assets/kefu.png" alt=""><p>福宝</p></div><div class="message-content"><span class="message-tip">你可以这样问我</span><div class="message-list" v-for="(item,index) in 5" :key="index"><img src="@/assets/message.png" alt=""><p>你好</p></div></div><div class="change-question"><img src="@/assets/change.png" alt=""><span>换一换</span></div></div></template>
<script lang="ts"></script><style lang="less" scoped>
.default-question{.customer-service{display: flex;align-items: center;img{width:30px;height: 30px;object-fit: cover;}p{font-size: 14px;padding-left: 10px;}}.message-content{background: white;border-radius: 10px;border-top-left-radius: 0px;margin-top: 20px;padding:10px;.message-tip{display: inline-block;margin: 10px 0px ;font-size: 14px;}.message-list{display: flex;align-items: center;padding:4px 7px;border-radius: 10px;background: #f3f8f9;margin-bottom: 10px;img{width:25px;height: 25px;object-fit: cover;}p{font-size: 14px;padding-left: 10px;}}}.change-question{margin-top: 10px;background: #c0d5d0;border-radius: 5px;padding:5px;display: inline-flex;img{width:20px;height:20px;object-fit: cover;margin-right: 10px;}span{font-size: 14px;line-height: 20px;color:white;}}}
</style>
- defaultquestion组件引入聊天咨询页
<template><!-- 标题栏 --><!-- <van-nav-bartitle=""
/> -->
<van-nav-bar title="福游宝" ><template #right><van-icon name="ellipsis" size="18"/></template>
</van-nav-bar><div class="content"><!-- 头部信息 --><foreWord></foreWord><!-- 默认问题 --><defaultQuestion></defaultQuestion></div></template>
<script setup lang="ts">import foreWord from"@/components/foreword/index.vue"import defaultQuestion from "@/components/defaultQuestion/index.vue"</script><style lang="less" scoped>
.content{padding:0 15px;
}
</style>
十一、多模态类型对话布局
新增组件:
src\components\charmessage\inde.vue
修改页面:
src\page\home\index.vue
- 实现效果图
- vant图片组件引入
import { createApp } from 'vue'// import './style.css'
import App from './App.vue'
// 动态改变字体大小
import "amfe-flexible"// 引入路由实例
import router from"./router/index"
const app = createApp(App)
// 注入路由
app.use(router)// vant组件样式
import 'vant/lib/index.css';// vant组件
import { NavBar,Icon ,Button} from 'vant';
// 标题栏
app.use(NavBar);
//icon图标
app.use(Icon);
// 按钮
app.use(Button);
// 图片
import { Image as VanImage } from 'vant';
app.use(VanImage);app.mount('#app')
- chatmessage组件内容
<!--AI聊天 --><template><div class="chat-message"><div class="user-text-message"><p>用户发送的问题</p></div><div class="user-image-message"><!-- 用户发送图片,使用vant组件 --><van-image width="100px" height="100px" fit="cover" radius="5"src="https://fastly.jsdelivr.net/npm/@vant/assets/cat.jpeg" /></div><!-- AI回复的内容 --><!-- 文字内容 --><div class="ai-message"><div class="customer-service"><img src="@/assets/kefu.png" alt=""><span> 福宝</span></div><p>本项目旨在构建一个以AI智能体为核心的福建省旅游信息查询系统,聚焦景点推荐、路线规划、交通天气查询等功能,为游客提供智能化、便捷化的旅游信息服务。项目采用前后端分离架构,前端基于Vite + TypeScript + Vue3技术栈,搭配轻量级移动端UI库Vant实现高效开发与响应式布局;后端采用SpringBoot框架构建RESTful API,通过MySQL进行数据存储与管理,将集成DeepSeekAI实现自然语言处理与智能推荐能力。</p></div></div>
</template>
<script lang="ts"></script><style lang="less" scoped>
.chat-message {display: flex;// 上下排序flex-direction: column;margin-bottom: 10px;.user-text-message {margin-top: 15px;align-self: flex-end;max-width: 70%;opacity: 0;transform: translateY(20px);animation: fadeUp 0.2s ease-in-out forwards;p {font-size: 16px; line-height: 1.5;background: #15c998;border-radius: 5px;border-top-right-radius: 0px;padding:5px;color: white;}}@keyframes fadeUp {0%{opacity: 0;transform: translateY(20px);}100%{opacity: 1;transform: translateY(0px);}}.user-image-message{align-self: flex-end;margin-top: 15px;}.ai-message{margin-top: 15px;.customer-service{display: flex;align-items: center;margin-bottom: 10px;img{width:30px;height: 30px;object-fit: cover;}span{font-size: 16px;padding-left: 10px;}}p{padding:5px;font-size: 16px;line-height: 1.5;background: white;border-radius: 5px;border-top-left-radius: 0px;color: rgb(117, 114, 114);}}
}
</style>
- chatmessage组件引入到聊天咨询界面
<template><!-- 标题栏 --><!-- <van-nav-bartitle=""
/> -->
<van-nav-bar title="福游宝" ><template #right><van-icon name="ellipsis" size="18"/></template>
</van-nav-bar><div class="content"><!-- 头部信息 --><foreWord></foreWord><!-- 默认问题 --><defaultQuestion></defaultQuestion><!-- 聊天内容 --><chatMessage/></div></template>
<script setup lang="ts">import foreWord from"@/components/foreword/index.vue"import defaultQuestion from "@/components/defaultQuestion/index.vue"import chatMessage from "@/components/charmessage/inde.vue"
</script><style lang="less" scoped>
.content{padding:0 15px;
}
</style>
十二、自定义加载组件
新增组件:
src\components\loading\index.vue
修改页面 :
src\components\charmessage\inde.vue
- 实现效果图
- loading组件内容
<template><div class="shape-circle"><span class="circle"></span><span class="circle"></span><span class="circle"></span></div></template>
<script lang="ts"></script><style lang="less" scoped>
.shape-circle{display: flex;align-items: center;.circle{width:7px;height: 7px;border-radius: 50%;background: #777a8d;margin: 0 4px;animation: colorChange 1s linear infinite;}/* 帧 */@keyframes colorChange {0%{background-color: #ffcc00;}33%{background-color: #ffcc00;}66.67%{background-color: #ffcc00;}}.circle:nth-child(1){animation-delay: 0s;}.circle:nth-child(2){animation-delay: 0.33s;}.circle:nth-child(3){animation-delay: 0.67s;}}</style>>
- chatmessage父组件引入loading组件
<!--AI聊天 --><template><!-- ... --><!-- AI回复的内容 --><div class="ai-message"><div class="mark-text" ><loading></loading></div></div></div>
</template>
<script setup lang="ts">
import loading from"@/components/loading/index.vue"</script>
十三、火车票查询组件布局
新增组件:
src\components\trainticket\index.vue
修改页面:
src\components\charmessage\inde.vue
- 实现效果图
- trainticket组件内容
<!-- 车票查询 -->
<template><div class="train-ticket"><div><p class="query-time">9:18</p><p class="station-name">泉州</p></div><div class="train-run-number"><p>2小时2分</p><p>D6666</p></div><div><p class="query-time">10:20</p><p class="station-name">福州</p></div><div><p class="product-price">¥86</p></div></div><div class="train-ticket"><div><p class="query-time">9:18</p><p class="station-name">泉州</p></div><div class="train-run-number"><p>2小时2分</p><p>D6666</p></div><div><p class="query-time">10:20</p><p class="station-name">福州</p></div><div><p class="product-price">¥86</p></div></div>
</template><script setup lang="ts"></script><style lang="less" scoped>
.train-ticket{border-bottom: 1px solid rgb(228, 222, 222);background: white;display: flex;align-items: center;justify-content: space-around;padding: 7px 0px;.product-price{color: #0a6f4d;}.query-time,.station-name{font-weight: bold;font-size: 12px;}.query-time{font-size: 16px;}
.train-run-number{p{font-size: 12px;color: #9ca1a0;}
}}</style>
- trainticket组件引入到chatmessage父组件中
<!--AI聊天 --><template><div class="chat-message"><!-- AI回复的内容 --><div class="ai-message"><!-- 头像 --><!-- 车票查询 --><trainTicket></trainTicket></div></div>
</template>
<script setup lang="ts">
import trainTicket from "@/components/trainticket/index.vue"</script>
十四、天气查询组件布局
新增组件:
src\components\weather\index.vue
修改页面:
src\components\charmessage\inde.vue
- 实现效果图预览
- weather组件内容
<!-- 天气查询 -->
<template><div class="weather-content"><div class="weather-item"><!-- 日期 --><div class="day-time">05/26</div><!-- 状态 --><div class="day-weather"><!-- src\assets\weather\qingtian.png--><img src="../../assets/weather/qingtian.png" alt=""><p>晴</p></div><!-- 摄氏度 --><div class="day-limit">10-20℃</div></div><div class="weather-item"><!-- 日期 --><div class="day-time">05/26</div><!-- 状态 --><div class="day-weather"><!-- src\assets\weather\qingtian.png--><img src="../../assets/weather/qingtian.png" alt=""><p>多云</p></div><!-- 摄氏度 --><div class="day-limit">10-20℃</div></div></div>
</template>
<script lang="ts">
</script><style lang="less" scoped>
.weather-content {background: linear-gradient(to bottom left, #ffffff, #48adff);margin-top: 10px;margin-bottom: 10px;font-size: 14px;.weather-item{display: flex;align-items: center;justify-content: space-around;padding:7px 0px;.day-time{flex:1;text-align: center;}.day-weather{flex: 1;display: flex;align-items: center ;img{width:20px;margin-right: 5px;height: 20px;}p{font-size: 14px;}}.day-limit{flex: 1;}}}
</style>
- weather组件引入到chatmessage父组件中
<!--AI聊天 --><template><div class="chat-message"><!-- AI回复的内容 --><!-- 天气查询 --><weather></weather></div></div>
</template>
<script setup lang="ts">
import weather from "@/components/weather/index.vue"</script>
十五、搜索商品组件布局
新增组件:src\components\searchgood\index.vue
修改页面:src\components\charmessage\inde.vue
修改页面:index.html
- 实现效果图预览
- 全局样式写入
- index.html文件
<style>/* 文本超过两行时,隐藏多余部分,并以省略号代替 */.text-show{overflow: hidden;display: -webkit-box;text-overflow: ellipsis;-webkit-line-clamp: 2;-webkit-box-orient: vertical;}</style>
- searchgood组件内容
<!-- 搜索商品 -->
<template><div class="goods-content"><p class="title">为您推荐以下相关的旅游套餐:</p><!-- 旅游套餐列表 --><div class="goods-list"><!-- 单个商品 --><div class="goods-item"><img src="../../assets/gu.jpg" alt=""><p class="goods-title text-show ">2025厦门,鹭岛漫游×山海文艺:厦门五天四夜全攻略</p><p class="goods-price">¥1233.3</p></div><div class="goods-item"><img src="../../assets/gu.jpg" alt=""><p class="goods-title text-show ">2025厦门,鹭岛漫游×山海文艺:厦门五天四夜全攻略</p><p class="goods-price">¥1233.3</p></div><div class="goods-item"><img src="../../assets/gu.jpg" alt=""><p class="goods-title text-show ">2025厦门,鹭岛漫游×山海文艺:厦门五天四夜全攻略</p><p class="goods-price">¥1233.3</p></div></div></div>
</template><script setup lang="ts"></script><style lang="less" scoped>
.goods-content{padding-top: 2px;padding-bottom: 2px;background: white;border-radius: 5px;.title{color:rgb(216, 166, 245);font-weight: bold;margin-top: 4px;margin-left: 4px;}.goods-list{display: flex;// x轴溢出overflow-x: auto;margin: 5px 0px;.goods-item{padding:6px;background: #f3f3f3;border-radius: 4px;display: flex;// 垂直布局flex-direction: column;margin: 0 4px;width: 33%;flex-shrink: 0;img{width:100%;border-radius: 4px;height: 130px;object-fit: cover;margin-bottom: 4px;}.goods-title{font-size: 16px;font-weight: bold;margin-bottom: 4px;}.goods-price{margin-top:auto;font-size: 14px;color: red;}}}
}</style>
- searchgood组件引入到chatmessage父组件中
<!--AI聊天 --><template><div class="chat-message"><!-- AI回复的内容 --><!-- 搜索商品 --><searchgood></searchgood></div></div>
</template>
<script setup lang="ts">import searchgood from "@/components/searchgood/index.vue"</script>
相关文章:
[福游宝——AI智能旅游信息查询平台]全栈AI项目-阶段二:聊天咨询业务组件开发
简言 本项目旨在构建一个以AI智能体为核心的福建省旅游信息查询系统,聚焦景点推荐、路线规划、交通天气查询等功能,为游客提供智能化、便捷化的旅游信息服务。项目采用前后端分离架构,前端基于Vite TypeScript Vue3技术栈,搭配…...
【Linux】进程的详讲(下)--进程的环境变量
目录 📖一、进程优先级 📖二、查看进程优先级 📖三、环境变量 📖四、环境变量PATH:Linux系统中的指令搜索路径 📖五、环境变量HOME 📖六、环境变量USER 📖七、命令行参数 …...
深入理解 MVC 模式在 C# 中的应用
MVC(Model-View-Controller)是一种经典的软件设计模式,广泛应用于现代应用程序开发中,尤其是在 Web 应用程序和桌面应用程序中。它通过将应用程序的不同职责进行分离,有助于提高代码的可维护性、可扩展性以及可测试性。…...
《鸿蒙软总线:基于UDP的数据传输奥秘与优势》
在鸿蒙系统构建的万物互联世界里,分布式软总线扮演着至关重要的角色,尤其是其基于UDP协议的数据传输机制,成为支撑多设备高效协同的关键技术。深入剖析这一技术的原理与优势,有助于我们理解鸿蒙系统如何实现设备间的无缝连接与流畅…...
关于 驱动开发方法 的详细分类、核心特点及对比分析,涵盖 TDD、MDD、BDD、DDD、ATDD、FDD、PDD 等主流方法
以下是关于 驱动开发方法 的详细分类、核心特点及对比分析,涵盖 TDD、MDD、BDD、DDD、ATDD、FDD、PDD 等主流方法: 一、驱动开发方法分类及详解 1. 测试驱动开发(TDD: Test-Driven Development) 定义:通过编写测试用…...
考研数据结构之二叉树(二):二叉树的遍历与线索二叉树(包含真题实战)
考研数据结构之二叉树(二):二叉树的遍历与线索二叉树 在上一篇文章中,我们详细探讨了二叉树的定义和存储结构。本文将深入讲解二叉树的核心操作——遍历,以及其重要应用形式之一——线索二叉树。这些内容不仅是考研的…...
Guava Cache的refreshAfterWrite机制
Guava Cache 的 refreshAfterWrite 机制在源码中通过 惰性刷新调度 和 细粒度锁控制 实现,核心逻辑集中在 LocalCache 类的 Segment 结构中。以下是关键源码解析: 一、核心数据结构 1. Segment 类 • 继承自 ReentrantLock:每个 Segment 独…...
邮件发送频率如何根据用户行为动态调整?
邮件发送频率,这可是个技术活儿。发多了,用户烦;发少了,机会溜。别担心,今天就给你支几招,教你如何根据用户行为,像变魔术一样灵活调整邮件发送频率。 一、盯紧用户行为数据 先别急着发邮件&a…...
HDMI与DVI接口热插拔检测
在当今数字音视频传输中,高清多媒体接口与数字视觉接口已成为主流标准。无论是电脑、蓝光播放器,还是电视与显示器,这两种接口都发挥着重要作用。而在保证系统“即插即用”和自动识别的过程中,热插拔检测(HPD)承担着关键角色。研究表明,HDMI 的第 19 引脚和 DVI 的第 16…...
Redis,RESP协议,阻塞IO 与非阻塞IO,Redis的线程模型
1.Redis 阻塞IO 与非阻塞IO Java在JDK1.4 中引入了NIO ,但是也有很多人在使用阻塞IO,这两种IO有什么区别? 在阻塞模式下,如果你从数据流读取不到指定大小的数据量,IO就会阻塞。 比如: 已知会有10个字节发送过来,但是我…...
Express学习笔记(六)——前后端的身份认证
目录 1. Web 开发模式 1.1 服务端渲染的 Web 开发模式 1.2 服务端渲染的优缺点 1.3 前后端分离的 Web 开发模式 1.4 前后端分离的优缺点 1.5 如何选择 Web 开发模式 2. 身份认证 2.1 什么是身份认证 2.2 为什么需要身份认证 2.3 不同开发模式下的身份认证 3. Sessio…...
DDoS攻防实战指南——解析企业级防护五大解决方案
一、流量清洗中心的智能化演进 云清洗服务已从被动响应转向主动防御。基于全球Anycast网络的分布式清洗节点,可在攻击发生时将流量牵引至专用清洗集群。阿里云2023年实测数据显示,其新一代清洗设备对SYN Flood的识别准确率达99.97%,误杀率控…...
2025年机电一体化、机器人与人工智能国际学术会议(MRAI 2025)
重要信息 时间:2025年4月25日-27日 地点:中国济南 官网:http://www.icmrai.org 征稿主题 机电一体化机器人人工智能 传感器和执行器 3D打印技术 智能控制 运动控制 光电系统 光机电一体化 类人机器人 人机界面 先进的运动控制 集成制造系…...
QT Sqlite数据库-教程002 查询数据-上
【1】DQL语句: DQL语句(数据查询语言),用来查询数据记录。DQL 基本结构由 SELECT FROM、WHERE、JOIN 等子句构成。DQL 语句并不会改变数据库,而是让数据库将查询结果发送结果集给客户端,返回的结果是一张虚…...
Java List流式编程全解析:从入门到实战高手
🚀 Java List流式编程全解析:从入门到实战高手 #Java8新特性 #Stream流 #集合操作 #高效编程 一、为什么需要Stream流? 传统集合操作痛点: 代码冗长:多层循环嵌套,可读性差难以并行:手动拆分…...
【Linux】深入理解线程控制
个人主页~ 深入理解线程控制 一、线程等待的原理二、线程的局部存储三、初步理解线程互斥1、互斥的概念2、需要互斥的原因 一、线程等待的原理 pthread_join的作用是线程等待,其中retval参数传递线程退出状态的原理是:当目标线程结束时,pthr…...
android面试情景题详解:android如何处理断网、网络切换或低速网络情况下的业务连续性
在移动互联网时代,Android应用已经成为人们日常生活中不可或缺的一部分。从社交媒体到在线购物,从移动办公到娱乐消费,几乎所有的服务都依赖于网络连接。然而,网络环境并非总是稳定可靠。断网、网络切换(如从Wi-Fi切换…...
基于 Qt 的 BMP 图像数据存取至 SQLite 数据库的实现
基于 Qt 的 BMP 图像数据存取至 SQLite 数据库的实现说明 本项目通过 Qt 框架实现了将 BMP 图像文件以二进制形式存入 SQLite 数据库,并可从数据库中读取还原为 BMP 图像文件的功能,适用于需要图像与结构化数据统一管理的场景。 整个流程分为两个主要部…...
Melos 发布pub.dev
🧰 Melos 全套实用教程(Flutter Monorepo 管理神器) 🚀 目录: 什么是 Melos?适合哪些项目? 安装与初始化 项目结构推荐 melos.yaml 配置详解 常用命令讲解(bootstrap、run、exe…...
基于 SSM 高校二手交易平台
收藏关注不迷路!! 🌟文末获取源码数据库🌟 感兴趣的可以先收藏起来,还有大家在毕设选题(免费咨询指导选题),项目以及论文编写等相关问题都可以给我留言咨询,希望帮助更多…...
Missashe考研日记-day20
Missashe考研日记-day20 1 高数 学习时间:2h30min学习内容: 今天当然是刷题啦,做不等式的证明板块的真题,证明题懂的都懂,难起来是真的一点思路都没有,这个板块还没做完,做完再总结题型。 2…...
Spring 单元测试核心注解全解:@InjectMocks、@MockBean、@Mock、@Autowired 的区别与实战
在编写 Spring Boot 应用的单元测试过程中,@InjectMocks、@MockBean、@Mock 和 @Autowired 是最常用的几个注解,但它们经常被混淆或误用,导致测试失败或注入错误。 本文将从本质区别、使用场景、示例代码、对比表格等多个维度,全面解析这几者的使用方法与差异,助你写出结…...
Spring Boot 项目里设置默认国区时区,Jave中Date时区配置
在 Spring Boot 项目里设置国区时区(也就是中国标准时间,即 Asia/Shanghai),可通过以下几种方式实现: 方式一:在application.properties或application.yml里设置 application.properties properties sp…...
如何使用Cloud Sync搭建群晖NAS跨设备自动备份与手机端实时监控
文章目录 前言1. 群晖NAS安装Cloud Sync1.1 安装和配置 Cloud Sync 2. 功能演示3. 群晖安装cpolar内网穿透3.1 配置Cloud Sync公网访问地址 4. 配置固定公网地址 前言 在当今这个信息爆炸的时代,个人和企业都面临着一个共同的难题:数据分散在各种设备和…...
git回退到指定版本
查看提交历史 在本地仓库中运行 git log 命令,找到需要回退到的版本对应的 commit ID。 重置本地分支 执行 git reset --hard commit_id 将本地分支回退至目标版本,commit_id为要会退的版本号。 强制推送更改 运行 git push origin HEAD --force 强制更…...
【Python爬虫】简单介绍2
目录 四、网页数据的加载方式 4.1 数据直接放在请求响应结果中 4.2 数据在异步请求响应结果中 五、爬虫 - 反爬虫 - 反反爬虫 5.1 反爬虫 5.2 反反爬虫 六、风险 6.1 合法性与合规性的重要性 6.2 违规使用爬虫面临的法律风险示例 6.3 合法合规使用爬虫的建议 四、网页…...
基于QtC++音乐播放器whisper语音转文字歌词解析
演示视频 github源码地址 gitee源码地址 通过网盘分享的文件:MySoftWare 链接: https://pan.baidu.com/s/1JdtZNoMcv7jXR_ELMuqZEg?pwd1yw6 提取码: 1yw6 –来自百度网盘超级会员v4的分享...
【QT】QT界面的美容院 -- QSS
一、背景介绍 🔥 在网页前端开发领域中,CSS 是一个至关重要的部分,描述了一个网页的 “样式”,从而起到对网页 美化 的作用。 所谓 样式 ,包括不限于大小、位置、颜色、背景、间距、字体等等。现在的网页很难找到没有…...
【AI】使用Huggingface模型实现文本内容摘要器
【AI】使用Huggingface模型实现文本内容摘要器 推荐超级课程: 本地离线DeepSeek AI方案部署实战教程【完全版】Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速入门实战目录 【AI】使用Huggingface模型实现文本内容摘要器什么是摘要器?摘要器的应用场景什么是…...
centOS 安装和配置docker
以下是在 CentOS 系统上安装和配置 Docker 的详细步骤: 一、安装 Docker 1. 卸载旧版本(如有) sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate …...
现在AI大模型能帮做数据分析吗?
实际上,有了AI大模型的支持才使得AI数据分析的功能得到更好地应用,比如小浣熊AI支持数据交互功能,只要你输入具体的数据分析要求,它就能自动帮你完成数据清洗、分析、可视化全流程,而且还能生成数据分析报告。 当然&a…...
qt中,父类中有Q_OBJECT,子类中还需要加Q_OBJECT吗
在 Qt 中,关于子类是否需要添加 Q_OBJECT 宏的问题,可以总结如下: 1. 需要添加 Q_OBJECT 的情况 如果子类满足以下任一条件,必须显式添加 Q_OBJECT 宏: 定义了新的信号或槽:即使父类已有 Q_OBJECT&#…...
vue2实现在屏幕中有一个小机器人可以随意移动
第一步:创建store目录结构 src/ ├── store/ │ ├── modules/ │ │ └── robot.js # 机器人专用状态模块 │ └── index.js # Vuex 主配置文件第二步:创建机器人状态模块 创建 src/store/modules/robot.js 文件ÿ…...
MCP协议实战指南:在VS Code中实现PostgreSQL到Excel的自动化迁移
作者:后端小肥肠 🍊 有疑问可私信或评论区联系我。 🥑 创作不易未经允许严禁转载。 姊妹篇: 从PDF到精准答案:Coze助力RAGFlow框架提升数据召回率_提升ragflow-CSDN博客 CozeTreeMind实测:秒出ISO标准流程图…...
Before After:SQL整容级优化
首先说明这个优化有一定提升,但不是我所期望的 我接到一个涉及优化的SQL,具体内容实在太长。而且可能也不利于阅读。于是我脱敏以及简化一下。SQL中间大量的充斥着 (select 列名1 from t1 where t1.id t2.id ) A, (select 列名2 from t1 where t1.id …...
hash.
Redis 自身就是键值对结构 Redis 自身的键值对结构就是通过 哈希 的方式来组织的 哈希类型中的映射关系通常称为 field-value,用于区分 Redis 整体的键值对(key-value), 注意这里的 value 是指 field 对应的值,不是键…...
JMeter重要的是什么
重要特性 支持多种协议: JMeter支持对多种协议进行性能测试,包括HTTP、HTTPS、FTP、JDBC(数据库)、LDAP、JMS、SOAP、REST等。这使得它能够适应各种不同的测试场景。强大的负载模拟能力: JMeter能够模拟大量的虚拟用户…...
Java研学-Activiti7工作流(二)
三 Activiti7 搭建环境 1 开发环境 Jdk1.8或以上版本;Mysql 5及以上的版本;Tomcat8.5;IDEA;Activiti 7.0.0.SR1(流程设计器) 2 安装Activiti流程设计器 ① 在线安装:在Plugins中搜索actiBPM,然后点击Sear…...
鸿蒙开发-编译器使用
15.2编译器使用-目录详解 15.3 编辑器使用-切换工程模块 15.3 编辑器使用-多设备预览 15.1 编辑器使用-编辑中英文...
HTML5+CSS前端开发【保姆级教学】+图像标签附路径问题
引入: Hello!,各位编程猿们!我们知道在网页文档中合理地加入图像,会使文档变得更加生动活泼和引人入胜,而且看上去更加专业、更具有信息性且易于浏览。本期主要介绍图像标签以及超链接标签 一、设置图像标…...
快速启动 Rust + WebAssembly 项目
一、 模板一:wasm-pack-template 适合目标:构建一个 Rust 写的 WebAssembly npm 包 这是最常用、也是最官方推荐的起点模板。它提供了: Cargo.toml 配置好 WebAssembly 的 crate 类型(cdylib)已设置 wee_alloc 和 pan…...
Linux命令-vim编辑
用vi或vim命令进入vim编辑器。 基础: u -- 撤销上一次操作。 x -- 剪切当前光标所在处的字符。 yy -- 复制当前行。 dd -- 剪切当前行。 p -- 粘贴剪贴板内容到光标下方。 i -- 切换到输入模式,在光标当前位置开始输入文本。 :wq -- 保存并退出Vim 编辑器。…...
Windows单机模拟MySQL主从复制
这里写自定义目录标题 下载MySQL ZIP压缩包安装主库1、创建配置文件2、安装服务3、初始化数据库4、启动服务5、配置主库 安装从库1、配置ini文件2、安装服务3、初始化数据库4、启动服务5、配置从库6、验证从库状态 操作主库验证 下载MySQL ZIP压缩包 https://dev.mysql.com/do…...
【区块链+ 人才服务】广州理工学院区块链教学平台 | FISCO BCOS 应用案例
深圳市火链文化传播有限公司与广州理工学院合作,共同建设了“区块链教学平台”。该平台旨在探索区块链技术在教 育领域的应用,特别是在混合式教学模式中的创新实践。 “区块链教学平台”运用了区块链技术的核心优势,包括分布式、信息防篡改以…...
Java Stream深度解析 高阶技巧与性能优化实战
文章目录 一、Stream底层机制揭秘1.1 Stream流水线架构1.2 Spliterator探秘 二、自定义收集器高级实现2.1 实现高性能统计收集器2.2 多级分组优化技巧 三、并行流深度优化3.1 并行度控制策略3.2 工作窃取(Work-Stealing)优化 四、无限流与短路操作4.1 生成无限质数流4.2 短路操…...
【JavaEE初阶】多线程重点知识以及常考的面试题-多线程进阶(一)
本篇博客给大家带来的是多线程的知识点, . 🐎文章专栏: JavaEE初阶 🚀若有问题 评论区见 ❤ 欢迎大家点赞 评论 收藏 分享 如果你不知道分享给谁,那就分享给薯条. 你们的支持是我不断创作的动力 . 王子,公主请阅🚀 要开心要快乐顺便进步 1. 常…...
计算机视觉图像分割入门:阈值、区域生长与分水岭算法
计算机视觉图像分割入门:阈值、区域生长与分水岭算法 一、前言二、图像分割基础概念大揭秘2.1 图像分割的定义2.2 图像分割的目的与作用2.3 图像分割的应用领域三、阈值算法:最简单的图像分割法3.1 原理剖析3.2 手动阈值分割及代码示例3.3 自动阈值分割方法及代…...
android弱网环境数据丢失解决方案(3万字长文)
在移动互联网时代,Android 应用已经成为人们日常生活中不可或缺的一部分。从社交媒体到在线购物,从移动办公到娱乐游戏,用户对应用的依赖程度与日俱增。然而,尽管网络基础设施在全球范围内得到了显著改善,弱网环境依然…...
设计模式:迪米特法则 - 最少依赖,实现高内聚低耦合
一、迪米特法则简介 迪米特法则(Law of Demeter,简称 LoD),也称为“最少知识法则”,核心思想是:一个对象应当对其他对象有最少的了解,仅与直接相关的对象交互。通过减少对象之间的耦合度&#…...
React 把一系列 state 更新加入队列
把一系列 state 更新加入队列 设置组件 state 会把一次重新渲染加入队列。但有时你可能会希望在下次渲染加入队列之前对 state 的值执行多次操作。为此,了解 React 如何批量更新 state 会很有帮助。 开发环境:Reacttsantd 学习内容 什么是“批处理”以…...