基于JavaWeb的婚恋交友网站设计与实现

news2025/7/16 10:33:43

项目描述

临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据疫情当下,你想解决的问题,今天给大家介绍一篇基于JavaWeb的婚恋交友网站设计与实现

功能需求

本系统采用B / S模式,并使用JSP来设计和实现页面。在线交友是互联网发展的必然产物,它改变了人们的网络交往形态,使得人们的即时通信变得更加的直观和亲切,并且具有良好的发展趋势。婚恋交友网站,满足了之间的点对点多媒体通信,为宽带网络上的个人客户们提供聊天功能。而交友系统拉近了人与人之间的距离,丰富人们的业余时间,为人们在网络中交友提供了便捷的渠道。

具备以下功能:

提高商业化利益,通过线上线下调查大部分交友网站,综合评价了我国感情现状和以及今后的发展趋势,进而分析婚恋交友网站实现理念和价值,设计网站功能点。
用户模块:首页、登录注册、我的好友、个人中心、系统公告、系统留言板、信息交流、好友间礼物赠送等
管理员模块:管理员登录、照片信息管理、消息模块管理、用户管理、充值与购买、友情链接管理、留言板管理、安全退出等

部分效果图

在这里插入图片描述
在这里插入图片描述在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述在这里插入图片描述
在这里插入图片描述

数据库设计

系统中用到了9张表,针对每个表都进行了设计,下面对部分核心表进行汇总罗列展示。
(1)用户信息表

CREATE TABLE `admin` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `account` varchar(20) DEFAULT NULL,
  `password` varchar(20) DEFAULT NULL,
  `power` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=52 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

(2)会员信息表

DROP TABLE IF EXISTS `class`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `class` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `class_no` varchar(20) DEFAULT NULL,
  `major_id` int(11) DEFAULT NULL,
  `class_name` varchar(20) DEFAULT NULL,
  `status` varchar(10) DEFAULT NULL,
  `join_time` varchar(20) DEFAULT NULL,
  `student_num` int(11) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=34 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

(3)留言板信息表


DROP TABLE IF EXISTS `semester`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `semester` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `name` varchar(30) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=7 DEFAULT CHARSET=utf8;
/*!40101 SET character_set_client = @saved_cs_client */;

--
部分代码

	@RequestMapping("/myMerchant.do")
	public String myMerchant(HttpSession session) {
		User user = (User) session.getAttribute("USER_SESSION");
		Merchant merchant = new Merchant();
		merchant.setUserId(user.getUserId());
		List<Merchant> list = merchantService.findMerchants(merchant, null, null);
		if (list != null) {
			if (list.size() > 0) {
				session.setAttribute("MERCHANT_SESSION", list.get(0));
				return "merchant/activityManage";
			}
		}
		return "redirect: ../index.jsp";
	}
	
	@RequestMapping("/back/showUserManage")
	public String showKindManage() {
		return "admin/userManage";
	}

	@RequestMapping(value = "/findUsers", method = RequestMethod.POST)
	@ResponseBody
	public String findUsers(int pageSize, int pageNumber, String sortName, String sortOrder, User user) {
		PageHelper.startPage(pageNumber, pageSize);// 一定要先分页后执行业务方法
		List<User> list = userService.findUsers(user, sortName, sortOrder);
		PageInfo<User> pageInfo = new PageInfo<>(list);
		List<User> rows = pageInfo.getList();
		int total = (int) pageInfo.getTotal();
		Map<String, Object> results = new HashMap<>();
		results.put("rows", rows); // "rows"为前端bootstrap table默认接收字段名,后端名称修改要和前端responseHandler()函数一致
		results.put("total", total); // "total"为前端bootstrap table默认接收字段名,后端名称修改要和前端responseHandler()函数一致
		return JSONArray.toJSONString(results);
	}

	@RequestMapping(value = "findUsersByUserName", method = RequestMethod.POST)
	@ResponseBody
	public boolean findUsersByUserName(String userName, String method) {
		List<User> list = userService.findUsersByUserName(userName, method);
		if (list != null) {
			if (list.size() > 0) {
				return false;
			}
		}
		return true;
	}

	@RequestMapping(value = "findUsersById", method = RequestMethod.POST)
	@ResponseBody
	public boolean findUsersById(Integer userId) {
		User user = userService.findUserById(userId);
		List<UserRole> list = userRoleService.findUserRoleListByUserId(userId);
		if (list != null) {
			ArrayList<Byte> roleIds = new ArrayList<>();
			for (UserRole userRole : list) {
				roleIds.add(userRole.getRoleId());
			}
			for (Byte roleId : roleIds) {
				if (roleId == 3) { // 判断用户是否已入驻
					return false;
				}
			}
		}
		if (user == null) {
			return false;
		}
		return true;
	}
	
	@RequestMapping(value = "/findUserById", method = RequestMethod.POST)
	@ResponseBody
	public User findUserById(Integer userId) {
		return userService.findUserById(userId);
	}
	
	@RequestMapping(value = "/getUpdField", method = RequestMethod.POST)
	@ResponseBody
	public boolean getUpdField(String updName) {
		if (updName != null && !"".equals(updName)) {
			UserController.updName = updName;
			return true;
		}
		return false;
	}

	@RequestMapping("/register")
	@ResponseBody
	public int register(User user) {
		user.setUserLogo("user.png");
		int count = userService.addUser(user);
		if (count > 0) {
			return userRoleService.addUserRole(user.getUserName(), "普通用户", null);
		}
		return 0;
	}

	@RequestMapping("/addUser")
	@ResponseBody
	public int addUser(User user, MultipartFile file, HttpSession session) {
		try {
			if (file != null) {
				if (file.getSize() > 0) {
					String path = session.getServletContext().getRealPath("upload/user/logo");
					File targetFile = new File(path, file.getOriginalFilename());
					file.transferTo(targetFile);
					user.setUserLogo(file.getOriginalFilename());
				}
			}else {
				user.setUserLogo("user.png");
			}
			int count = userService.addUser(user);
			if (count > 0) {
				return userRoleService.addUserRole(user.getUserName(), "普通用户", null);
			}
		} catch (IOException e) {
			e.printStackTrace();
		}
		return 0;
	}

	@RequestMapping("/updUser")
	@ResponseBody
	public int updUser(User user, MultipartFile file, HttpSession session) {
		try {
			if (file != null) {
				if (file.getSize() > 0) {
					String path = session.getServletContext().getRealPath("upload/user/logo");
					File targetFile = new File(path, file.getOriginalFilename());
					file.transferTo(targetFile);
					user.setUserLogo(file.getOriginalFilename());
				}
			}
			return userService.updUserById(user);
		} catch (IOException e) {
			e.printStackTrace();
		}
		return 0;
	}

	@RequestMapping(value = "/delUsers", method = RequestMethod.POST)
	@ResponseBody
	public int delUsers(Integer[] userIds) {
		return userService.delUsersById(userIds);
	}
	
	@RequestMapping(value = "/checkPassWord", method = RequestMethod.POST)
	@ResponseBody
	public boolean checkPassWord(String passWord,HttpSession session) {
		User user = (User) session.getAttribute("USER_SESSION");
		return userService.checkPassWord(user.getUserId(), passWord);
	}
	
	@RequestMapping(value = "/updPassWord", method = RequestMethod.POST)
	public String updPassWord(String passWord,HttpSession session) {
		User user = (User) session.getAttribute("USER_SESSION");
		int count = userService.updPassWord(user.getUserId(), passWord);
		if (count != 0) {
			session.invalidate();
			return "redirect: ../index.jsp";
		}
		return null;
	}
安装部署需求

eclipse/idea运行启动

系统部署

系统开发后,在生产环境配置项目运行环境,具体步骤如下:
安装linux或者windows10操作系统;
安装JDK1.8并配置环境变量;
安装MySQL5.7版本以上版本数据库,创建数据库并执行脚本创建表;
在eclipse/idea中运行打包;

本项目用到的技术和框架

1.开发语言:Java
2.开发模式:B/S
3.数据库:MySQL5.7
4.框架:jsp+servlet+jdbc

本项目中的关键点

此系统的开发采用java语言开发,基于B/S结构,这些开发环境使系统更加完善。使用到的工具和技术都是开源免费的。

环境工具

开发工具 Eclipse
语言 JDK1.8 、jsp、servlet
硬件:笔记本电脑;
软件:Tomcat8.0 Web服务器、Navicat数据库客户端、MySQL;
操作系统:Windows 10;
其它软件:截图工具、常用浏览器;
以上是本系统的部分功能展示,如果你的选题正好相符,那么可以做毕业设计或课程设计使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/38129.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何平衡新老策略的好与坏,一道常见风控送命题解答

作为一个风控策略从业者&#xff0c;在做风险管理的过程中一直在做的就是&#xff0c;不断的挖掘有效的变量特征来填充风控决策体系&#xff0c;使决策体系的功效变大变强&#xff0c;最终形成一套可变的稳定风险护盾。我们常见的一个场景比如如何筛选一些新策略来挑战老策略&a…

【C++中预处理语句 include、define、if】

1.预处理阶段 预处理阶段&#xff0c;在实际发生编译之前就根据对应的预处理语句进行操作&#xff0c;等到预处理阶段完成之后才进行编译阶段 。 2.预处理语句 预处理语句主要有include、define、if 和 program。利用 # 进行标记 2.1 include语句 include语句就是将所包含的…

if-else练习

if单分支 输入两个数&#xff0c;分别放入x和y中&#xff0c;若两数不相等&#xff0c;则输出其中的大数&#xff0c;若两数相等&#xff0c;则输出字符串“xy&#xff1a;”并输出其值 #define _CRT_SECURE_NO_WARNINGS 1 #include<stdio.h> int main() {int a 0;int …

智慧油田解决方案-最新全套文件

智慧油田解决方案-最新全套文件一、建设背景1、智慧油田的概念及意义2、智慧油田的建设目标二、建设思路三、建设方案四、获取 - 智慧油田全套最新解决方案合集一、建设背景 1、智慧油田的概念及意义 石油产量、采收率、安全生产等都与石油工业未来息息相关&#xff0c;随着石…

十八、CANdelaStudio深入-Data Types

本专栏将由浅入深的展开诊断实际开发与测试的数据库编辑,包含大量实际开发过程中的步骤、使用技巧与少量对Autosar标准的解读。希望能对大家有所帮助,与大家共同成长,早日成为一名车载诊断、通信全栈工程师。 本文介绍CANdelaStudio的Data Types(数据类型),欢迎各位朋友订…

旧系统改造

背景 很多时候&#xff0c;我们在项目前期会优先确保项目业务的落地&#xff0c;在短时间内进行项目冲刺&#xff0c;最后完成项目上线。这样做让短时间内的目标达貌似达成了&#xff0c;却给系统留下了很大的隐患。 在项目的冲刺过程中&#xff0c;我们的精力大部分花在了业…

动态规划-不同路径

一个机器人位于一个 m x n 网格的左上角 &#xff08;起始点在下图中标记为 “Start” &#xff09;。 机器人每次只能向下或者向右移动一步。机器人试图达到网格的右下角&#xff08;在下图中标记为 “Finish” &#xff09;。 问总共有多少条不同的路径&#xff1f; 示例 …

单源广度优先搜索 (leetcode经典例题 C++实现)

文章目录01矩阵地图分析腐烂的橘子深度优先搜索与广度优先搜索前情回顾&#xff1a; 深度搜索dfs与广度搜索bfs算法总结&#xff08;c 例题&#xff09; 本节是广度优先搜索的进阶&#xff1a; 01矩阵 传送门&#xff1a; https://leetcode.cn/problems/01-matrix/?envType…

JavaWeb----Servlet技术

JavaEE简介 什么是JavaEE JavaEE&#xff08;Java Enterprise Edition&#xff09;&#xff0c;Java企业版&#xff0c;是一个用于企业 级web开发平台,它是一组Specification。最早由Sun公司定制并发 布&#xff0c;后由Oracle负责维护。在JavaEE平台规范了在开发企业级web 应…

【操作系统】死锁(详细)

文章目录一、死锁的概念二、死锁的产生因素三、死锁的必要条件1、互斥条件2、占有和等待条件&#xff08;部分分配条件&#xff09;3、不剥夺条件4、循环等待条件&#xff08;环路条件&#xff09;四、死锁防止1、破坏互斥条件2、破坏占有和等待条件3、破坏不剥夺条件4、破坏循…

Ceph文件系统

目录 一、环境准备 二、什么是文件系统 三、ceph块存储与文件系统区别 四、创建ceph文件系统 1、启动MDS服务 2、创建存储池 3、创建Ceph文件系统 4、客户端挂载 一、环境准备 Ceph集群搭建参照&#xff1a;Ceph集群部署_桂安俊kylinOS的博客-CSDN博客 以下Ceph存储实…

springcloud22:sentinal的使用

sentinal对比&#xff08;分布式系统的流量防卫&#xff09; 监控保护微服务 Hystrix 需要自己去手工搭建监控平台&#xff0c;没有一套web界面可以进行细粒度化的配置&#xff0c;流控&#xff0c;速率控制&#xff0c;服务熔断&#xff0c;服务降级… 整合机制&#xff1a;se…

外卖项目08---Linux

目录 一、 Linux简介 119 二、Linux安装 120 三、常用命令 122 3.1Linux命令初体验 3.1.1 command [-options] [parameter] 3.2Linux常用命令---文件目录操作命令-ls&-cd&-cat 124 3.2.1list 3.2.2 cd 3.2.3 cat 3.3 Linux常用命令---文件目录操作命令…

9.前端笔记-CSS-CSS三大特性

三大特性&#xff1a;层叠性、继承性、优先级 1、层叠性&#xff08;覆盖性&#xff09; 给相同的选择器设置相同的样式&#xff0c;此时一个样式会覆盖&#xff08;层叠&#xff09;其他冲突的样式。 层叠性原则&#xff1a; 同一选择器&#xff0c;样式冲突&#xff0c;遵…

OpenMV输出PWM,实现对舵机控制

OpenMV的定时器官方函数介绍&#xff1a;Timer类 – 控制内部定时器 目录 OpenMV的PWM资源介绍 为什么要用OpenMV输出PWM OpenMV的PWM资源分配 资源 注意 建议 PWM输出代码 代码讲解 Timer Timer.channel tim.channel与Timer.channel区别 Timer.channel解析 OpenM…

Iframe通信

跨域的种类 一般有两种形式的跨域问题&#xff1a; ①使用XmlHttpRequest(XHR)或者使用AJAX发送的POST或者GET请求。这种形式的跨域是&#xff1a;前端页面与后端进行的跨域请求。 ②父子页面之间进行的DOM操作&#xff08;父子窗口之间的document操作&#xff09;。这种形式…

使用XShell、XFTP 连接 win7 虚拟机(windows、Linux无法远程登录问题)

文章目录前言出错原因&#xff08;题外话&#xff09;那么我们为什么要使用 SSH 连接开始操作&#xff08;Windows7&#xff09;首先进行 SSH 测试获取所需的openSSH文件安装openSSH添加环境变量ssh测试发布ssh服务开始操作&#xff08;Linux&#xff0c;以Ubuntu为例&#xff…

Linux启动流程分析

一、Linux启动流程图 二、硬件启动流程 2.1、POST Linux开机加电后&#xff0c;系统开始开机自检&#xff0c;该过程主要对计算机各种硬件设备进行检测&#xff0c;如CPU、内存、主板、硬盘、CMOS芯片等。主要完成检测硬件能否满足运行的基本条件&#xff0c;叫做“硬件自检(P…

【网络编程】第一章 网络基础(协议+OSI+TCPIP+网络传输的流程+IP地址+MAC地址)

&#x1f3c6;个人主页&#xff1a;企鹅不叫的博客 ​ &#x1f308;专栏 C语言初阶和进阶C项目Leetcode刷题初阶数据结构与算法C初阶和进阶《深入理解计算机操作系统》《高质量C/C编程》Linux ⭐️ 博主码云gitee链接&#xff1a;代码仓库地址 ⚡若有帮助可以【关注点赞收藏】…

onnx-modifier使用

文章目录**0、作用和功能****1、准备****2、界面介绍****3、注意tips**onnx-modifier基于流行的模型可视化工具 Netron 和轻量级Web应用框架 flask 开发。希望它能给社区带来一些贡献0、作用和功能 经常作为不同框架模型转化的中间文件&#xff0c;拿到ONNX文件&#xff0c;想…