基于Vue+SpringBoot+MySQL实现个人博客系统

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 基于Vue+SpringBoot+MySQL实现个人博客系统

基于Vue+SpringBoot+MySQL实现个人博客系统

实现前后端完全分离:

前端

  • 使用Vue等技术构建单页应用
  • 通过Axios或Fetch调用后端提供的API
  • 关注交互逻辑和UI展现

后端

  • 提供基于RESTful的JSON API
  • 只关注数据与业务逻辑
  • 不关心前端技术

交互

  • 前端通过Axios等调用后端API
  • 后端返回JSON数据
  • 前端根据JSON数据更新UI

优点

  • 前后端解耦
  • 独立开发、部署
  • 更易于维护
  • 前端可替换
  • 后端可扩展

例如:

// 前端
axios.get('/api/articles').then(response => {
  this.articles = response.data
})
// 后端
@GetMapping("/api/articles")
public List<Article> getArticles() {
  return articleService.findAll();
}

上述代码实现了:

  • 前端调用/api/articles接口获取文章列表数据
  • 后端提供基于RESTful的JSON API接口
  • 通过JSON数据交互

实现前后端分离。

前端只关注使用JSON数据更新UI,后端只关注提供JSON数据。

部署方面,前端可以部署到任何webapp上,后端可以部署到任何Java应用服务器。

通过这种方式,我们可以:

  • 独立开发前后端
  • 独立部署前后端
  • 通过JSON数据进行通信

前端(Vue):

创建Vue项目,包含路由、状态管理等

根据你提供的需求,可按以下步骤创建Vue项目:

  1. 创建项目
vue create my-blog

选择默认配置(请选择Manually select features)

  1. 安装依赖
npm install vue-router vuex axios
  • vue-router:路由
  • vuex:状态管理
  • axios:请求库
  1. 定义路由(router/index.js)
import VueRouter from 'vue-router'
const router = new VueRouter({
  routes: [
    { path: '/', component: ArticleList }
  ]
})
export default router
  1. 创建状态管理器(store/index.js)
import Vuex from 'vuex'
const store = new Vuex.Store({
  state: {
  },
  mutations: {
  },
  actions: { 
  }
})
export default store
  1. 定义接口服务(api/article.js)
import axios from 'axios'
export default {
  getArticles() {
    return axios.get('/api/articles')  
  }
}

通过这种方式,我们基本搭建好路由、状态管理和接口调用功能,后续再根据需求完善组件、actions等内容。

定义ArticleList组件,获取文章列表

ArticleList组件获取文章列表的代码如下:

<template>
  <ul>
    <li v-for="article in articles">
     {{ article.title }}   
    </li>    
  </ul>
</template>
<script>
export default {  
  data() {
    return {
      articles: []
    }   
  },
  created() {
    this.getArticles()    
  },   
  methods: {
    async getArticles() {
      let { data } = await axios.get('/api/articles')    
      this.articles = data    
    }    
  }    
}   
</script>
  • data函数中定义articles数组保存文章数据
  • created生命周期钩子中,调用getArticles方法获取文章列表
  • getArticles方法异步调用接口请求文章列表
  • 接口请求成功后,将响应数据data赋值给articles,从而渲染文章列表

主要功能包括:

  1. 定义articles数据
  2. created钩子中调用接口
  3. 通过await执行异步接口请求
  4. 接口成功后设置articles渲染列表

上述代码实现了:

  • 定义ArticleList组件渲染文章列表
  • 在创建时调用接口获取文章数据
  • 设置数据后渲染列表

重复定义ArticleEdit、TagList等组件

根据你提供的需求,可按以下步骤定义其他组件:

  1. ArticleEdit组件
<template>
  <form @submit.prevent="saveArticle">
    <input v-model="article.title" /> 
    <textarea v-model="article.content"></textarea>
    <button type="submit">保存文章</button>   
  </form>  
</template>
<script>
export default {
  data() {
    return {
      article: {
        title: '',
        content: ''  
      }
    }
  },
  methods: {    
    async saveArticle() {
      await axios.post('/api/article', this.article)
      this.$router.push('/')     
    }    
  }    
}
</script>
  1. TagList组件
<template>
 <ul>
   <li v-for="tag in tags">
    {{ tag.name }}
   </li>
 </ul>  
</template>
<script>
export default {    
  data() {
    return {
      tags: []
    }      
  },  
  async created() {
    let { data } = await axios.get('/api/tags')
    this.tags = data    
  }   
}
</script>
  1. CommentList组件
<template>
  <ul>  
   <li v-for="comment in comments">
     <p>{{ comment.content }}</p>   
   </li>      
  </ul>
</template>
<script>
export default {
  data() {
    return {
      comments: []
    }
  },
  async created() {
    let { data } = await axios.get('/api/comments')
    this.comments = data      
  }        
}
</script>

通过定义不同的组件,对应处理不同的数据和业务逻辑,我们就可以完整展现页面所需功能。

后端(Spring Boot):

创建Spring Boot项目,配置JPA和MySQL依赖

根据需求,可以按照以下步骤搭建Spring Boot项目:

  1. 使用IDE(IDEA、STS)创建 Spring Initialzr 项目

选择:

  • Group: com.example
  • Artifact: demo
  • Java: 1.8
  • Packaging: Jar
  • Dependencies:
  • Web
  • MySQL
  • JPA
  1. 添加MySQL连接信息

application.properties添加:

spring.datasource.url= jdbc:mysql://localhost:3306/demo  
spring.datasource.username= root
spring.datasource.password= 123456
  1. 定义Article实体类
@Entity
public class Article {
  @Id  
  @GeneratedValue
  private Long id;
  private String title;
  private String content;
  // getters and setters
}
  1. 定义ArticleRepository
public interface ArticleRepository extends JpaRepository<Article, Long> {
}
  1. 定义ArticleService
@Service
public class ArticleService {
  @Autowired
  ArticleRepository articleRepository;
  public List<Article> findAll() {
    return articleRepository.findAll();
  }
}
  1. 定义ArticleController提供API
@GetMapping("/articles")
public List<Article> findAll() {
  return articleService.findAll();
}

通过这种方式,我们基于Spring Boot + JPA 就能快速搭建一个连接MySQL的示例项目。

定义Article实体类映射到数据库表

,Article实体类可以如下定义:

@Entity
@Table(name = "articles")
public class Article {
  @Id  
  @GeneratedValue  
  private Long id;
  @Column(name = "title")  
  private String title;  
  @Column(name = "content")  
  private String content;  
  // getters and setters  
}

主要特征有:

  1. 使用@Entity注解声明这是一个实体类
  2. 使用@Table指定数据库表名为articles
  3. id字段使用@Id@GeneratedValue注解,指定为主键和自动增长
  4. 其他字段使用@Column注解指定数据库列名
  5. 为字段提供对应的gettersetter方法

当我们运行项目时,Spring Data JPA 会根据此对象对应的表的结构:

CREATE TABLE articles (
  id bigint AUTO_INCREMENT,   
  title VARCHAR(255),
  content TEXT,
  PRIMARY KEY (id)
)

所以通过在实体类上使用JPA注解,我们就实现了:

  • 定义一个映射到数据库表的实体类
  • 指定主键和列名映射
  • 将Java属性映射到数据库列

JPA在后续进行持久化时,就会根据此对象操作对应的数据库表。

定义ArticleRepository接口,继承JpaRepository

根据需求,ArticleRepository可以如下定义:

public interface ArticleRepository extends JpaRepository<Article, Long> {
}
  • 继承JpaRepository
  • 参数一:管理的实体类Article
  • 参数二:实体类主键类型Long

通过继承JpaRepository,我们即声明了一个操作Article实体类与数据库表对应的仓库接口。

Spring Data JPA会自动为我们实现该接口,提供如下方法:

save()   // 保存实体
findAll() //查询全部
findById() // 根据id查询
...

比如findAll()方法实现为:

public List<Article> findAll() {
  return em.createQuery("from Article").getResultList();
}

所以通过继承JpaRepository,我们只需要定义接口即可:

  • 不需要编写任何实现
  • Spring Data JPA会自动实现
  • 提供CRUD和复杂查询的方法

在后续ArticleService中,我们可以通过自动装配的方式使用此仓库:

@Autowired
ArticleRepository articleRepository;

通过调用其方法实现与数据库的交互。

定义ArticleService服务,调用Repository

根据需求,ArticleService可以如下定义:

@Service
public class ArticleService {
  @Autowired 
  ArticleRepository articleRepository;
  public List<Article> findAll() {
    return articleRepository.findAll();
  }
  // 定义其他方法 
}
  • 使用@Service注解声明这是一个服务类
  • 通过@Autowired自动装配ArticleRepository
  • 定义findAll()方法调用仓库的findAll()方法获取全部文章
  • 可以定义其他业务方法,调用Repository

所以在服务类中:

  1. 通过@Autowired注入对应的仓库
  2. 定义业务方法,调用仓库方法
  3. 提供业务逻辑

同时我们:

  • 解耦了Service和Repository
  • 服务可以支持多种数据持久层
  • Repository专注于数据访问

在Controller中,我们可以注入此服务类使用:

@Autowired
ArticleService articleService;
// ...
articleService.findAll();

通过这种设计:

  • Service调用Repository访问数据
  • Controller调用Service提供业务

实现了清晰的分层结构。

定义ArticleController控制器,提供RESTful API

根据你的需求,ArticleController可以如下定义:

@RestController
@RequestMapping("/api/articles")
public class ArticleController {
  @Autowired
  ArticleService articleService;
  @GetMapping
  public List<Article> findAll() {
    return articleService.findAll();  
  }
  @GetMapping("/{id}")  
  public Article findById(@PathVariable Long id) {
    ...  
  }
  // 其它API
}

主要特征:

  1. 使用@RestController注解,代表一个RESTful的控制器
  2. 使用@RequestMapping指定基础URL为/api/articles
  3. 通过@Autowired注入ArticleService
  4. 使用@GetMapping标注GET请求路由,映射到方法
  5. 在方法中调用服务进行业务逻辑
  6. 使用@PathVariable绑定URL模板变量,如id
  7. 返回对应实体类的JSON数据

通过这种方式,我们定义了与Article相关的所有RESTful API:

  • GET /api/articles 获取全部文章
  • GET /api/articles/{id} 根据id获取文章
  • 其他获取、新增、修改、删除文章的API

客户端(前端)通过这些接口与后端交互,获取JSON格式的数据。

重复定义Tag、Comment等实体类

根据需求,可以按照以下方式定义Tag、Comment等实体类:

Tag

@Entity
public class Tag {
  @Id  
  @GeneratedValue  
  private Long id;
  @Column(name = "name")
  private String name;
  @ManyToMany  
  @JoinTable(
     name = "article_tag", 
     joinColumns = @JoinColumn(name = "tag_id"),
     inverseJoinColumns = @JoinColumn(name = "article_id"))       
  private Set<Article> articles;
  // getters and setters  
}

Comment

@Entity
public class Comment {
  @Id  
  @GeneratedValue  
  private Long id;  
  @Column(name = "content")     
  private String content;  
  @ManyToOne
  @JoinColumn(name = "article_id")  
  private Article article;
  // getters and setters
}

主要特征:

  • 使用JPA注解定义实体类
  • 指定ID生成策略
  • 映射数据库表字段
  • 定义关系:
  • @ManyToMany 一个标签对应多个文章
  • @ManyToOne 一个评论对应一个文章
  • 使用@JoinTable指定关系表article_tag
  • 为属性提供gettersetter方法

通过这种方式,我们可以:

  • 定义多个实体类映射到不同数据库表
  • 定义实体类间的关系映射
  • 搭建完整的ORM框架

部署:

分别构建并部署Vue项目和Spring Boot项目

根据你的需求,可以按以下步骤分别构建和部署Vue前端项目和Spring Boot后端项目:

Vue项目

  1. 使用vue create命令创建Vue项目
  2. 安装依赖:npm install
  3. 开发前端组件,定义接口调用等
  4. 构建产物:
npm run build

此命令会构建出一个dist文件夹,包含静态文件

  1. 部署:
  • 直接上传dist文件夹到任意web服务器即可提供服务
  • 也可以使用:npm install -g serve安装serve,使用serve -s dist本地部署

Spring Boot项目

  1. 使用IDE创建Spring Initializr项目
  2. 连接MySQL数据库,编写实体、服务、接口等代码
  3. 构建产物:
./mvnw package

生成一个可执行的jar文件

  1. 部署:
  • 直接运行jar文件:java -jar demo.jar
  • 也可部署到任意Java服务器上

交互

  • Vue项目中,通过Axios调用Spring Boot提供的RESTful API接口
  • 获取JSON数据后,渲染到相应组件
  • 实现前后端完全分离

通过这种方式,我们可以:

  • 分别开发和部署前后端
  • 前端使用Vue等技术
  • 后端提供RESTful API服务
  • 前后端通过JSON交互

实现前后端完全分离的个人博客系统。

Vue通过Axios调用Spring Boot提供的JSON API

前端Vue项目通过Axios调用Spring Boot提供的JSON API的过程如下:

在Vue项目中,需要:

  1. 安装Axios库:
npm install axios
  1. 定义接口服务:
import axios from 'axios'
export default {  
  getArticles() {
    return axios.get('http://localhost:8080/api/articles')  
  }
}
  1. 在组件中使用接口:
import ArticleApi from './api/article'
export default {
  methods: {
    async loadArticles() {
      let { data } = await ArticleApi.getArticles()
      this.articles = data    
    }
  } 
}
  1. 调用方法加载数据:
created() {
  this.loadArticles()
}

在Spring Boot后端,需要定义:

  1. ArticleController:
@GetMapping("/api/articles")
public List<Article> getArticles() {
  return articleService.findAll();  
}
  1. ArticleService,ArticleRepository在Spring Boot后端,需要定义:ArticleService
@Service
public class ArticleService {
  @Autowired
  ArticleRepository articleRepository;
  public List<Article> findAll() {
    return articleRepository.findAll();  
  }
}
  1. ArticleService中的方法:
  • 调用ArticleRepository进行数据访问
  • 提供业务逻辑,如新增、删除文章
  1. ArticleRepository
public interface ArticleRepository extends JpaRepository<Article, Long> {
}
  1. ArticleRepository:
  • 继承JpaRepository,定义对Article操作的方法
  • Spring Data JPA会自动实现接口,提供基本CRUD方法
  1. ArticleController
@RestController
public class ArticleController {
  @Autowired
  ArticleService articleService;
  @GetMapping("/api/articles")  
  public List<Article> getArticles() {
    return articleService.findAll();  
  }  
}
  1. ArticleController:
  • 定义JSON API端点
  • 通过@Autowired注入ArticleService
  • 实现HTTP请求处理方法,调用ArticleService
  1. 三者组合结构:
  • ArticleRepository提供数据访问
  • ArticleService封装业务逻辑,调用Repository
  • ArticleController提供API,调用Service
  1. 分层设计:
  • 解耦了数据访问和业务逻辑
  • Repository只负责数据,Service只负责业务
  • Controller只关注API定义
  1. 所以在Spring后端,需要定义三个部分:Repository(数据)、Service(业务)和Controller(API)。

上述接口会返回:

[ 
  {
    "id": 1,
    "title": "Introduction to Spring Boot",
    "content": "..."   
  },
  ...
]

Vue项目通过Axios调用该接口,获取JSON数据,再设置给articles 用来渲染。

通过这种方式,我们实现了:

  • 前端通过Axios调用后端提供的JSON API接口
  • 后端使用Spring MVC定义Restful JSON API
  • 通过JSON交互实现前后端分离
  • 实现前后端完全分离

通过以上步骤,我们就可以实现一个基于Vue、Spring Boot和MySQL的简单个人博客系统,实现前后端分离


相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
8天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
59 1
|
2天前
|
存储 安全 Java
打造智能合同管理系统:SpringBoot与电子签章的完美融合
【10月更文挑战第7天】 在数字化转型的浪潮中,电子合同管理系统因其高效、环保和安全的特点,正逐渐成为企业合同管理的新宠。本文将分享如何利用SpringBoot框架实现一个集电子文件签字与合同管理于一体的智能系统,探索技术如何助力合同管理的现代化。
17 4
|
2天前
|
前端开发 Java Apache
SpringBoot实现电子文件签字+合同系统!
【10月更文挑战第15天】 在现代企业运营中,合同管理和电子文件签字成为了日常活动中不可或缺的一部分。随着技术的发展,电子合同系统因其高效性、安全性和环保性,逐渐取代了传统的纸质合同。本文将详细介绍如何使用SpringBoot框架实现一个电子文件签字和合同管理系统。
10 1
|
4天前
|
JavaScript Java 关系型数据库
自主版权的Java诊所管理系统源码,采用Vue 2、Spring Boot等技术栈,支持二次开发
这是一个自主版权的Java诊所管理系统源码,支持二次开发。采用Vue 2、Spring Boot等技术栈,涵盖患者管理、医生管理、门诊管理、药店管理、药品管理、收费管理、医保管理、报表统计及病历电子化等功能模块。
|
5天前
|
文字识别 安全 Java
SpringBoot3.x和OCR构建车牌识别系统
本文介绍了一个基于Java SpringBoot3.x框架的车牌识别系统,详细阐述了系统的设计目标、需求分析及其实现过程。利用Tesseract OCR库和OpenCV库,实现了车牌图片的识别与处理,确保系统的高准确性和稳定性。文中还提供了具体的代码示例,展示了如何构建和优化车牌识别服务,以及如何处理特殊和异常车牌。通过实际应用案例,帮助读者理解和应用这一解决方案。
|
9天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用
【10月更文挑战第8天】本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,通过 Spring Initializr 创建并配置 Spring Boot 项目,实现后端 API 和安全配置。接着,使用 Ant Design Pro Vue 脚手架创建前端项目,配置动态路由和菜单,并创建相应的页面组件。最后,通过具体实践心得,分享了版本兼容性、安全性、性能调优等注意事项,帮助读者快速搭建高效且易维护的应用框架。
18 3
|
10天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用
【10月更文挑战第7天】本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,通过 Spring Initializr 创建 Spring Boot 项目并配置 Spring Security。接着,实现后端 API 以提供菜单数据。在前端部分,使用 Ant Design Pro Vue 脚手架创建项目,并配置动态路由和菜单。最后,启动前后端服务,实现高效、美观且功能强大的应用框架。
13 2
|
9天前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
14 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
9天前
|
Java 关系型数据库 MySQL
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
这篇文章是关于如何使用Spring Boot框架通过JdbcTemplate操作MySQL数据库的教程。
11 0
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
|
11天前
|
机器学习/深度学习 移动开发 自然语言处理
基于人工智能技术的智能导诊系统源码,SpringBoot作为后端服务的框架,提供快速开发,自动配置和生产级特性
当身体不适却不知该挂哪个科室时,智能导诊系统应运而生。患者只需选择不适部位和症状,系统即可迅速推荐正确科室,避免排错队浪费时间。该系统基于SpringBoot、Redis、MyBatis Plus等技术架构,支持多渠道接入,具备自然语言理解和多输入方式,确保高效精准的导诊体验。无论是线上医疗平台还是大型医院,智能导诊系统均能有效优化就诊流程。