微信小程序中会议列表页面的前后端实现
题外话:想通过集成腾讯IM来解决即时聊天的问题,如果含语音视频,腾讯组件一年5万起步,贵了!后面我们改为自己实现这个功能,这里只是个总结而已。
图文会诊需求
首先是个图文列表界面 同个界面可以查看具体的图文内容:
发起图文的聊天的时候 首先选择患者-->再次选择医生团队-->最后选择需要参与的医生-->发起会话
原有的图文聊天 用了腾讯会议的组件,这里要改为我们自己的东西!
数据库设计
后面应该有个图文会议的列表
一个图文会议 应该关联患者、医生信息
现有设计是集成IM的,在一张表当反映了这些信息
如果重新设计 这个就不太合理了 ,应该重新设计会议列表、医生 会议关系表 、患者会议关系表三张表.
那我们就创建一张会议表与2张关系表:
CREATE TABLE chat_group (id INT AUTO_INCREMENT PRIMARY KEY,title VARCHAR(255) NOT NULL,create_time TIMESTAMP DEFAULT CURRENT_TIMESTAMP,creator VARCHAR(255) NOT NULL,memo TEXT
);CREATE TABLE doctor_chat_group_relation (id INT AUTO_INCREMENT PRIMARY KEY,doctor_id INT UNSIGNED NOT NULL,chat_group_id INT NOT NULL,datetime DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '记录时间',FOREIGN KEY (doctor_id) REFERENCES sys_doctors(id) ,FOREIGN KEY (chat_group_id) REFERENCES chat_group(id)
)CREATE TABLE patient_chat_group_relation (id INT AUTO_INCREMENT PRIMARY KEY,patient_id INT NOT NULL,chat_group_id INT NOT NULL,datetime DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '记录时间',FOREIGN KEY (patient_id) REFERENCES sys_patient(id) ,FOREIGN KEY (chat_group_id) REFERENCES chat_group(id)
) ENGINE=InnoDB;
插入10条测试数据:
INSERT INTO chat_group (title, creator, memo) VALUES
('Group 1', 'Creator 1', 'Memo for Group 1'),
('Group 2', 'Creator 2', 'Memo for Group 2'),
('Group 3', 'Creator 3', 'Memo for Group 3'),
('Group 4', 'Creator 4', 'Memo for Group 4'),
('Group 5', 'Creator 5', 'Memo for Group 5'),
('Group 6', 'Creator 6', 'Memo for Group 6'),
('Group 7', 'Creator 7', 'Memo for Group 7'),
('Group 8', 'Creator 8', 'Memo for Group 8'),
('Group 9', 'Creator 9', 'Memo for Group 9'),
('Group 10', 'Creator 10', 'Memo for Group 10');
原来的代码是集成腾讯IM,调用它
会议列表页面
现在单独做个页面:
要求:首先是要显示第一页数据,下拉的时候加载下一页数据
第一步:pages.json当中 还需开启上拉加载事件。如下图
"enablePullDownRefresh" : true,
"onReachBottomDistance":100,
第二步:先下载导入要用到uni-load-more:它用于列表中,做滚动加载使用,展示 loading 的各种状态。
ps:uni-app官网
3第三步编写前端代码:
基于Vue和uni-app框架的会诊列表页面开发
一、项目背景
本页面是一个基于Vue和uni-app框架开发的会诊列表页面,用于展示医生参与的会诊信息。用户可以通过该页面查看会诊的标题、备注、创建时间等详细信息,并支持点击会诊项进入详情页面。
完整代码:
<template><view><view class="tuijian"><image src="https://prdservice.com/minio/edwin/msg.png"></image><text >会诊列表</text></view><view class="button_container"> <view class="custom-button"><image class="button-icon" src="https://prdservice.com/minio/edwin/add_active.png" mode="aspectFit"></image><text class="button-text">发起图文</text></view></view><view class="list" ><uni-list v-for="(item ,index) in lists" :key="index" ><uni-list-item showArrow :title="item.title" :note="item.memo" :rightText="item.createTime" thumb="https://prdservice.com/minio/edwin/chatHospitor/doctorImg.png"clickable @click="onClick()"></uni-list-item></uni-list><uni-load-more :status="status" :icon-size="14" :content-text="contentText" /></view></view></template><script>import {loginRequest} from '@/api/request.js'export default {data() {return {status: 'more',totalCount: 1,params: {doctorId: 0,pageNo: 1,pageSize: 20,keyword: '',total: 0,status: 0},contentText: {contentdown: '加载更多~',contentrefresh: '加载中',contentnomore: '我是有底线的~'},lists: [],extraIcon: '/check.png'}},methods: {//获取列表// async getList(){// let paramJson = {// page:this.params.pageNo,// limit:this.params.pageSize,// };// let { code,data,total } = await app.getReferrerListByPage(paramJson);// // console.info(data)// if(200 == code){// // //请求接口成功之后,判断加载状态,处理数据// this.totalCount = total;// if(this.params.pageNo == 1){// this.lists= data// }else{// this.lists= this.lists.concat(data); // }// if (this.params.pageNo * this.params.pageSize >= total) {// this.status = 'noMore';// }// this.params.pageNo++;// } // },async getList() {this.params.doctorId = wx.getStorageSync('userInfo').id// this.isloading = true// uni.showLoading({// title: '加载中'// });try{uni.request({url: loginRequest.baseURL + 'getChatGroups',method: 'POST',header: {'auth-token': wx.getStorageSync("token")},data: {...this.params},success: res => {console.log('res: ', res)if (res.data.code === 200) {// //请求接口成功之后,判断加载状态,处理数据this.totalCount = res.data.data.total;if(this.params.pageNo == 1){this.lists=res.data.data.chatGroups}else{this.lists= this.lists.concat(res.data.data.chatGroups); }if (this.params.pageNo * this.params.pageSize >= this.totalCount) {this.status = 'noMore';}this.params.pageNo++;} else {uni.showToast({title: res.data.msg,icon: "error"})}}}) } catch (error) {console.error('请求失败:', error);uni.showToast({title: '请求失败,请稍后再试',icon: "error"});this.status = 'more'; // 恢复为可加载更多状态} finally {this.status = 'more'; // 确保最终状态为可加载更多(除非已经没有更多数据)}// uni.hideLoading()// this.isloading = false},//触底加载onReachBottom() {if (this.status != 'noMore') {this.status = 'loading';this.getList()} else {this.status ="noMore"}},onClick(item) {// 处理点击事件,例如跳转到详情页console.log('点击了项目:', item);// 例如:uni.navigateTo({ url: `/pages/detail/detail?id=${item.id}` });}},mounted() {this.getList(); // 页面加载时获取第一页数据}}
</script><style>
/* 页面或组件的样式表 *//* 设置页面的高度、背景色和滚动行为 */
page {height: 100vh;
/* background-color: #F5F6FA; */overflow-y: auto;
}.list{margin-left: 20rpx; /* 设置外边距 */margin-right: 20rpx;
}
/* 为列表容器设置高度和可能的滚动行为(注意:这里通常不需要overflow-y,因为父元素已经设置了) */
.list-container {height: calc(100vh - 130rpx); /* 使用calc函数计算高度,注意rpx是微信小程序的响应式单位 */
}/* 为推荐项设置样式 */
.tuijian {width: 710rpx;height: 94rpx;line-height: 94rpx; /* 设置行高与高度相同,使文本垂直居中 */margin: 20rpx; /* 设置外边距 */background-color: rgba(14, 196, 153, 1); /* 设置背景色 */box-sizing: border-box; /* 确保padding和border不会增加元素的总宽度和高度 */display: flex; /* 使用flex布局 */align-items: center; /* 垂直居中 */
}/* 为推荐项中的图片设置样式 */
.tuijian image {/* 注意:在微信小程序中,应该使用<image>标签,并且它是自闭合的,不需要结束标签 */width: 30rpx;height: 30rpx;margin-left: 40rpx;margin-right: 20rpx;
}/* 但是,由于<image>是一个原生组件,并且微信小程序不支持直接使用标签名选择器在组件样式中,因此上面的选择器应该被重写为类选择器,如果图片有特定的类名的话。例如: */
.tuijian .image-class {width: 30rpx;height: 30rpx;margin-left: 40rpx;margin-right: 20rpx;
}/* 为推荐项中的文本设置样式 */
/* 注意:在微信小程序中,通常使用<text>标签包裹文本,但<text>并不是一个真正的DOM元素,它更像是一个文本容器,用于应用样式。然而,在.wxss文件中,您仍然可以使用类选择器来定义它的样式。 */
.tuijian .text-class {font-size: 36rpx;color: #fff;text-shadow: 1px 1px 0px rgba(0, 0, 0, 0.647058823529412); /* 设置文本阴影 */
}.button_container {display: flex;justify-content: center;align-items: center;border: none; /* 无边框 */
}.custom-button {display: flex;align-items: center;padding: 10px 20px;border: none; /* 无边框 */}.button-icon {width: 24px; /* 图标宽度 */height: 24px; /* 图标高度 */margin-right: 8px; /* 图标与文字之间的间距 */
}.button-text {font-size: 12px; /* 文字大小 */color: #333; /* 文字颜色 */
}
</style>
实际效果如图:
。
二、页面结构
- 顶部推荐区域:包含一个文本“会诊列表”,用于标识页面功能。
- 列表区域:展示会诊列表项,每个列表项包含标题、备注和创建时间。
- 加载更多区域:用于在用户滚动到页面底部时触发加载更多数据的操作。
三、代码说明
1. 模板部分(template)
<view class="tuijian">
:包含推荐区域的文本“会诊列表”。<uni-list>
:用于包裹列表项,支持循环渲染。<uni-list-item>
:列表项,包含标题(title)、备注(note)和创建时间(rightText)。
<uni-load-more>
:加载更多组件,根据status状态显示不同的文本内容。
2. 脚本部分(script)
- 数据(data):
status
:加载更多状态,支持'more'(可加载更多)、'loading'(正在加载)和'noMore'(没有更多数据)。totalCount
:总数据量。params
:请求参数,包括医生ID、页码、每页数量、关键词等。contentText
:加载更多组件的文本内容。lists
:会诊列表数据。
- 方法(methods):
getList
:获取会诊列表数据的方法,通过uni.request发送请求到后端接口,并处理返回的数据。onReachBottom
:触底加载方法,当用户滚动到页面底部时触发,调用getList
方法加载更多数据。onClick
:点击列表项的方法,当前仅输出点击的项信息,可根据需求跳转到详情页面。
- 生命周期钩子(mounted):
- 在页面加载时调用
getList
方法获取第一页数据。
- 在页面加载时调用
3. 样式部分(style)
- 页面样式:设置页面高度、背景色和滚动行为。
- 列表容器样式:为列表容器设置高度和可能的滚动行为(注意:这里通常不需要overflow-y,因为父元素已经设置了)。
- 推荐项样式:为推荐项设置宽度、高度、背景色、文本样式等。
- 文本样式:为推荐项中的文本设置字体大小、颜色、文本阴影等。
四、开发步骤
- 创建页面文件:在uni-app项目中创建新的页面文件,包括
.vue
、.js
、.json
和.wxss
文件(或直接在.vue
文件中编写模板、脚本和样式)。 - 编写模板:根据页面结构编写模板代码,包括推荐区域、列表区域和加载更多区域。
- 编写脚本:
- 在data中定义页面所需的数据和状态。
- 编写获取会诊列表数据的方法
getList
,并处理返回的数据。 - 编写触底加载方法
onReachBottom
,调用getList
方法加载更多数据。 - 编写点击列表项的方法
onClick
,根据需求处理点击事件。 - 在mounted生命周期钩子中调用
getList
方法获取第一页数据。
- 编写样式:根据页面设计编写样式代码,包括页面高度、背景色、列表容器样式、推荐项样式和文本样式等。
- 测试页面:在开发环境中测试页面功能,确保数据能够正确加载和显示,点击事件能够正常触发和处理。
五、注意事项
- 请求接口:确保后端提供的接口地址和参数格式正确,且接口能够返回正确的数据格式。
- 数据处理:在获取到数据后,需要根据需求对数据进行处理,如分页、排序等。
- 样式调整:根据页面设计调整样式代码,确保页面美观和用户体验良好。
- 错误处理:在请求数据时,需要处理可能出现的错误情况,如网络异常、接口返回错误码等,并给出相应的提示信息。
六、其他调整
项目item前加个小图标吧 ,如下图加上img src 属性 ,给uni-list-item 加上thumb属性即可
<template><view><view class="tuijian"><image src="https://prdservice.com/minio/edwin/msg.png"></image><text >会诊列表</text></view><view class="list" ><uni-list v-for="(item ,index) in lists" :key="index" ><uni-list-item showArrow :title="item.title" :note="item.memo" :rightText="item.createTime" thumb="https://prdservice.com/minio/edwin/chatHospitor/doctorImg.png"clickable @click="onClick()"></uni-list-item></uni-list><uni-load-more :status="status" :icon-size="14" :content-text="contentText" /></view></view></template>
本想用图标,不知道为啥不成功 后面有空再调整。现在效果如下:
ps:uni-app官网
还差一点,左右没有留白啊,这个好办,应用其他页面写得样式即可。
.list{margin-left: 20rpx; /* 设置外边距 */margin-right: 20rpx;
}
还有背景颜色 去掉style 当中page{} 设置的背景色,即可 ,整个项目 本身就设置好了全局背景颜色了。
最后,加上一个“发起图文”按钮
<view class="button_container"> <view class="custom-button"><image class="button-icon" src="https://prdservice.com/minio/edwin/add_active.png" mode="aspectFit"></image><text class="button-text">发起图文</text></view></view>
效果如图:
3、服务端代码开发
项目背景
本项目的目标是开发一个用于医生与聊天群组关系管理的后端服务。医生可以通过这个服务查询自己所参与的聊天群组列表。这些群组信息将从小程序端发送到后端,后端根据医生ID分页返回相关的群组信息。
项目结构
- Controller层:处理HTTP请求,调用Service层的方法,并返回响应结果。
- Service层:包含业务逻辑,调用Mapper层的方法与数据库进行交互。
- Mapper层:定义与数据库交互的SQL语句。
- 数据模型:定义数据传输对象(DTO)和实体类。
编码步骤
1. 创建数据模型
首先,我们需要定义数据传输对象(DTO)和实体类。
// ChatGroup.java
@Data
public class ChatGroup {private Integer pageNo;private Integer pageSize;private Integer doctorId;private Integer total;private Integer status; // 注意:原代码中有一个拼写错误,将'tatus'改为'status'private List<ChatGroupDto> chatGroups;
}// ChatGroupDto.java
@Data
public class ChatGroupDto {private Integer chatGroupId;private String title;private LocalDateTime createTime;private String creator;private String memo;
}// DoctorChatGroupRelation.java
@Data
public class DoctorChatGroupRelation {private Integer id;private Integer doctorId;private Integer chatGroupId;private LocalDateTime datetime;
}
2. 创建Mapper接口
Mapper接口定义与数据库交互的SQL语句。
// DoctorChatGroupRelationMapper.java
@Mapper
public interface DoctorChatGroupRelationMapper {@Select("SELECT COUNT(*) FROM doctor_chat_group_relation WHERE doctor_id = #{doctorId}")int countByDoctorId(@Param("doctorId") Integer doctorId);@Select("SELECT dcgr.chat_group_id, cg.title, cg.create_time, cg.creator, cg.memo " +"FROM doctor_chat_group_relation dcgr " +"JOIN chat_group cg ON dcgr.chat_group_id = cg.id " +"WHERE dcgr.doctor_id = #{doctorId} " +"LIMIT #{offset}, #{limit}")List<ChatGroupDto> findByDoctorIdWithPagination(@Param("doctorId") Integer doctorId,@Param("offset") int offset,@Param("limit") int limit);
}
3. 创建Service接口和实现类
Service层包含业务逻辑,调用Mapper层的方法。
// DoctorChatGroupRelationServiceInterface.java
public interface DoctorChatGroupRelationServiceInterface {int countByDoctorId(Integer doctorId);List<ChatGroupDto> findByDoctorIdWithPagination(Integer doctorId, int pageNo, int pageSize);
}// DoctorChatGroupRelationServiceImpl.java
@Service
public class DoctorChatGroupRelationServiceImpl implements DoctorChatGroupRelationServiceInterface {@Autowiredprivate DoctorChatGroupRelationMapper doctorChatGroupRelationMapper;@Overridepublic int countByDoctorId(Integer doctorId) {return doctorChatGroupRelationMapper.countByDoctorId(doctorId);}@Overridepublic List<ChatGroupDto> findByDoctorIdWithPagination(Integer doctorId, int pageNo, int pageSize) {int offset = (pageNo - 1) * pageSize;return doctorChatGroupRelationMapper.findByDoctorIdWithPagination(doctorId, offset, pageSize);}
}
4. 创建Controller
Controller层处理HTTP请求,调用Service层的方法,并返回响应结果。
// DoctorChatGroupRelationController.java
@RestController
@RequestMapping("/wechat/client")
@Api(value = "会议")
public class DoctorChatGroupRelationController {@Autowiredprivate DoctorChatGroupRelationServiceInterface doctorChatGroupRelationService;@PostMapping("/getChatGroups")public ResponseResult<ChatGroup> getChatGroups(@RequestBody ChatGroup chatGroup) {try {Integer doctorId = chatGroup.getDoctorId();Integer pageNo = chatGroup.getPageNo();Integer pageSize = chatGroup.getPageSize();int totalCount = doctorChatGroupRelationService.countByDoctorId(doctorId);List<ChatGroupDto> chatGroups = doctorChatGroupRelationService.findByDoctorIdWithPagination(doctorId, pageNo, pageSize);chatGroup.setTotal(totalCount);chatGroup.setChatGroups(chatGroups);chatGroup.setStatus(1); // 可以根据需要设置状态码,例如1表示成功return ResponseResult.ok(chatGroup);} catch (Exception e) {return ResponseResult.failed("获取会议列表失败" + e.getMessage());}}
}
5. 创建通用的响应结果类
通常,我们会创建一个通用的响应结果类来封装返回给客户端的数据。
// ResponseResult.java
@Data
public class ResponseResult<T> {private int code;private String message;private T data;public static <T> ResponseResult<T> ok(T data) {ResponseResult<T> result = new ResponseResult<>();result.setCode(200);result.setMessage("成功");result.setData(data);return result;}public static <T> ResponseResult<T> failed(String message) {ResponseResult<T> result = new ResponseResult<>();result.setCode(500);result.setMessage(message);return result;}
}
注意事项
- 异常处理:在Controller中,我们使用try-catch块捕获异常,并返回失败的响应结果。这样可以确保即使发生异常,客户端也能接收到明确的错误信息。
- 分页处理:在Service层,我们通过计算偏移量(offset)来实现分页查询。
- 数据验证:在实际项目中,需要对接收到的数据进行验证,确保数据的有效性和安全性。可以使用Spring的
@Valid
注解和自定义验证器来实现。 - 日志记录:在关键业务逻辑处添加日志记录,以便在出现问题时进行故障排查。
通过以上步骤,我们完成了一个简单的医生聊天群组关系管理后端服务。该服务可以接收小程序端的请求,根据医生ID分页返回相关的群组信息。
返回类型 也要封装一下
{code: 200, msg: "操作成功!", data: {pageNo: 1, pageSize: 20, doctorId: 350, total: 2, tatus: null,…}}
code: 200
data: {pageNo: 1, pageSize: 20, doctorId: 350, total: 2, tatus: null,…}
chatGroups: [{chatGroupId: 1, title: "Group 1", createTime: "2024-11-22 20:57:46", creator: "Creator 1",…},…]
0: {chatGroupId: 1, title: "Group 1", createTime: "2024-11-22 20:57:46", creator: "Creator 1",…}
1: {chatGroupId: 2, title: "Group 2", createTime: "2024-11-22 20:57:46", creator: "Creator 2",…}
doctorId: 350
pageNo: 1
pageSize: 20
tatus: null
total: 2
msg: "操作成功!"
相关文章:
微信小程序中会议列表页面的前后端实现
题外话:想通过集成腾讯IM来解决即时聊天的问题,如果含语音视频,腾讯组件一年5万起步,贵了!后面我们改为自己实现这个功能,这里只是个总结而已。 图文会诊需求 首先是个图文列表界面 同个界面可以查看具体…...
决策树——基于乳腺癌数据集与cpu数据集实现
决策树——乳腺癌数据实现 4.1 训练决策树模型,并计算测试集的准确率 1. 读入数据 from sklearn import datasets from sklearn.tree import DecisionTreeClassifier from sklearn.model_selection import train_test_split from sklearn.metrics import confusion_matrix …...
2024年11月24日Github流行趋势
项目名称:FreeCAD 项目维护者:wwmayer, yorikvanhavre, berndhahnebach, chennes, WandererFan等项目介绍:FreeCAD是一个免费且开源的多平台3D参数化建模工具。项目star数:20,875项目fork数:4,117 项目名称࿱…...
库的操作.
创建、删除数据库 创建语法: CREATE DATABASE [IF NOT EXISTS] db_name[ ]是可选项,IF NOT EXISTS 是表明如果不存在才能创建数据库 //查看数据库,假设7行 show databases; //创建数据库 --- 本质在Linux创建一个目录 create database databa…...
Go错误与日志处理—推荐实践
错误的分类 在 Go 语言中,错误是通过实现 error 接口的类型表示的,但不同场景下的错误可以按性质和用途进行分类。以下是 Go 语言错误的常见分类,以及每类错误的解释和示例: 标准错误类型 标准库中定义了许多常见的错误类型&…...
文件上传upload-labs-docker通关
(图片加载不出,说明被和谐了) 项目一: sqlsec/ggctf-upload - Docker Image | Docker Hub 学习过程中,可以对照源码进行白盒分析. 补充:环境搭建在Linux虚拟机上的同时,以另一台Windows虚拟机进行测试最…...
C语言——数组基本知识(一)
目录 一.一维数组的初始化 二.数组的排序 ①冒泡排序: 代码: 没有第二个for循环运行结果如下: 正确的运行结果如下: ②选择排序 代码如下: 运行结果如图: 往期回顾: 一.一维数组的初始…...
vue2日历组件
【效果图】 <template><div style"width: 100%"><!-- <div> --><!-- <div>{{ startDate.getMonth() 1 - startDate.getDate() }}</div><div>{{ endDate.getMonth() 1 - endDate.getDate() }}</div> --&g…...
Unity C# 影响性能的坑点
c用的时间长了怕unity的坑忘了,记录一下。 GetComponent最好使用GetComponent<T>()的形式, 继承自Monobehaviour的函数要避免空的Awake()、Start()、Update()、FixedUpdate().这些空回调会造成性能浪费 GetComponent方法最好避免在Update当中使用…...
Redis(概念、IO模型、多路选择算法、安装和启停)
一、概念 关系型数据库是典型的行存储数据库,存在的问题是,按行存储的数据在物理层面占用的是连续存储空间,不适合海量数据存储。 Redis在生产中使用的最多的是用作数据缓存。 服务器先在缓存中查询数据,查到则返回,…...
多线程
线程是什么? 1、线程是进程的执行分支,一个进程内部的控制程序 2、一个进程至少有一个执行线程 3、从CPU角度来看,线程就是一个更轻量化的线程 4、线程在进程内部运行,所以本质就是在进程地址空间上运行 注意: 一…...
Spring Boot林业产品推荐系统:用户指南
摘 要 网络技术和计算机技术发展至今,已经拥有了深厚的理论基础,并在现实中进行了充分运用,尤其是基于计算机运行的软件更是受到各界的关注。加上现在人们已经步入信息时代,所以对于信息的宣传和管理就很关键。因此林业产品销售信…...
计算机网络 实验八 应用层相关协议分析
一、实验目的 熟悉CMailServer邮件服务软件和Outlook Express客户端软件的基本配置与使用;分析SMTP及POP3协议报文格式和SMTP及POP3协议的工作过程。 二、实验原理 为了观察到邮件发送的全部过程,需要在本地计算机上配置邮件服务器和客户代理。在这里我…...
实战ansible-playbook:Ansible Vault加密敏感数据(三)
在实际生产环境中,使用 Ansible Vault 来加密敏感数据是一种常见的做法。以下是一个详细的步骤和实际生产环境的使用案例,展示如何使用 Ansible Vault 来加密和管理敏感数据。 1. 安装 Ansible 确保你已经安装了 Ansible。如果还没有安装,可以使用以下命令进行安装: # 在…...
oracle 12c查看执行过的sql及当前正在执行的sql
V$SQL 提供了已经执行过及正在执行的SQL语句的信息。 一 查看共享池中所有sql的统计信息 #统计共享池中某类sql执行次数,总体执行时长,平均执行时长等信息,并按总体执行时长降序排序 SELECT INST_ID,SQL_ID,SQL_TEXT,SQL_FULLTEXT,EXECUTI…...
【大模型】Spring AI Alibaba 对接百炼平台大模型使用详解
目录 一、前言 二、Spring AI概述 2.1 spring ai是什么 2.2 Spring AI 核心能力 2.3 Spring AI 应用场景 三、Spring AI Alibaba 介绍 3.1 Spring AI Alibaba 是什么 3.2 Spring AI Alibaba 核心特点 3.3 Spring AI Alibaba 应用场景 四、SpringBoot 对接Spring AI Al…...
CSS:怎么把网站都变成灰色
当大家看到全站的内容都变成了灰色,包括按钮、图片等等。这时候我们可能会好奇这是怎么做到的呢? 有人会以为所有的内容都统一换了一个 CSS 样式,图片也全换成灰色的了,按钮等样式也统一换成了灰色样式。但你想想这个成本也太高了…...
Maven 常用命令
Maven 是一个强大的构建自动化工具,主要用于 Java 项目的管理和构建。 理解 Maven 命令对于高效管理与构建您的 Java 项目至关重要。 在本篇博客中,我们将探索每个 Java 开发者都应该掌握的一些最重要的 Maven 命令。 1. 设置 Maven 在深入探讨 Mave…...
【算法day1】数组:双指针算法
题目引用 这里以 1、LeetCode704.二分查找 2、LeetCode27.移除元素 3、LeetCode977.有序数组的平方 这三道题举例来说明数组中双指针的妙用。 1、二分查找 给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target ,写一个函数搜…...
CTF之密码学(DES)
一、基本原理 DES加密使用相同的密钥进行加密和解密操作。它使用一个56位的密钥(另外8位为奇偶校验位,不直接参与加密过程,因此实际密钥长度为56位),对64位的数据块进行加密,得到64位的密文。加密过程主要…...
【css实现收货地址下边的平行四边形彩色线条】
废话不多说,直接上代码: <div class"address-block" ><!-- 其他内容... --><div class"checked-ar"></div> </div> .address-block{height:120px;position: relative;overflow: hidden;width: 500p…...
Linux—进程概念学习-03
目录 Linux—进程学习—31.进程优先级1.1Linux中的进程优先级1.2修改进程优先级—top 2.进程的其他概念3.进程切换4.环境变量4.0环境变量的理解4.1环境变量的基本概念4.2添加环境变量—export4.3Linux中环境变量的由来4.4常见环境变量4.5和环境变量相关的命令4.6通过系统调用获…...
设计模式之破环单例模式和阻止破坏
目录 1. 序列化和反序列化2. 反射 这里单例模式就不多说了 23种设计模式之单例模式 1. 序列化和反序列化 这里用饿汉式来做例子 LazySingleton import java.io.Serializable;public class LazySingleton implements Serializable {private static LazySingleton lazySinglet…...
c++(斗罗大陆)
这次,作者编了斗罗大陆的武魂、魂力等级,目前只写到了11级 #include<iostream> #include<conio.h> #include<windows.h> #include<stdlib.h> #include<stdio.h> #include<time.h> #include<strin…...
NodeJs使用Addon调用C++
本文介绍的是NodeJs使用node-addon-api调用C的方法 node-addon-api是一个C封装,基于N-API构建,目的是提供一个更高级和更易用的接口,但它仍然依赖N-API。 官方参考文档 开发环境 必须具备NodeJs环境 Window配置NodeJs环境(绅士版…...
YOLOv11(Ultralytics)视频选定区域目标统计计数及跟踪
在计算机视觉的众多应用场景中,对特定区域的目标进行检测、跟踪与计数是一个常见且重要的需求。无论是在智慧交通中统计通过特定路口的车辆数量,还是在零售分析中追踪进入特定区域的顾客行为,这一功能都发挥着不可或缺的作用。 随着深度学习…...
【Nginx系列】Nginx配置优先级
💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…...
搭建私有docker仓库
1. 安装docker依赖包 sudo yum install -y yum-utils device-mapper-persistent-data lvm2 sudo yum-config-manager --add-repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo sudo yum install docker-ce docker-ce-cli containerd.io sudo systemctl …...
C语言练级->##__VA_ARGS__(可变参数)的用法
有什么用? 通常__VA_ARGS__用于宏定义,其中关于日志宏需要用的,printf 等支持可变参数的函数的宏封装。 首先我们先知道这个__VA_ARGS__的英文全称是“Variadic Arguments” 叫可变参数。说到可变参数学过C语言的朋友们应该都会想到printf&…...
在 wordpress 中简易目录插件添加滑动条
实现思路 给目录容器添加一个 固定高度,并设置 CSS 的 overflow 属性 为 auto 或 scroll,使其内容可滚动。确保目录的滚动行为独立于页面的整体滚动。优化用户体验,添加平滑滚动效果。 操作步骤 1. 检查目录的 HTML 结构 首先,…...
Linux和Ubuntu的关系
Linux和Ubuntu的关系: 1. Linux本身是内核,Ubuntu系统是基于Linux内核的操作系统。 2. Linux内核操作系统的构成: 内核、shell、文件系统、应用程序 -应用程序:文本编辑器等 -文件系统:文件存放在存储设备上的组织方…...
【大数据学习 | Spark-Core】详解Spark的Shuffle阶段
1. shuffle前言 对spark任务划分阶段,遇到宽依赖会断开,所以在stage 与 stage 之间会产生shuffle,大多数Spark作业的性能主要就是消耗在了shuffle环节,因为该环节包含了大量的磁盘IO、序列化、网络数据传输等操作。 负责shuffle…...
缓存方案分享
不知道大家平常更新缓存是怎么做的,但是大部分时候都是更新数据的同时更新缓存,今天和同事一起聊到一个缓存方案的问题,感觉很有趣、非常精妙,记录一下。 基于此本文将介绍几种常见的缓存更新策略,包括简单的缓存覆盖…...
从零开始配置Qt+VsCode环境
从零开始配置QtVsCode环境 文章目录 从零开始配置QtVsCode环境写在前面扩展安装及配置Qt Configure配置 VsCode创建Qt工程VsCodeQMakeMinGwVsCodeQMakeMsvcVsCodeCMakeMinGwVsCodeCMakeMsvcQtCreatorQMakeMinGw->VsCodeQtCreatorQMakeMsvc->VsCodeQtCreatorCMakeMinGw-&g…...
Linux中离线安装gcc
gcc在安装一些其他工具的经常用到,在此记录下如何安装gcc。 1.在线安装 yum -y install gcc 2.离线安装 2.1 获取安装包链接: https://pan.baidu.com/s/1oDvt64ByWs1w-evz5TXU7w?pwd9cfo mpfr-3.1.1-4.el7.x86_64.rpmlibmpc-1.0.1-3.el7.x86_64.rp…...
告别 Kafka,拥抱 Databend:构建高效低成本的用户行为分析体系
用户行为数据埋点指标是数据仓库中不可或缺的重要数据源之一,同时也是企业最宝贵的资产之一。通常情况下,用户行为数据分析包含两大数据源:用户行为分析日志和上游关系型数据库(如 MySQL)。基于这些数据,企…...
【python 迪杰斯特拉-最短路径算法】
- 算法实现 import heapq import networkx as nx import matplotlib.pyplot as pltdef dijkstra(graph, start, goal):distances {node: float("infinity") for node in graph}distances[start] 0parents {node: None for node in graph}priority_queue [(0, st…...
从〇开始深度学习(0)——背景知识与环境配置
从〇开始深度学习(0)——背景知识与环境配置 文章目录 从〇开始深度学习(0)——背景知识与环境配置写在前面1.背景知识1.1.Pytorch1.2.Anaconda1.3.Pycharm1.4.CPU与GPU1.5.整体关系 2.环境配置2.1.准备工作2.1.1.判断有无英伟达显卡2.1.2.清理电脑里的旧环境 2.1.安装Anaconda…...
【NLP 2、机器学习简介】
人生的苦难不过伏尔加河上的纤夫 —— 24.11.27 一、机器学习起源 机器学习的本质 —— 找规律 通过一定量的训练样本找到这些数据样本中所蕴含的规律 规律愈发复杂,机器学习就是在其中找到这些的规律,挖掘规律建立一个公式,导致对陌生的数…...
多目标优化算法——多目标粒子群优化算法(MOPSO)
Handling Multiple Objectives With Particle Swarm Optimization(多目标粒子群优化算法) 一、摘要: 本文提出了一种将帕累托优势引入粒子群优化算法的方法,使该算法能够处理具有多个目标函数的问题。与目前其他将粒子群算法扩展…...
Edify 3D: Scalable High-Quality 3D Asset Generation
Deep Imagination Research | NVIDIA 目录 一、Abstract 二、核心内容 1、多视图扩散模型 3、重建模型: 4、数据处理模块: 三、结果 1、文本到 3D 生成结果 2、图像到 3D 生成结果 3、四边形网格拓扑结构 一、Abstract NVIDIA 开发的用于高质量…...
探索校企合作新模式:职业院校大数据专业实验(实训)室建设指南
一、引言 作为一种强大的信息处理与分析工具,大数据技术在企业管理、科研探索、社会治理等多个领域均产生了广泛而深远的影响。在此背景下,大数据实验室的建设显得尤为重要,而校企合作则为这一建设提供了坚实的支撑。学校借助企业资源&#…...
YOLO的框架及版本迭代
YOLO(You Only Look Once)是一种非常流行的实时目标检测算法,其特点是将目标检测任务转换为一个回归问题,通过一次前向传播就可以同时完成目标的分类和定位。以下是YOLO框架的整体架构和工作原理: 一、YOLO的基本框架…...
第四十篇 DDP模型并行
摘要 分布式数据并行(DDP)技术是深度学习领域中的一项重要技术,它通过将数据和计算任务分布在多个计算节点上,实现了大规模模型的并行训练。 DDP技术的基本原理是将数据和模型参数分割成多个部分,每个部分由一个计算节点负责处理。在训练过程中,每个节点独立计算梯度,…...
鸿蒙进阶篇-状态管理之@Provide与@Consume
大家好,这里是鸿蒙开天组,今天我们来学习一下状态管理中的Provide与Consume。 一、概述 嘿!大家还记得这张图吗?不记得也要记得哦,因为这张图里的东西,既是高频必考面试题,也是实际开发中&…...
鸿蒙本地模拟器 模拟TCP服务端的过程
鸿蒙模拟器模拟TCP服务端的过程涉及几个关键步骤,主要包括创建TCPSocketServer实例、绑定IP地址和端口、监听连接请求、接收和发送数据以及处理连接事件。以下是详细的模拟过程: **1.创建TCPSocketServer实例:**首先,需要导入鸿蒙…...
Qt程序发布及打包成exe安装包
参考:Qt之程序发布以及打包成exe安装包 目录 一、简述 Qt 项目开发完成之后,需要打包发布程序,而因为用户电脑上没有 Qt 配置环境,所以需要将 release 生成的 exe 文件和所依赖的 dll 文件复制到一个文件夹中,然后再用 Inno Setup 打包工具打包成一个 exe 安装包,就可以…...
Spring Boot + ActiveMQ Artemis:快速实现高效消息队列处理功能
在现代微服务架构中,消息队列是实现异步通信、解耦系统的重要手段。而通过 Spring Boot 和 ActiveMQ Artemis,您可以快速搭建一个高效、可靠的消息队列处理系统,轻松应对订单处理、日志分析等场景。本文将带您从零开始,逐步实现一…...
【FPGA-MicroBlaze】串口收发以及相关函数讲解
前言 工具:Vivado2018.3及其所对应的SDK版本 目前网上有许多MicroBlaze 的入门教程,比如下面的这个参考文章,用串口打印一个hello world。 【FPGA】Xilinx MicroBlaze软核使用第一节:Hello World!_fpga软核microblaze-CSDN博客 个…...
CGAL CGAL::Polygon_mesh_processing::self_intersections解析
CGAL::Polygon_mesh_processing::self_intersections 是用于检测多边形网格(Polygon Mesh)中的自相交的函数。自相交是指网格中的某些面(例如三角形)与同一网格中的其他面交叉的情况。这种情况通常是不期望的,因为它会…...