大学生相亲网站 毕业设计 JAVA+Vue+SpringBoot+MySQL

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 大学生相亲网站 毕业设计 JAVA+Vue+SpringBoot+MySQL

https://gf.bilibili.com/item/detail/1104414029

为了帮助小白入门 Java,博主录制了本项目配套的《项目手把手启动教程》,希望能给同学们带来帮助。

一、摘要

1.1 项目介绍

基于JAVA+Vue+SpringBoot+MySQL的大学生相亲网站,包含了会员管理模块、新闻管理模块、相亲大会模块、留言管理模块,还包含系统自带的用户管理、部门管理、角色管理、菜单管理、日志管理、数据字典管理、文件管理、图表展示等基础模块,大学生相亲网站基于角色的访问控制,给相亲管理员、红娘老师使用,可将权限精确到按钮级别,您可以自定义角色并分配权限,系统适合设计精确的权限约束需求。

1.2 项目录屏


二、功能模块

本系统包含容纳了各所高校人员的信息管理,另外还有站内新闻,交友信息,相亲大会活动,在线留言板等内容。

本系统共有账号管理、会员信息管理、新闻管理、相亲大会管理、留言管理五大模块。会员信息管理模块,记录了注册的会员的详细信息,管理注册的用户,进行审核、修改、删除信息等操作。账号管理模块包括对用户名、密码、确认密码、权限的管理。新闻管理模块主要有添加新闻、查询新闻,包括标题、内容、人等。相亲大会管理模块进行添加活动、查询活动,包括活动标题、时间、地点、费用、备注等。留言管理模块通过搜索姓名,留言概要查找会员的信息,可进行回复、修改、删除操作。

本系统将使用B/S体系结构,进行需求分析、体系结构设计、代码构建和测试,以Java、HTML5、CSS3、javaScript.,作为编程语言,使用Mwsa…数据库,以idea、VSCode 作为开发工具,采用三层架构模型,运用一些 Java 中经典框架如Spring、SpringBoot、SpringMVC、Mbatis等来进行开发。使用Maven构建工具来配置开发需要的环境。

可以实现会员注册,查看新闻(会员们的交友信息),交友查询,相亲大会活动,在线留言

  1. 账号管理:用户名、密码、确认密码、权限。
  2. 会员管理:注册会员管理(管理注册的用户,审核、修改、删除信息等操作)。
  3. 新闻管理:添加新闻、查询新闻,包括标题、内容、人等。
  4. 相亲大会管理:添加活动、查询活动,包括活动标题、时间、地点、费用、备注等。
  5. 留言管理:通过搜索姓名,留言概要查找会员的信息,可回复、修改、删除。

三、系统展示


四、核心代码

4.1 查询会员

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询会员")
public Result<IPage<Member>> getByPage(@ModelAttribute Member member ,@ModelAttribute PageVo page){
    QueryWrapper<Member> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(member.getName())) {
        qw.like("name",member.getName());
    }
    if(!ZwzNullUtils.isNull(member.getResidence())) {
        qw.like("residence",member.getResidence());
    }
    if(!ZwzNullUtils.isNull(member.getAddress())) {
        qw.like("address",member.getAddress());
    }
    if(!ZwzNullUtils.isNull(member.getHouse())) {
        qw.like("house",member.getHouse());
    }
    if(!ZwzNullUtils.isNull(member.getSchooling())) {
        qw.like("schooling",member.getSchooling());
    }
    IPage<Member> data = iMemberService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<Member>>().setData(data);
}

4.2 查询相亲大会

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询相亲大会")
public Result<IPage<MatchmakingConference>> getByPage(@ModelAttribute MatchmakingConference matchmakingConference ,@ModelAttribute PageVo page){
    QueryWrapper<MatchmakingConference> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(matchmakingConference.getTitle())) {
        qw.like("title",matchmakingConference.getTitle());
    }
    if(!ZwzNullUtils.isNull(matchmakingConference.getContent())) {
        qw.like("content",matchmakingConference.getContent());
    }
    if(!ZwzNullUtils.isNull(matchmakingConference.getAddress())) {
        qw.like("address",matchmakingConference.getAddress());
    }
    IPage<MatchmakingConference> data = iMatchmakingConferenceService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<MatchmakingConference>>().setData(data);
}

4.3 新增留言

@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增留言")
public Result<Message> insert(Message message){
    User currUser = securityUtil.getCurrUser();
    message.setUserId(currUser.getId());
    message.setUserName(currUser.getNickname());
    message.setTime(DateUtil.now());
    message.setReplyContent("");
    message.setReplyName("");
    message.setReplyId("");
    message.setReplyTime("");
    iMessageService.saveOrUpdate(message);
    return new ResultUtil<Message>().setData(message);
}

4.4 查询新闻

@RequestMapping(value = "/getByPage", method = RequestMethod.GET)
@ApiOperation(value = "查询新闻")
public Result<IPage<News>> getByPage(@ModelAttribute News news ,@ModelAttribute PageVo page){
    QueryWrapper<News> qw = new QueryWrapper<>();
    if(!ZwzNullUtils.isNull(news.getTitle())) {
        qw.like("title",news.getTitle());
    }
    if(!ZwzNullUtils.isNull(news.getContent())) {
        qw.like("content",news.getContent());
    }
    if(!ZwzNullUtils.isNull(news.getUserName())) {
        qw.like("user_name",news.getUserName());
    }
    IPage<News> data = iNewsService.page(PageUtil.initMpPage(page),qw);
    return new ResultUtil<IPage<News>>().setData(data);
}

4.5 新增新闻

@RequestMapping(value = "/insert", method = RequestMethod.POST)
@ApiOperation(value = "新增新闻")
public Result<News> insert(News news){
    if(Objects.equals(0,news.getSortOrder().compareTo(BigDecimal.ZERO))) {
        news.setSortOrder(BigDecimal.valueOf(iNewsService.count() + 1L));
    }
    User currUser = securityUtil.getCurrUser();
    news.setUserName(currUser.getNickname());
    iNewsService.saveOrUpdate(news);
    return new ResultUtil<News>().setData(news);
}

五、免责说明

  • 本项目仅供个人学习使用,商用授权请联系博主,否则后果自负。
  • 博主拥有本软件构建后的应用系统全部内容所有权及独立的知识产权,拥有最终解释权。
  • 如有问题,欢迎在仓库 Issue 留言,看到后会第一时间回复,相关意见会酌情考虑,但没有一定被采纳的承诺或保证。

下载本系统代码或使用本系统的用户,必须同意以下内容,否则请勿下载!

  1. 出于自愿而使用/开发本软件,了解使用本软件的风险,且同意自己承担使用本软件的风险。
  2. 利用本软件构建的网站的任何信息内容以及导致的任何版权纠纷和法律争议及后果和博主无关,博主对此不承担任何责任。
  3. 在任何情况下,对于因使用或无法使用本软件而导致的任何难以合理预估的损失(包括但不仅限于商业利润损失、业务中断与业务信息丢失),博主概不承担任何责任。
  4. 必须了解使用本软件的风险,博主不承诺提供一对一的技术支持、使用担保,也不承担任何因本软件而产生的难以预料的问题的相关责任。
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
1月前
|
关系型数据库 MySQL Java
【MySQL+java+jpa】MySQL数据返回项目的感悟
【MySQL+java+jpa】MySQL数据返回项目的感悟
42 1
|
1月前
|
关系型数据库 MySQL Java
【IDEA】java后台操作mysql数据库驱动常见错误解决方案
【IDEA】java后台操作mysql数据库驱动常见错误解决方案
59 0
|
7天前
|
分布式计算 关系型数据库 MySQL
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型 图像处理 光通信 分布式计算 算法语言 信息技术 计算机应用
27 8
|
8天前
|
SQL 前端开发 关系型数据库
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
37 9
|
20天前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
|
1月前
|
Java 关系型数据库 MySQL
springboot学习五:springboot整合Mybatis 连接 mysql数据库
这篇文章是关于如何使用Spring Boot整合MyBatis来连接MySQL数据库,并进行基本的增删改查操作的教程。
57 0
springboot学习五:springboot整合Mybatis 连接 mysql数据库
|
1月前
|
Java 关系型数据库 MySQL
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
这篇文章是关于如何使用Spring Boot框架通过JdbcTemplate操作MySQL数据库的教程。
22 0
springboot学习四:springboot链接mysql数据库,使用JdbcTemplate 操作mysql
|
16天前
|
关系型数据库 MySQL Java
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
SpringBoot项目中mysql字段映射使用JSONObject和JSONArray类型
21 0
|
6天前
|
安全 Java 测试技术
Java并行流陷阱:为什么指定线程池可能是个坏主意
本文探讨了Java并行流的使用陷阱,尤其是指定线程池的问题。文章分析了并行流的设计思想,指出了指定线程池的弊端,并提供了使用CompletableFuture等替代方案。同时,介绍了Parallel Collector库在处理阻塞任务时的优势和特点。
|
3天前
|
安全 Java 开发者
深入解读JAVA多线程:wait()、notify()、notifyAll()的奥秘
在Java多线程编程中,`wait()`、`notify()`和`notifyAll()`方法是实现线程间通信和同步的关键机制。这些方法定义在`java.lang.Object`类中,每个Java对象都可以作为线程间通信的媒介。本文将详细解析这三个方法的使用方法和最佳实践,帮助开发者更高效地进行多线程编程。 示例代码展示了如何在同步方法中使用这些方法,确保线程安全和高效的通信。
16 9