广州证券

SpringBoot + Vue + Electron 开发 QQ 版聊天工具的详细教程

 更新时间:2020年05月20日 14:51:16   转载 作者:不安分的猿人  
这篇文章主要介绍了SpringBoot + Vue + Electron 开发 QQ 版聊天工具的教程,本文通过截图实例代码相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

在这里插入图片描述

一、简介

这是一款基于 JS广州证券 实现的超轻量级桌面版聊天软件。主要适用于私有云项目内部聊天,企业内部管理通讯等功能,主要通讯协议websocket。也支持web网页聊天实现。文字聊天,互传文件,离线消息,群聊,断线重连等功能。

先看一下效果,下图左边是web版,右边为PC版。

二、本地搭建

2.1 技术栈

后端技术栈:

  • springboot: 让开发人员快速开发的一款Java的微服务框架。
  • tio: 是百万级网络框架oauth2.0: OAuth 2.0 是一个行业的标准授权协议。
  • OAuth 2.0 专注于简化客户端开发人员,同时为 Web 应用程序,桌面应用程序,手机和客厅设备提供特定的授权流程。

前端技术栈:

  • vue: 套用于构建用户界面的渐进式前端框架。
  • iview: 一套基于 Vue.js 的开源 UI 组件库,主要服务于 PC 界面的中后台产品。
  • electron: 用HTML,CSS和JavaScript来构建跨平台桌面应用程序的一个开源库。

2.2 启动后端服务

下载项目

使用gitBash 工具下载项目到本地

git clone

广州证券这里说明一下,项目的前后端代码这样就一次下载下来了。

  • V-IM-PC: 前端代码
  • V-IM-Server:后端代码

修改配置文件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方法,就可以开发环境启动后端服务了。

2.3 启动 web 前端服务

下载依赖

一次执行下面命令,就可下载前端项目所需的所有依赖包。

cd V-IM-PC #切换目录
npm install #npm安装依赖
yarn #yarn 

本地运行

本地运行两种方式,分别是 WebPC。命令如下:

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 #打包为可执行文件

2.4 启动 PC 前端

安装PC版

这里有两种方式,直接下载作者已经打包好的*.exe文件,或者使用上面的命令自己构建PC版本。
我这里直接下载的PC版本。

下载地址:https://gitee.com/lele-666/V-IM/raw/master/v-im%20Setup%200.5.3.exe
本地运行

安装好PC版后,双击运行即可。效果如下图:

广州证券这里配置一下服务就可连接到对应的后台服务了。

三、最后

按照这样的步骤走下来,几分钟就可以搭建QQ版聊天工具了。本篇讲了开发环境搭建聊天工具的步骤。当然服务器部署也特别简单的。如果你对这款聊天工具有兴趣,不妨动动手指哦!

附t-io项目地址:

总结

广州证券到此这篇配资公司 SpringBoot + Vue + Electron 开发 QQ 版聊天工具的详细教程的文章就介绍到这了,更多相关springboot vue electron qq聊天工具内容请搜索脚本之家以前的文章或继续浏览下面的广州证券相关的文章希望大家以后多多支持脚本之家!

广州证券相关的文章

  • 全民学编程之 Hello World

    全民学编程之 Hello World

    Hello World的迷人之处在于:它是简单的,即便没有任何基础,你也可以轻松理解,但它又不是苍白的,它带有一个程序语言鲜明的特色,体现了该语言最基本的思想和特征。同样也是Hello World,让人体会到第一份成功的喜悦
    2014-01-01
  • IEEE Spectrum 2014编程语言排行榜

    IEEE Spectrum 2014编程语言排行榜

    这篇文章主要介绍了IEEE Spectrum 2014编程语言排行榜,这不是TIOBE编程语言排行榜哦,需要的朋友可以参考下
    2014-08-08
  • Hadoop框架起步之图解SSH、免密登录原理和实现方法

    Hadoop框架起步之图解SSH、免密登录原理和实现方法

    这篇文章主要介绍了Hadoop框架起步之图解SSH、免密登录原理和实现方法,本文给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-07-07
  • 解决Chrome在新版MacOS上报错 NET::ERR_CERT_WEAK_KEY 的问题

    解决Chrome在新版MacOS上报错 NET::ERR_CERT_WEAK_KEY 的问题

    这篇文章主要介绍了解决Chrome在新版MacOS上报错 NET::ERR_CERT_WEAK_KEY 的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-05-05
  • 2019最新系统学习路线零基础如何转行大数据

    2019最新系统学习路线零基础如何转行大数据

    今天小编给你一个大数据工程师具体的学习路线图。非常不错,具有一定的参考借鉴价值,需要的朋友参考下吧
    2019-06-06
  • 编程语言里的静态、动态、强类型、弱类型等概念介绍

    编程语言里的静态、动态、强类型、弱类型等概念介绍

    这篇文章主要介绍了编程语言里的静态、动态、强类型、弱类型等概念介绍,需要的朋友可以参考下
    2015-05-05
  • 基于Token的身份验证之JWT基础教程

    基于Token的身份验证之JWT基础教程

    JWT(json web token)是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准。下面这篇文章主要给大家介绍了配资公司 基于Token的身份验证之JWT的基础相关资料,文中通过示例代码的非常详细,需要的朋友可以参考下
    2018-09-09
  • TIOBE编程语言排行榜前20的语言入门书籍推荐

    TIOBE编程语言排行榜前20的语言入门书籍推荐

    这篇文章主要为大家推荐了TIOBE编程语言排行榜前20的语言入门书籍,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • 编程趣事:当下流行编程语言的”讨厌”程度排行榜

    编程趣事:当下流行编程语言的”讨厌”程度排行榜

    这篇文章主要介绍了编程趣事:当下流行编程语言的”讨厌”程度排行榜,和小编的感觉一样,需要的朋友可以参考下
    2014-07-07
  • 支付宝 接口开发帮助(asp,php,asp.net,jsp)

    支付宝 接口开发帮助(asp,php,asp.net,jsp)

    支付宝的接口开发使用的技术含量并不高!因为使用的是HTTP普通GET和Post方式传递数据,而这些数据是传给您的程序由您的程序任意处理和支付宝服务器处理,所以重点在再流程和传参!
    2009-06-06

最新评论

深高CWB1(580014)

上汽CWB1(580016)

赣粤CWB1(580017)

石化CWB1(580019)

上港CWB1(580020)

青啤CWB1(580021)

国电CWB1(580022)

康美CWB1(580023)

宝钢CWB1(580024)

葛洲CWB1(580025)