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

基于微信小程序的在线聊天功能实现:WebSocket通信实战

基于微信小程序的在线聊天功能实现:WebSocket通信实战

摘要

本文将详细介绍如何使用微信小程序结合WebSocket协议开发一个实时在线聊天功能。通过完整的代码示例和分步解析,涵盖界面布局、WebSocket连接管理、消息交互逻辑及服务端实现,适合新手快速掌握即时通信开发核心技术。

前言

在移动互联网时代,即时通信功能已成为众多应用的核心需求。WebSocket协议凭借其全双工通信低延迟长连接的特性,成为实现实时交互的首选方案。本文将基于微信小程序框架,结合Node.js服务端,从零构建一个具备消息发送/接收、界面自动滚动、消息差异化展示的在线聊天系统,并深入解析通信流程与优化技巧。

一、项目环境与技术栈

技术模块具体实现
开发工具微信开发者工具(稳定版)
前端框架微信小程序(WXML/WXSS/JavaScript)
通信协议WebSocket
服务端技术Node.js + ws 模块
运行环境本地调试(Windows/macOS)

二、完整代码实现

2.1 项目初始化与页面配置

步骤1:创建小程序项目
  1. 打开微信开发者工具,新建项目,命名为"在线聊天",选择"不使用模板"
  2. 项目目录结构:
在线聊天/
├─ pages/index/
│  ├─ index.wxml    // 页面结构
│  ├─ index.wxss    // 页面样式
│  ├─ index.js      // 逻辑代码
│  └─ index.json    // 页面配置
├─ images/          // 头像素材(需手动创建)
├─ app.js           // 应用逻辑
├─ app.json         // 全局配置
└─ app.wxss         // 全局样式
步骤2:配置导航栏(pages/index/index.json
{"navigationBarTitleText": "在线聊天","navigationBarBackgroundColor": "#FFF","navigationBarTextStyle": "black"
}

2.2 界面布局与样式设计

页面结构(index.wxml
<view class="chat"><!-- 消息滚动容器 --><scroll-view scroll-y scroll-into-view="item_{{ lastId }}" class="chat-container"><!-- 消息列表渲染 --><view wx:for="{{ list }}" wx:key="id" class="chat-message chat-message-{{ item.role }}" id="item_{{ item.id }}"><!-- 头像 --><image class="chat-avatar" src="/images/{{ item.role }}.png"></image><!-- 消息内容 --><view class="chat-content"><view>{{ item.content }}</view></view></view></scroll-view><!-- 消息输入栏 --><view class="message"><input type="text" placeholder="请输入聊天内容..." value="{{ content }}" bindinput="handleInput"/><button type="primary" bindtap="handleSend">发送</button></view>
</view>
页面样式(index.wxss
page {background-color: #f7f7f7;display: flex;flex-direction: column;height: 100vh;
}.chat-container {flex: 1;padding: 30rpx;overflow-y: auto;
}/* 隐藏滚动条 */
::-webkit-scrollbar { display: none; }.chat-message {display: flex;margin-bottom: 30rpx;align-items: flex-start;
}.chat-avatar {width: 60rpx;height: 60rpx;border-radius: 50%;margin-top: 5rpx;
}.chat-content view {padding: 15rpx 30rpx;border-radius: 10rpx;line-height: 60rpx;max-width: 70%;word-wrap: break-word;
}/* 用户消息(右对齐) */
.chat-message-me .chat-content view {float: right;background-color: #95d4ff;margin-left: 50rpx;
}/* 服务器消息(左对齐) */
.chat-message-server .chat-content view {float: left;background-color: #e3f2fd;margin-right: 50rpx;
}.message {height: 120rpx;padding: 20rpx;background-color: #fff;display: flex;align-items: center;border-top: 2rpx solid #eee;
}.message input {flex: 1;height: 80rpx;padding: 0 20rpx;font-size: 32rpx;border: 1rpx solid #ddd;border-radius: 40rpx;
}.message button {width: 180rpx;height: 80rpx;font-size: 32rpx;padding: 0;margin-left: 20rpx;background-color: #409eff;border: none;
}

2.3 WebSocket连接与消息处理(index.js

Page({data: {list: [],         // 消息列表lastId: '',       // 最新消息锚点content: ''       // 输入内容},ws: null, // WebSocket实例// 页面加载时建立连接onLoad() {this.ws = wx.connectSocket({url: 'ws://127.0.0.1:3000', // 本地服务器地址success: () => console.log('WebSocket连接成功'),fail: err => console.error('连接失败:', err)});// 监听消息接收this.ws.onMessage((msg) => {const data = JSON.parse(msg.data);this.handleReceiveMessage(data);});// 监听连接关闭this.ws.onClose(res => console.log('连接关闭:', res));},// 页面卸载时关闭连接onUnload() {this.ws.close();},// 输入框内容变化handleInput(e) {this.setData({ content: e.detail.value });},// 发送消息handleSend() {const message = this.data.content.trim();if (!message) return wx.showToast({ title: '消息不能为空', icon: 'none' });// 发送至服务器this.ws.send({ data: message });// 更新本地消息列表this.updateMessageList(message, 'me');this.setData({ content: '' });},// 处理接收消息handleReceiveMessage(data) {this.updateMessageList(data.content, 'server');},// 更新消息列表并自动滚动updateMessageList(content, role) {const list = this.data.list;const id = list.length;list.push({ id, content, role });this.setData({list,lastId: `item_${id}` // 锚点定位到最新消息});}
});

保存上述代码,运行程序,在微信小程序的控制台中会看到图所示的效果。图中控制台中输出的消息说明WebSocket连接成功。
在这里插入图片描述

2.4 服务器端代码(Node.js)

const WebSocket = require('ws');
const wss = new WebSocket.Server({ port: 3000 }); // 监听3000端口// 客户端连接事件
wss.on('connection', (ws) => {console.log('新客户端连接');// 接收客户端消息ws.on('message', (data) => {const message = data.toString();console.log('接收消息:', message);// 模拟自动回复(可对接业务逻辑)ws.send(JSON.stringify({content: `服务器回复:${message}`,timestamp: new Date().toLocaleTimeString()}));});// 连接关闭事件ws.on('close', () => console.log('客户端断开连接'));
});console.log('WebSocket服务器启动,地址:ws://127.0.0.1:3000');

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述

三、常见问题与解决方案

问题1:WebSocket连接失败

  • 原因分析
    1. 服务器未启动或端口被占用
    2. 微信开发者工具未关闭域名校验
  • 解决步骤
    # 1. 安装依赖并启动服务器
    npm install ws       # 安装WebSocket模块
    node index.js       # 启动服务端# 2. 微信开发者工具设置:
    # 详情 -> 本地设置 -> 勾选"不校验合法域名"
    

问题2:消息未更新到页面

  • 原因:未通过setData触发视图更新
  • 解决方案
    // 确保数据变更后调用setData
    this.setData({ list, lastId }); // 强制页面重新渲染
    

问题3:消息格式解析失败

  • 原因:服务端未正确序列化JSON数据
  • 解决方法
    // 服务端发送消息时使用JSON.stringify
    ws.send(JSON.stringify({ content: '消息内容' }));
    

四、项目总结

4.1 核心功能实现

  1. 实时通信:通过WebSocket实现客户端与服务端双向即时消息传输
  2. 界面交互
    • 消息列表自动滚动(scroll-into-view结合动态锚点)
    • 用户/服务器消息差异化展示(不同背景色、对齐方式)
  3. 状态管理:使用小程序setData机制实现数据与视图同步

4.2 技术关键点

  • WebSocket生命周期connectSocket建立连接,onMessage监听消息,close断开连接
  • 滚动容器优化:通过动态计算最新消息ID,实现scroll-view自动定位到最新消息
  • 界面布局:Flex弹性布局结合浮动实现消息气泡左右对齐

五、功能延伸与优化方向

5.1 基础功能扩展

  1. 多用户聊天
    • 添加用户登录认证(微信UnionID)
    • 实现群聊/单聊功能(维护用户列表与房间机制)
  2. 富媒体支持
    • 增加图片发送(wx.chooseImage + 二进制传输)
    • 集成表情面板(自定义组件或第三方库)
  3. 消息持久化
    • 对接微信云开发数据库存储历史消息
    • 实现消息分页加载(下拉刷新/上拉加载更多)

5.2 性能与稳定性优化

  1. 长连接维护
    • 添加心跳机制(定时发送PING帧防止断连)
    • 自动重连逻辑(onClose事件中重新连接)
  2. 列表渲染优化
    • 虚拟列表技术(处理上万条消息场景)
    • 消息分批加载(limit参数控制单次渲染数量)
  3. 安全加固
    • 服务端消息过滤(防止XSS攻击)
    • WebSocket连接鉴权(Token验证机制)

六、代码获取与运行指南

6.1 服务器端部署

  1. 创建index.js并粘贴服务端代码
  2. 安装依赖并启动:
npm install ws    # 安装WebSocket模块
node index.js    # 启动服务器(端口3000)

在这里插入图片描述

6.2 小程序配置

  1. 在微信开发者工具中导入项目
  2. 确保index.js中WebSocket地址与服务端一致:
url: 'ws://127.0.0.1:3000' // 本地地址,生产环境需替换为域名
  1. images文件夹中添加me.pngserver.png头像素材(尺寸建议80rpx×80rpx)

注意:生产环境需在微信公众平台配置合法域名并启用HTTPS,本地调试可勾选"不校验合法域名"。

在这里插入图片描述

七、总结

本文通过完整的实战案例,展示了微信小程序与WebSocket结合实现实时聊天的完整流程。从界面布局到通信逻辑,再到服务端实现,覆盖了即时通信开发的核心环节。开发者可在此基础上,根据业务需求扩展功能模块,进一步探索实时通信在社交、客服、协作等场景中的应用。

欢迎在评论区交流技术问题,或分享你的优化方案!


相关文章:

基于微信小程序的在线聊天功能实现:WebSocket通信实战

基于微信小程序的在线聊天功能实现&#xff1a;WebSocket通信实战 摘要 本文将详细介绍如何使用微信小程序结合WebSocket协议开发一个实时在线聊天功能。通过完整的代码示例和分步解析&#xff0c;涵盖界面布局、WebSocket连接管理、消息交互逻辑及服务端实现&#xff0c;适合…...

SaaS基于云计算、大数据的Java云HIS平台信息化系统源码

利用云计算、大数据等现代信息技术研发的医疗信息管理系统&#xff08;HIS&#xff09;实现了医院信息化从局域网向互联网转型&#xff0c;重新定义医疗卫生信息化建设的理念、构架、功能和运维体系。平台构建了以患者为中心的云架构、云服务、云运维的信息体系&#xff0c;实现…...

【Linux】动静态库的使用

&#x1f4dd;前言&#xff1a; 这篇文章我们来讲讲Linux——动静态库的使用 &#x1f3ac;个人简介&#xff1a;努力学习ing &#x1f4cb;个人专栏&#xff1a;Linux &#x1f380;CSDN主页 愚润求学 &#x1f304;其他专栏&#xff1a;C学习笔记&#xff0c;C语言入门基础&…...

10.2 LangChain v0.3全面解析:模块化架构+多代理系统如何实现效率飙升500%

LangChain 框架概述 关键词:LangChain 技术栈, 模块化架构, LCEL 表达式语言, LangGraph 多代理系统, LangServe 服务化部署 1. 框架定位与技术演进 LangChain 是当前大模型应用开发的事实标准框架,通过模块化设计实现 AI 工作流编排、工具链集成 和 复杂业务逻辑封装。其演…...

开源免费iOS或macOS安装虚拟机运行window/Linux系统

官网地址&#xff1a;UTM 开源地址&#xff1a;https://github.com/utmapp/UTM 基于 QEMU&#xff08;一个开源的硬件虚拟化工具&#xff09;&#xff0c;UTM 可以在 macOS&#xff08;包括 Apple Silicon M1/M2 和 Intel x86&#xff09;上运行 Windows、Linux、macOS&…...

《C++ vector详解》

目录 1.结构 2.构造函数 无参构造 指定参数构造 迭代器构造 初始化列表构造 3.拷贝构造 4.析构函数 5.遍历 重载【】 5.插入 扩容 尾插 指定位置插入 6.删除 尾删 指定位置删除 1.结构 vector是一个类似于数组一样的容器&#xff0c;里面可以放各种各样的元素…...

【现代深度学习技术】注意力机制07:Transformer

【作者主页】Francek Chen 【专栏介绍】 ⌈ ⌈ ⌈PyTorch深度学习 ⌋ ⌋ ⌋ 深度学习 (DL, Deep Learning) 特指基于深层神经网络模型和方法的机器学习。它是在统计机器学习、人工神经网络等算法模型基础上&#xff0c;结合当代大数据和大算力的发展而发展出来的。深度学习最重…...

浅析 Spring 启动过程:从源码到核心方法

浅析 Spring 启动过程&#xff1a;从源码到核心方法 一、Spring 注解方式启动类 Demo二、Spring 启动过程源码解析​AnnotationConfigApplicationContext构造函数refresh()方法详解 三、refresh()的核心方法/步骤obtainFreshBeanFactory() - 获取Bean工厂prepareBeanFactory(be…...

5G + 区块链:技术巨浪下的新型数字生态!

5G + 区块链:技术巨浪下的新型数字生态! 1. 为什么 5G 和区块链的结合如此重要? 区块链和 5G 这两大技术近几年风头正劲,一个在去中心化数据管理上展现潜力,一个在高吞吐低延迟通信方面带来颠覆。这两者结合,意味着: 更快的数据传输,让区块链交易速度提升,摆脱“低 …...

时序数据库IoTDB分布式架构解析与运维指南

一、IoTDB分布式架构概述 分布式系统由一组独立的计算机组成&#xff0c;通过网络通信&#xff0c;对外表现为一个统一的整体。IoTDB的原生分布式架构将服务分为两个核心部分&#xff1a; ‌ConfigNode&#xff08;CN&#xff09;‌&#xff1a;管理节点&#xff0c;负责管理…...

CertiK荣获以太坊基金会两项资助,领跑zkEVM形式化验证

近日&#xff0c;以太坊基金会公布了2025年第一季度研究资助名单&#xff0c;全球最大的Web3.0安全公司CertiK荣获两项研究资助&#xff0c;源于zkEVM形式化验证竞赛。这不仅是以太坊扩展性战略的里程碑式事件&#xff0c;也进一步彰显了CertiK在零知识证明&#xff08;ZKP&…...

c++和c的不同

c:面向对象&#xff08;封装&#xff0c;继承&#xff0c;多态&#xff09;&#xff0c;STL&#xff0c;模板 一、基础定义与背景 C语言 诞生年代&#xff1a;20世纪70年代&#xff0c;Dennis Ritchie在贝尔实验室开发。主要特点&#xff1a; 过程式、结构化编程面向系统底层…...

光流 | Matlab工具中的光流算法

在MATLAB中,光流算法用于估计图像序列中物体的运动。以下是详细解释及实现步骤: 1. 光流算法基础 光流基于两个核心假设: 亮度恒定:同一物体在连续帧中的像素亮度不变。微小运动:相邻帧之间的时间间隔短,物体运动幅度小。常见算法: Lucas-Kanade (局部方法):假设局部窗…...

@Controller 与 @RestController-笔记

1.Controller与RestController对比 Spring MVC 中 Controller 与 RestController 的功能对比&#xff1a; Controller是Spring MVC中用于标识一个类作为控制器的标准注解。它允许处理HTTP请求&#xff0c;并返回视图名称&#xff0c;通常和视图解析器一起使用来渲染页面。而R…...

LeetCode 热题 100 105. 从前序与中序遍历序列构造二叉树

LeetCode 热题 100 | 105. 从前序与中序遍历序列构造二叉树 大家好&#xff0c;今天我们来解决一道经典的二叉树问题——从前序与中序遍历序列构造二叉树。这道题在 LeetCode 上被标记为中等难度&#xff0c;要求根据给定的前序遍历和中序遍历序列&#xff0c;构造并返回二叉树…...

IP地址查询助力业务增长

IP地址查询的技术基石 IP地址分为IPv4和IPv6&#xff0c;目前IPv4仍广泛应用&#xff0c;它由四个0-255的十进制数组成&#xff0c;如192.168.1.1。而IPv6为应对IPv4地址枯竭问题而生&#xff0c;采用128位地址长度&#xff0c;极大扩充了地址空间。IP地址查询主要依赖庞大的I…...

Nginx核心功能及同类产品对比

Nginx 作为一款高性能的 Web 服务器和反向代理工具&#xff0c;凭借其独特的架构设计和丰富的功能&#xff0c;成为互联网基础设施中不可或缺的组件。以下是其核心功能及与同类产品&#xff08;如 HAProxy、LVS&#xff09;的对比优势&#xff1a; 一、Nginx 核心功能 高性能架…...

抽奖系统-奖品-活动

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 前言获取奖品列表前端页面活动创建需求分析活动创建后端实现1-控制层实现及校验活动活动创建后端实现2-保存信息活动插入活动奖品插入 整合活动信息存入redis测试活…...

【Java】 volatile 和 synchronized 的比较及使用场景

在 Java 的并发编程中&#xff0c;volatile 和 synchronized 是两个常用的关键字&#xff0c;它们分别用于保证多线程环境中的 可见性 和 原子性&#xff0c;但它们的工作原理和适用场景却有所不同。今天&#xff0c;我们将深入探讨这两个关键字的异同&#xff0c;帮助大家理解…...

javaScript简单版

简介 JavaScript&#xff08;简称:JS)是一门跨平台、面向对象的脚本语言&#xff0c;是用来控制网页行为&#xff0c;实现页面的交互效果。 JavaScript和Java是完全不同的语言&#xff0c;不论是概念还是设计。但是基础语法类似。 组成: ECMAScript:规定了JS基础语法核心知…...

三种常见接口测试工具(Apipost、Apifox、Postman)

三种常见接口测试工具&#xff08;Apipost、Apifox、Postman&#xff09;的用法及优缺点对比总结&#xff1a; &#x1f527; 一、Apipost ✅ 基本用法 支持 RESTful API、GraphQL、WebSocket 等接口调试自动生成接口文档支持环境变量、接口分组、接口测试用例编写可进行前置…...

蓝桥杯13届国B 完全日期

题目描述。 如果一个日期中年月日的各位数字之和是完全平方数&#xff0c;则称为一个完全日期。 例如&#xff1a;2021 年 6 月 5 日的各位数字之和为 20216516&#xff0c;而 16 是一个完全平方数&#xff0c;它是 4 的平方。所以 2021 年 6 月 5 日是一个完全日期。 例如&…...

kafka connect 大概了解

kafka connect Introduction Kafka Connect is the component of Kafka that provides data integration between databases, key-value stores, search indexes, file systems, and Kafka brokers. kafka connect 是一个框架&#xff0c;用来帮助集成其他系统的数据到kafka…...

嵌入式培训之数据结构学习(三)gdb调试、单向链表练习、顺序表与链表对比

目录 一、gdb调试 &#xff08;一&#xff09;一般调试步骤与命令 &#xff08;二&#xff09;找段错误&#xff08;无下断点的地方&#xff09; &#xff08;三&#xff09;调试命令 二、单向链表练习 1、查找链表的中间结点&#xff08;用快慢指针&#xff09; 2、找出…...

MySQL——九、锁

分类 全局锁表级锁行级锁 全局锁 做全库的逻辑备份 flush tables with read lock; unlock tables;在InnoDB引擎中&#xff0c;我们可以在备份时加上参数–single-transaction参数来完成不加锁的一致性数据备份 mysqldump --single-transaction -uroot -p123456 itcast>…...

精益数据分析(57/126):创业移情阶段的核心要点与实践方法

精益数据分析&#xff08;57/126&#xff09;&#xff1a;创业移情阶段的核心要点与实践方法 在创业的浩瀚征程中&#xff0c;每一个阶段都承载着独特的使命与挑战。今天&#xff0c;我们继续秉持共同进步的理念&#xff0c;深入研读《精益数据分析》&#xff0c;聚焦创业的首…...

服务器被打了怎么应对

云服务器遭受攻击该如何应对&#xff1f; 在互联网时代&#xff0c;不少使用云服务器的网络工作者常常会面临网络攻击的威胁。若云服务器未配置完善的防火墙&#xff0c;极易引发服务器宕机&#xff0c;甚至被封禁隔离&#xff08;俗称“陷入黑洞”&#xff09;&#xff0c;进…...

Halcon案例(二):C#联合Halcon回形针以及方向

本案例分3部分 识别效果,分别显示识别前后识别后;代码展示,分别是Halcon源码和Halcon转为C#的代码代码解释(解释在源码中); 原图如下 识别后图像: 其中计算回形针与X轴之间的夹角 Halcon代码: * clip.hdev: Orientation of clips *识别图像中的回形针,并且计算回形针与X轴之间…...

Spyglass:跨时钟域同步(同步单元)

相关阅读 Spyglasshttps://blog.csdn.net/weixin_45791458/category_12828934.html?spm1001.2014.3001.5482 简介 同步单元方案可以用于控制/数据信号跨时钟域同步&#xff0c;该方案使用约束或参数将目标时钟域中单元指定为同步单元&#xff0c;如图1所示。 图1 同步单元方案…...

JAVA异常体系

在 Java 里&#xff0c;异常体系是其错误处理机制的核心内容&#xff0c;它能够帮助开发者有效应对程序运行时出现的各种意外状况。 异常体系的基本架构 它主要包含两个重要分支&#xff1a; Error&#xff08;错误&#xff09;&#xff1a;这类异常是程序自身无法处理的严重…...

Milvus 视角看主流嵌入式模型(Embeddings)

嵌入是一种机器学习概念&#xff0c;用于将数据映射到高维空间&#xff0c;其中语义相似的数据被紧密排列在一起。嵌入模型通常是 BERT 或其他 Transformer 系列的深度神经网络&#xff0c;它能够有效地用一系列数字&#xff08;称为向量&#xff09;来表示文本、图像和其他数据…...

全面解析 Server-Sent Events(SSE)协议:从大模型流式输出到实时通信场景

全面解析 Server-Sent Events&#xff08;SSE&#xff09;协议&#xff1a;从大模型流式输出到实时通信场景 一、SSE 协议概述 Server-Sent Events&#xff08;SSE&#xff09; 是 HTML5 标准中定义的一种基于 HTTP 的服务器向客户端单向推送实时数据的协议。其核心特性包括&a…...

数据库系统概论|第七章:数据库设计—课程笔记

前言 本章讨论数据库设计的技术和方法&#xff0c;主要讨论基于关系数据库管理系统的关系数据库设计问题&#xff0c;而关于数据库的设计过程中&#xff0c;关于数据模型、关系模型等基本概念在前文中已经有详尽介绍&#xff0c;此处便不再赘述&#xff0c;本文主要围绕概念结…...

Java项目拷打(外卖+点评)

一、点评星球&#xff08;黑马点评&#xff09; 1、项目概述 1.1、项目简介 本项目是基于Spring Boot与Redis深度整合的前后端分离的点评平台。系统以Redis为核心技术支撑&#xff0c;重点解决高并发场景下的缓存穿透、击穿、雪崩等问题&#xff0c;涵盖商户展示、优惠券秒杀…...

MCP:开启AI的“万物互联”时代

MCP&#xff1a;开启AI的“万物互联”时代 ——从协议标准到生态革命的技术跃迁 引言&#xff1a;AI的“最后一公里”困境 在2025年的AI技术浪潮中&#xff0c;大模型已从参数竞赛转向应用落地之争。尽管模型能生成流畅的对话、创作诗歌甚至编写代码&#xff0c;但用户逐渐发现…...

【PostgreSQL数据分析实战:从数据清洗到可视化全流程】附录-D. 扩展插件列表(PostGIS/PostgREST等)

&#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 &#x1f449; 点击关注不迷路 文章大纲 附录D. PostgreSQL扩展插件速查表一、插件分类速查表二、核心插件详解三、安装与配置指南四、应用场景模板五、版本兼容性说明六、维护与优化建议七、官方资源与工具八、附录…...

Spring Boot拦截器详解:原理、实现与应用场景

精心整理了最新的面试资料和简历模板&#xff0c;有需要的可以自行获取 点击前往百度网盘获取 点击前往夸克网盘获取 一、拦截器概述 拦截器&#xff08;Interceptor&#xff09;是Spring MVC框架中用于对请求进行预处理和后处理的组件&#xff0c;主要作用于Controller层。相…...

万字解析:Java字符串

目录 一、 String类 1. String类的初始化 1.1 常用的三种构造String类的方式 1.2 String类如何存储字符串&#xff1f; 2. String类的常用功能方法 2.0 字符串长度的获取 2.1 String对象的比较 2.2 字符/字符串的查找 2.3 字符串的转化 2.4 字符 / 字符串的替换 2.5…...

0514得物、0509滴滴面试总结复盘

目前最欠缺的还是&#xff0c;编码不是很熟&#xff0c;很多都遇到过但是就是写不出来&#xff0c;或者靠背先写一点&#xff0c;然后去加&#xff0c;加的过程没考虑逻辑是不是对的&#xff0c;用滴滴面试官的一句话&#xff0c;就是多刷多练多编码&#xff01; 第二块就是项目…...

记录算法笔记(20025.5.14)对称二叉树

给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 示例 1&#xff1a; 输入&#xff1a;root [1,2,2,3,4,4,3] 输出&#xff1a;true 示例 2&#xff1a; 输入&#xff1a;root [1,2,2,null,3,null,3] 输出&#xff1a;false 提示&#xff1a; 树中节点数目…...

AI大模型从0到1记录学习 linux day23

第 1 章 MySQL概述 1.1 基本概念 1.1.1 数据库是什么&#xff1f; 数据库&#xff08;DB&#xff1a;Database&#xff09;&#xff1a;存储数据的地方。 1.1.2 为什么要用数据库&#xff1f; 应用程序产生的数据是在内存中的&#xff0c;如果程序退出或者是断电了&#xff0c;…...

用git下载vcpkg时出现Connection was reset时的处理

用git安装vcpkg时出现Connect was rest&#xff08;如上图&#xff09;。多谢这位网友的博文解决了问题&#xff1a; 通过:http.sslVerify false全局来设置&#xff0c;执行以下命令&#xff1a; git config --global http.sslVerify "false" 原文链接&#xff1a…...

【数据库复习】SQL语言

一、SQL通用语法与分类 &#xff08;一&#xff09;SQL通用语法 SQL语句的格式通常较为规范&#xff0c;以关键字开头&#xff0c;如CREATE、SELECT、INSERT等&#xff0c;后跟具体的表名、字段名和条件等。在MySQL中&#xff0c;还可以使用help命令获取帮助信息&#xff0c;…...

二叉树——层序遍历

目录 实现层序遍历 判断是否为完全二叉树 实现层序遍历 除了先序遍历&#xff0c;中序遍历&#xff0c;后序遍历外&#xff0c;还可以对二叉树进行层序遍历。设二叉树的结点所在层数为1&#xff0c;层序遍历就是从所在二叉树的根结点出发&#xff0c;首先访问第一层的树根结点…...

Seata源码—2.seata-samples项目介绍

大纲 1.seata-samples的配置文件和启动类 2.seata-samples业务服务启动时的核心工作 3.seata-samples库存服务的连接池配置 4.Seata对数据库连接池代理配置的分析 5.Dubbo RPC通信过程中传递全局事务XID 6.Seata跟Dubbo整合的Filter(基于SPI机制) 7.seata-samples的AT事…...

企业数字化转型背景下的企业知识管理挑战与经验杂谈

一、引言 在数字化转型的浪潮下&#xff0c;企业知识管理正面临前所未有的挑战。随着数据量的急剧增长&#xff0c;企业内部积累的信息呈现出碎片化、分散化的趋势&#xff0c;传统的知识管理体系已难以有效应对这一变革。首先&#xff0c;信息碎片化问题日益严重&#xff0c;…...

第二章:磁盘管理与文件管理

一、磁盘管理 1.windows和Linux磁盘管理的区别 windows资源管理方式 系统一般安装在C盘 C盘下的"Windows"目录是操作系统的核心 C盘下的"Program Files"目录下安装软件 C盘下的"用户"目录是所有的用户&#xff0c;包括超级管理员也在其中 …...

Java版OA管理系统源码 手机版OA系统源码

Java版OA管理系统源码 手机版OA系统源码 一&#xff1a;OA系统的主要优势 1. 提升效率 减少纸质流程和重复性工作&#xff0c;自动化处理常规事务&#xff0c;缩短响应时间。 2. 降低成本 节省纸张、打印、通讯及人力成本&#xff0c;优化资源分配。 3. 规范管理 固化企…...

springboot踩坑记录

之前运行好端端的项目&#xff0c;今天下午打开只是添加了一个文件之后 再运行都报Failed to configure a DataSource: url attribute is not specified and no embedded datasource could be configured.Reason: Failed to determine a suitable driver class Action: Conside…...

SpringAI

机器学习&#xff1a; 定义&#xff1a;人工智能的子领域&#xff0c;通过数据驱动的方法让计算机学习规律&#xff0c;进行预测或决策。 核心方法&#xff1a; 监督学习&#xff08;如线性回归、SVM&#xff09;。 无监督学习&#xff08;如聚类、降维&#xff09;。 强化学…...