这是一款基于
JS
实现的超轻量级桌面版聊天软件。主要适用于私有云项目内部聊天,企业内部管理通讯等功能,主要通讯协议websocket。也支持web网页聊天实现。文字聊天,互传文件,离线消息,群聊,断线重连等功能。
先看一下效果,下图左边是web
版,右边为PC
版。
后端技术栈:
前端技术栈:
下载项目
使用gitBash
工具下载项目到本地
git clone https://gitee.com/lele-666/V-IM.git 复制代码
这里说明一下,项目的前后端代码这样就一次下载下来了。
修改配置文件application.properties
这里主要修改数据库连接和文件上传的路径:
#server.port=8081 spring.mvc.static-path-pattern=/** #上传的文件路径 web.upload-path=D:/Temp spring.datasource.driver-class-name=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1:3306/vim?useSSL=false spring.datasource.username=root spring.datasource.password=123456 ... 复制代码
注: 后端服务的端口根据自己的需要进行设置即可,默认 8080
。
初始化数据库
数据库初始化脚本在V-IM-Server\doc\init-20181231.sql
,通过Navicat
数据库可视化工具导入数据库脚本即可。
运行VServerApplication.java
将项目导入到Idea
,自动下载项目的相关依赖后,直接运行项目VServerApplication
类的main
方法,就可以开发环境启动后端服务了。
web
前端服务下载依赖
一次执行下面命令,就可下载前端项目所需的所有依赖包。
cd V-IM-PC #切换目录 npm install #npm安装依赖 yarn #yarn 复制代码
本地运行
本地运行两种方式,分别是 Web
和PC
。命令如下:
npm run serve #以web方式运行 npm run electron:serve #以客户端方式运行 复制代码
注: web
启动时,前端项目访问的端口是8080
,会与后端的端口相同,所以将前端的访问的端口修改下就可以了。修改的文件为index.js
:
export default { app_name: "V-IM", http_protocol: "http", http_port: 8080, #修改这个地方 ws_port: 9326, init: "/api/user/init", his_url: "/api/message/list", chat_users_url: "/api/user/chatUserList", token_path: "/oauth/token", register_url: "/register", ws_protocol: "ws", getHostUrl: function() { return ( this.http_protocol + "://" + localStorage.getItem("host") + ":" + this.http_port ); }, ... 复制代码
web
版的效果:
PC
版的效果:
打包命令
本地测试功能问题,就可以进行项目打包了,打包命令也有两个:
npm run build #打包为web形式 npm run electron:build #打包为可执行文件 复制代码
PC
前端安装PC版
这里有两种方式,直接下载作者已经打包好的*.exe
文件,或者使用上面的命令自己构建PC
版本。
我这里直接下载的PC
版本。
下载地址:gitee.com/lele-666/V-…
本地运行
安装好PC
版后,双击运行即可。效果如下图:
服务
就可连接到对应的后台服务了。
按照这样的步骤走下来,几分钟就可以搭建QQ
版聊天工具了。本篇讲了开发环境搭建聊天工具的步骤。当然服务器部署也特别简单的。如果你对这款聊天工具有兴趣,不妨动动手指哦!