这是一款基于
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
);
},
...
打包命令
本地测试功能问题,就可以进行项目打包了,打包命令也有两个:
npm run build #打包为web形式
npm run electron:build #打包为可执行文件
PC
前端安装PC版
这里有两种方式,直接下载作者已经打包好的*.exe
文件,或者使用上面的命令自己构建PC
版本。
我这里直接下载的PC
版本。
下载地址:https://gitee.com/lele-666/V-IM/raw/master/v-im%20Setup%200.5.3.exe
本地运行
安装好PC
版后,双击运行即可。效果如下图:
这里配置一下服务
就可连接到对应的后台服务了。
按照这样的步骤走下来,几分钟就可以搭建QQ
版聊天工具了。本篇讲了开发环境搭建聊天工具的步骤。当然服务器部署也特别简单的。如果你对这款聊天工具有兴趣,不妨动动手指哦!