局域网聊天工具

局域网聊天工具

仓库地址:https://github.com/Sunrisies/lan-share.git

一个基于 Rust + Axum 的局域网实时聊天工具,支持文本、图片和文件分享。

功能特性

  • ✅ 实时文本聊天
  • ✅ 图片上传和预览
  • ✅ 文件上传和下载
  • ✅ 在线用户数量显示
  • ✅ 消息历史记录
  • ✅ 消息时间戳
  • ✅ 文件大小限制提示(100MB)
  • ✅ 消息提示弹窗
  • ✅ 自动滚动到最新消息

技术栈

  • 后端: Rust + Axum + Tokio + WebSocket
  • 前端: HTML + Tailwind CSS + JavaScript
  • 通信: WebSocket 实时通信
  • 文件处理: Multipart 文件上传

快速开始

环境要求

  • Rust 1.70+
  • Cargo

安装

bash 复制代码
# 克隆项目
git clone https://github.com/Sunrisies/lan-share.git
cd lan-share

# 编译项目
cargo build --release

# 运行项目
cargo run

访问

服务器启动后,访问 http://localhost:3000

使用说明

聊天功能

  1. 发送文本消息

    • 在输入框中输入消息
    • 按 Enter 键或点击"发送"按钮
  2. 发送图片

    • 点击附件按钮
    • 选择图片文件
    • 图片会自动上传并显示预览
  3. 发送文件

    • 点击附件按钮
    • 选择任意文件
    • 文件会自动上传,其他用户可下载

界面说明

  • 在线用户数量: 页面顶部显示当前在线用户数
  • 消息历史: 新用户加入时可查看之前的消息
  • 时间戳: 每条消息显示发送时间
  • 消息提示: 操作成功或失败会显示提示弹窗

配置说明

修改端口

编辑 src/main.rs 文件:

rust 复制代码
let addr = SocketAddr::from(([0, 0, 0, 0], 3000)); // 修改端口号

修改文件大小限制

编辑 src/main.rs 文件:

rust 复制代码
const MAX_FILE_SIZE: usize = 100 * 1024 * 1024; // 修改大小限制(字节)

修改历史消息数量

编辑 src/main.rs 文件:

rust 复制代码
if history.len() > 100 { // 修改历史消息数量
    history.remove(0);
}

项目结构

复制代码
synchronization/
├── src/
│   └── main.rs          # 后端主程序
├── static/
│   └── index.html       # 前端界面
├── shared_files/        # 上传文件存储目录
├── Cargo.toml           # 项目依赖
└── README.md            # 项目文档

API 接口

WebSocket

  • 连接地址 : ws://localhost:3000/ws
  • 消息格式: JSON
消息类型
  1. 文本消息
json 复制代码
{
  "type": "message",
  "content": "消息内容",
  "sender_id": "用户ID"
}
  1. 图片消息
json 复制代码
{
  "type": "image",
  "content": "",
  "sender_id": "用户ID",
  "file_url": "/files/xxx.jpg",
  "file_name": "图片.jpg",
  "file_type": "image"
}
  1. 文件消息
json 复制代码
{
  "type": "file",
  "content": "",
  "sender_id": "用户ID",
  "file_url": "/files/xxx.zip",
  "file_name": "文件.zip",
  "file_type": "file"
}

HTTP

  • GET / - 主页面
  • POST /upload - 文件上传
  • GET /files/{filename} - 文件下载
  • GET /files - 文件列表

常见问题

1. 文件上传失败

  • 检查文件大小是否超过 100MB
  • 检查网络连接是否正常
  • 查看服务器控制台错误信息

2. WebSocket 连接失败

  • 确保服务器正在运行
  • 检查防火墙设置
  • 确认端口未被占用

3. 无法访问其他设备

  • 确保所有设备在同一局域网
  • 检查服务器绑定地址(默认 0.0.0.0)
  • 检查防火墙设置
相关推荐
烬羽1 天前
后端返回的 JSON 字符串,浏览器怎么"看懂"的?——Ajax 全链路拆解
javascript
半个落月1 天前
一个新手用 Bun + Axios 调通 DeepSeek API 的实践记录
javascript
不好听6131 天前
深入理解链表:线性数据结构的另一面
javascript·数据结构
林希_Rachel_傻希希1 天前
学React治好了我的焦虑症,1小时速通React 前20分钟。
前端·javascript·面试
小林ixn1 天前
从 Ajax 到异步编程:JSON 序列化、Event Loop 与 XHR 请求完全解析
javascript
guyoung1 天前
BoxAgnts 工具系统(7)——Skill 模板、Agent 代理与 Cron 调度
rust·agent·ai编程
丷丩1 天前
MapLibre GL JS第47课:添加动画图标
javascript·gis·动画·mapbox·maplibre
快乐的哈士奇1 天前
【Next.js实战①】Gmail API 按柜号检索邮件:OAuth 双 Cookie 与搜索 Fallback
开发语言·javascript·ecmascript
云水一下1 天前
Vue.js从零到精通系列(五):全局状态管理——Pinia 核心与实践
前端·javascript·vue.js
分布式存储与RustFS1 天前
基于Rust的国产开源对象存储RustFS:S3 Table对Iceberg数据湖的适配详解
rust·开源·iceberg·对象存储·rustfs·minio平替·s3 table