基于springboot+vue快速搭建一个轻量级实用的博客系统

简介: 基于springboot+vue快速搭建一个轻量级实用的博客系统

在去年七月份,看着自己有一台空闲的服务器放在那里也是浪费,刚好我也有域名备案了就想着在公网部署一个博客系统。于是我去Github上找用Java语言写的博客系统,
找到自己喜欢的博客系统后拉下来研究了一通,发现他这个项目的技术栈和现在主流的互联网应用架构一样,比如用SpringCloud微服务、中间件、ES等等。

他这个项目用的倒是互联网公司主流框架,而且仅SpringBoot微服务都需要部署5个左右更何况还有ES等中间件,显然在我自己服务器(1核2G)这样的配置下不太可行。
于是我下定决心自己写一套轻量级的博客系统在不损失功能性的情况下保证以最少资源就可以部署。

Tip以下是我用SpringBoot+Vue搭建的轻量级博客的源码,有兴趣可以自己获取。

// Git代码
https://gitee.com/yeeevip/yeee-blog

1 功能介绍

这个博客项目从功能上整体划分为 后台管理端 和 前台用户端,管理端主要负责维护博客文章查看用户范围行为等,用户端主要用于展示博客文章和提供用户交互功能(点赞、评论等)

1.1 用户端

预览地址:一页的博客

  • 1 博客首页

blog-index2.png

  • 2 博客详情

blog-detail.png

  • 3 点赞/评论

blog-likecomment.png

1.2 管理端

  • 1 管理员输入账号密码后即可进入管理页面

blog-login.png

  • 2 在博客管理菜单下,有文章、专题、标题、分类管理

blog-list.png

  • 3 在文章管理下,我们首先创建文章,设置标题、分类等基本信息

blog-create.png

  • 4 紧接着列表页双击标题进入文章详情编辑页编辑/预览文章

blog-edit.png
blog-preview.png

  • 5 还有个专门的菜单展示博客的用户行为日志

blog-stats.png

2 技术设计

博客的技术架构上采用的是前后端分离,其中前端页面是基于Vue+Element-ui组件库来开发编译打包的,服务端则采用SpringBoot框架来自动化配置及按需引入Starter组件实现业务功能逻辑开发。

2.1 前后端分离+微服务

前后端独立,脱离相互依赖,降低开发部署影响风险提升开发效率

  • 1 前端页面独立使用Vue+Element-ui

blog-design-ui.png

  • 2 后端采用Maven+SpringBoot,并按照功能模块分层设计,虽然目前打包为一个单体项目,但是之后需要时很方便独立部署

blog-design-service.png

2.2 富文本编辑

博客详情内容编辑采用的是一个开源的功能强大的富文本编辑器 wangeditor(5.1.23)

wangeditor5是一款基于JavaScript开发的Web富文本编辑器,多达20个常用功能,使用简单,维护便利,提供了扩展插件、上传服务等等相关的资源,可以让我们在开发过程中更好地使用。

blog-design-richtext1.png
blog-design-richtext2.png

2.3 资源权限认证

博客管理端的资源权限认证框架使用的是 SpringSecurity + Oauth2 + Jwt 框架;SpringSecurity是Spring框架的安全框架,用于提供身份认证和授权功能,
使用Oauth2来实现认证服务器统一颁发/验证令牌,主要用于单点登录(SSO),生成令牌的数据格式使用的是Jwt它具有可靠性和自校验性。

blog-design-auth1.png

Tip我已经将SpringSecurity + Oauth2 + Jwt封装成为starter了,只需要引入对应server/cient就可以使用,有兴趣可以自己获取。

// Git代码
https://gitee.com/yeeevip/yeee-memo/tree/master/memo-parent/memo-common/common-auth

blog-design-auth2.png

2.4 接口性能优化

项目的业务比较简单主要就是查询,如查询详情页、列表页,显而易见系统的主要性能瓶颈就是数据库的QPS,所以我决定使用二级缓存 (redis + 本地缓存),在这里市面上已经有一个比较流行的框架JetCache。

JetCache是由阿里巴巴 Group 开源的一款基于 Spring 和 Redis 的分布式缓存框架,它的主要特点包括:基于注解、多级缓存、高性能、易用性。

  • 在需要的方法上直接加缓存注解@Cached

blog-design-jetcache.png

3 云服务器部署项目

要运行项目,我们得提前安装好 JDK(1.8)、Mysql(>=5.7)、Redis、Nginx(静态资源代理),其次就是将编译好的静态资源、功能服务Jar文件打包到服务器。

3.1 基础环境安装

  • 我这里使用的Docker安装的,具体安装过程本文章不详细复述

blog-deploy-base.png

3.2 静态资源部署

  • 1 管理端UI更改.env.production文件,然后执行npm命令打包

blog-deploy-adminui.png

  • 2 用户端UI更改.env.production文件,然后执行npm命令打包

blog-deploy-webui.png

  • 3 将编译打包好的静态文件分别上传服务器/home/webpage/对应目录中,并配置nginx.conf转发
server {
   
   
        listen 443 ssl;
        server_name wwww.yeee.vip;
        ...
        ## 管理端UI转发
        location ^~/adminui {
   
   
            alias /home/webpage/adminui/index.html;
        }
        ## 用户端UI转发
        location ^~/webui {
   
   
            alias /home/webpage/webui/index.html;
        }
    }

3.3 功能服务部署

  • 1 本地执行mvn clean install编译打包jar文件上传到服务器

blog-deploy-srvjar.png

  • 2 nginx.conf配置接口转发,执行java -jar 命令启动java程序
server {
   
   
        listen 443 ssl;
        server_name wwww.yeee.vip;
        ...
        ## 管理端接口
        location ^~/manage {
   
   
            proxy_pass       http://127.0.0.1:8801;
        }
        ## 用户端接口
        location ^~/api {
   
   
            proxy_pass       http://127.0.0.1:8801;
        }
    }
java -jar -Xms300m -Xmx300m yeee-app-bootstrap-1.0.0-SNAPSHOT.jar >./startup-blog.log&

最后

至此我整体上通过功能介绍、技术架构及部署流程完整的介绍了我的这个开源的轻量级博客系统,有什么问题大家可以评论区交流,也可以去github给我
提交PR或者提问,感谢大家支持。

Tip以下是我用SpringBoot+Vue搭建的轻量级博客的源码,有兴趣可以自己获取。

// Git代码
https://gitee.com/yeeevip/yeee-blog
目录
相关文章
|
19天前
|
存储 JavaScript 前端开发
基于 SpringBoot 和 Vue 开发校园点餐订餐外卖跑腿Java源码
一个非常实用的校园外卖系统,基于 SpringBoot 和 Vue 的开发。这一系统源于黑马的外卖案例项目 经过站长的进一步改进和优化,提供了更丰富的功能和更高的可用性。 这个项目的架构设计非常有趣。虽然它采用了SpringBoot和Vue的组合,但并不是一个完全分离的项目。 前端视图通过JS的方式引入了Vue和Element UI,既能利用Vue的快速开发优势,
101 13
|
27天前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
|
2月前
|
XML Java 数据库连接
SpringBoot集成Flowable:打造强大的工作流管理系统
在企业级应用开发中,工作流管理是一个核心组件,它能够帮助我们定义、执行和管理业务流程。Flowable是一个开源的工作流和业务流程管理(BPM)平台,它提供了强大的工作流引擎和建模工具。结合SpringBoot,我们可以快速构建一个高效、灵活的工作流管理系统。本文将探讨如何将Flowable集成到SpringBoot应用中,并展示其强大的功能。
322 1
|
2月前
|
JavaScript NoSQL Java
CC-ADMIN后台简介一个基于 Spring Boot 2.1.3 、SpringBootMybatis plus、JWT、Shiro、Redis、Vue quasar 的前后端分离的后台管理系统
CC-ADMIN后台简介一个基于 Spring Boot 2.1.3 、SpringBootMybatis plus、JWT、Shiro、Redis、Vue quasar 的前后端分离的后台管理系统
52 0
|
4月前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的服装商城管理系统
基于Java+Springboot+Vue开发的服装商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的服装商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
200 2
基于Java+Springboot+Vue开发的服装商城管理系统
|
3月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
198 1
|
4月前
|
前端开发 JavaScript Java
SpringBoot项目部署打包好的React、Vue项目刷新报错404
本文讨论了在SpringBoot项目中部署React或Vue打包好的前端项目时,刷新页面导致404错误的问题,并提供了两种解决方案:一是在SpringBoot启动类中配置错误页面重定向到index.html,二是将前端路由改为hash模式以避免刷新问题。
357 1
|
2月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,创建并配置 Spring Boot 项目,实现后端 API;然后,使用 Ant Design Pro Vue 创建前端项目,配置动态路由和菜单。通过具体案例,展示了如何快速搭建高效、易维护的项目框架。
128 62
|
2月前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
120 2
|
2月前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。