基于微信小程序的大学生租房服务平台设计与实现

💗博主介绍:✌全网粉丝10W+,CSDN全栈领域优质创作者,博客之星、掘金/知乎/b站/华为云/阿里云等平台优质作者、专注于Java、小程序/APP、python、大数据等技术领域和毕业项目实战,以及程序定制化开发、文档编写、答疑辅导等。
👇🏻 精彩专栏 推荐订阅👇🏻
计算机毕业设计精品项目案例(持续更新)
🌟文末获取源码+数据库+文档🌟
感兴趣的可以先收藏起来,还有大家在毕设选题,项目以及论文编写等相关问题都可以和学长沟通,希望帮助更多的人

一.前言

在这里插入图片描述

随着高校扩招及城市化进程加速,大学生租房需求激增,传统租房方式存在信息不对称、流程繁琐等问题。微信小程序以其便捷性、即用即走的特点,为大学生群体提供了一个高效、透明、个性化的租房服务解决方案,旨在简化租房流程,提升租房体验,满足大学生对安全、经济、便捷租房服务的迫切需求

本微信小程序的租房服务平台采用小程序、SpringBoot架构技术,微信端以小程序页面呈现给用户,结合后台java语言使页面更加完善,后台使用MySQL数据库进行数据存储。该微信小程序主要设计并完成了管理过程中的用户注册登录、个人信息修改、用户、房源信息、房屋户型、租赁预约、租赁订单、房东、合同信息、自助缴费、租房信息等功能。该微信小程序操作简便,界面设计简洁,不但可以基本满足本行业的日常管理工作,同时又可以有效减少人员成本和时间成本,为租房服务管理工作提供了方便。


二.技术环境

jdk版本:1.8 及以上
ide工具:Eclipse或者 IDEA,微信小程序开发工具
数据库: mysql5.7 (必须5.7)
编程语言: Java
java框架:SpringBoot
maven: 3.6.1
详细技术:HTML+CSS+JAVA+SpringBoot+MYSQL+VUE+MAVEN+微信开发工具


三.功能设计

微信小程序的租房服务平台综合网络空间开发设计要求。目的是将租房服务平台通过网络平台将传统管理方式转换为在网上操作,方便快捷、安全性高、交易规范做了保障,目标明确。微信小程序的租房服务平台可以将功能划分为用户、房东和管理员功能[10]。
(1)管理员用例图如下所示:
在这里插入图片描述

(2)用户用例图如下所示:
在这里插入图片描述
(3)房东用例图如下所示:
在这里插入图片描述
微信小程序的租房服务平台根据权限类型进行分类,主要可分为房东微信端、用户微信端和管理员服务端三大模块。系统总体模块设计如下如图所示。
在这里插入图片描述

程序上交给用户进行使用时,需要提供程序的操作流程图,这样便于用户容易理解程序的具体工作步骤,现如今程序的操作流程都有一个大致的标准,即先通过登录页面提交登录数据,通过程序验证正确之后,用户才能在程序功能操作区页面操作对应的功能。
在这里插入图片描述

四.数据设计

数据库概念模型的设计是为了抽象真实世界的信息,并对信息世界进行建模。它是数据库设计的强大工具。数据库概念模型设计可以通过E-R图描述现实世界的概念模型。而且Mysql数据库是自我保护能力比较强的数据库,在系统中的局部E-R图,如图所示:

在这里插入图片描述

五.部分效果展示

5.1用户微信端功能实现效果

当游客微信小程序的网址后,首先看到的就是首页界面。在这里,游客能够看到微信小程序的租房服务平台的低部导航条显示首页、租房服务、任务信息、地图、我的等,微信小程序界面如图所示:
在这里插入图片描述

当进入微信小程序时可以通过注册来登录,只需要根据相应的提示,输入用户账号、用户姓名、性别、头像、用户电话等信息即可。用户注册界面如图所示:

在这里插入图片描述

用户点击房源信息,在房源信息可以查看房源名称、房屋户型 、区域、所在小区、楼层、面积、月租金 、房源状态、发布时间、房源图片、房东账号、房东姓名、点击次数、评论数、收藏数等信息,还可以点击预约看房、收藏或者评论等操作,如图所示:
在这里插入图片描述

用户点击租房信息,在租房信息可以查看采暖、租期、标题、图片、租赁方式、面积、朝向、维护、入住、楼层、电梯、车位、用水、用电、燃气等信息,如图所示:
在这里插入图片描述

用户点击我的页面,在我的页面可以对租赁预约、租赁订单、合同信息、自助缴费、我的收藏、我的发帖、修改密码,进行详细操作,如图所示:

在这里插入图片描述

5.2管理员服务端功能实现效果

管理员登录,在登录页面选择需要登录的角色,在正确输入用户名和密码后选择角色,点击登录操作;如图所示。
在这里插入图片描述

管理员进入主页面,主要功能包括对系统首页、用户、房源信息、房源户型、租赁预约、租赁订单、房东、合同信息、自助缴费、租房信息、租房论坛、系统管理、用户信息等进行操作。

在房东信息页面的输入栏中输入房东账号、房东姓名进行搜索,可以查看到房东信息详细信息,并根据需要进行修改或者删除等操作;如图所示:
在这里插入图片描述

管理员点击房源信息:在房源信息页面,可以对房源名称、房屋户型 、区域、所在小区、楼层、面积、月租金 、房源状态、发布时间、房源图片、房东账号、房东姓名、点击次数、评论数、收藏数、审核回复、审核状态等信息,进行搜索、新增或者删除房源信息等操作,如图所示:
在这里插入图片描述

管理员点击租房信息:在租房信息页面,可以对采暖、租期、标题、图片、租赁方式、面积、朝向、维护、入住、楼层、电梯、车位、用水、用电、燃气等信息,进行搜索、新增或者删除租房信息等操作,如图所示:
在这里插入图片描述

管理员点击租赁预约:在租赁预约页面,可以对房源名称、房屋户型 、区域、所在小区、月租金 、房源图片、房源状态、账号、姓名、手机、身份证、预约时间、房东账号、房东姓名、审核回复、审核状态等信息,进行搜索、新增或者删除租赁预约等操作,如图所示:
在这里插入图片描述

管理员点击租赁订单:在租赁订单页面,可以对房源名称、房源图片、房屋户型 、所在小区、月租金 、账号、姓名、租赁日期、预交押金、房东账号、房东姓名、是否支付等信息,进行搜索或者删除租赁订单等操作,如图所示:
在这里插入图片描述

管理员点击合同信息:在合同信息页面,可以对房源名称、房屋户型 、房源图片、所在小区、月租金 、房东账号、房东姓名、联系电话、合同附件、账号、姓名、签订日期等信息,进行搜索或者删除合同信息等操作,如图所示:
在这里插入图片描述

5.3房东服务端功能实现效果

房东进入主页面,主要功能包括对系统首页、房源信息、房源户型、租赁预约、租赁订单、合同信息、自助缴费、租房信息、用户信息等进行操作。管理员主页面如图所示:
在这里插入图片描述

部分功能代码

	/**
	 * 上传文件
	 */
	@RequestMapping("/upload")
    @IgnoreAuth
	public R upload(@RequestParam("file") MultipartFile file,String type) throws Exception {
		if (file.isEmpty()) {
			throw new EIException("上传文件不能为空");
		}
		String fileExt = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf(".")+1);
		File path = new File(ResourceUtils.getURL("classpath:static").getPath());
		if(!path.exists()) {
		    path = new File("");
		}
		File upload = new File(path.getAbsolutePath(),"/upload/");
		if(!upload.exists()) {
		    upload.mkdirs();
		}
		String fileName = new Date().getTime()+"."+fileExt;
        if(StringUtils.isNotBlank(type) && type.contains("_template")) {
            fileName = type + "."+fileExt;
            new File(upload.getAbsolutePath()+"/"+fileName).deleteOnExit();
        }
		File dest = new File(upload.getAbsolutePath()+"/"+fileName);
		file.transferTo(dest);
		if(StringUtils.isNotBlank(type) && type.equals("1")) {
			ConfigEntity configEntity = configService.selectOne(new EntityWrapper<ConfigEntity>().eq("name", "faceFile"));
			if(configEntity==null) {
				configEntity = new ConfigEntity();
				configEntity.setName("faceFile");
				configEntity.setValue(fileName);
			} else {
				configEntity.setValue(fileName);
			}
			configService.insertOrUpdate(configEntity);
		}
		return R.ok().put("file", fileName);
	}

	/**
	 * 登录
	 */
	@IgnoreAuth
	@RequestMapping(value = "/login")
	public R login(String username, String password, String captcha, HttpServletRequest request) {
		UsersEntity user = userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", username));
		if(user==null || !user.getPassword().equals(password)) {
			return R.error("账号或密码不正确");
		}
		String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
		return R.ok().put("token", token);
	}
	
	/**
	 * 注册
	 */
	@IgnoreAuth
	@PostMapping(value = "/register")
	public R register(@RequestBody UsersEntity user){
//    	ValidatorUtils.validateEntity(user);
    	if(userService.selectOne(new EntityWrapper<UsersEntity>().eq("username", user.getUsername())) !=null) {
    		return R.error("用户已存在");
    	}
        userService.insert(user);
        return R.ok();
    }

数据库参考


--
-- Table structure for table `fangdong`
--

DROP TABLE IF EXISTS `fangdong`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `fangdong` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `fangdongzhanghao` varchar(200) NOT NULL COMMENT '房东账号',
  `mima` varchar(200) NOT NULL COMMENT '密码',
  `fangdongxingming` varchar(200) DEFAULT NULL COMMENT '房东姓名',
  `xingbie` varchar(200) DEFAULT NULL COMMENT '性别',
  `nianling` int(11) DEFAULT NULL COMMENT '年龄',
  `lianxidianhua` varchar(200) DEFAULT NULL COMMENT '联系电话',
  `touxiang` longtext COMMENT '头像',
  `sfsh` varchar(200) DEFAULT '待审核' COMMENT '是否审核',
  `shhf` longtext COMMENT '审核回复',
  PRIMARY KEY (`id`),
  UNIQUE KEY `fangdongzhanghao` (`fangdongzhanghao`)
) ENGINE=InnoDB AUTO_INCREMENT=69 DEFAULT CHARSET=utf8 COMMENT='房东';

--
-- Table structure for table `fangyuanxinxi`
--

DROP TABLE IF EXISTS `fangyuanxinxi`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `fangyuanxinxi` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `fangyuanmingcheng` varchar(200) DEFAULT NULL COMMENT '房源名称',
  `fangwuhuxing` varchar(200) DEFAULT NULL COMMENT '房屋户型',
  `quyu` varchar(200) DEFAULT NULL COMMENT '区域',
  `suozaixiaoqu` varchar(200) DEFAULT NULL COMMENT '所在小区',
  `louceng` varchar(200) DEFAULT NULL COMMENT '楼层',
  `mianji` varchar(200) DEFAULT NULL COMMENT '面积(m2)',
  `yuezujin` varchar(200) DEFAULT NULL COMMENT '月租金(元)',
  `fangyuanzhuangtai` varchar(200) DEFAULT NULL COMMENT '房源状态',
  `fangyuanjieshao` longtext COMMENT '房源介绍',
  `fabushijian` date DEFAULT NULL COMMENT '发布时间',
  `fangyuantupian` longtext COMMENT '房源图片',
  `fangdongzhanghao` varchar(200) DEFAULT NULL COMMENT '房东账号',
  `fangdongxingming` varchar(200) DEFAULT NULL COMMENT '房东姓名',
  `sfsh` varchar(200) DEFAULT '待审核' COMMENT '是否审核',
  `shhf` longtext COMMENT '审核回复',
  `thumbsupnum` int(11) DEFAULT '0' COMMENT '赞',
  `crazilynum` int(11) DEFAULT '0' COMMENT '踩',
  `clicktime` datetime DEFAULT NULL COMMENT '最近点击时间',
  `clicknum` int(11) DEFAULT '0' COMMENT '点击次数',
  `discussnum` int(11) DEFAULT '0' COMMENT '评论数',
  `storeupnum` int(11) DEFAULT '0' COMMENT '收藏数',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=29 DEFAULT CHARSET=utf8 COMMENT='房源信息';
/*!40101 SET character_set_client = @saved_cs_client */;
--
-- Table structure for table `hetongxinxi`
--

DROP TABLE IF EXISTS `hetongxinxi`;
/*!40101 SET @saved_cs_client     = @@character_set_client */;
/*!40101 SET character_set_client = utf8 */;
CREATE TABLE `hetongxinxi` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
  `addtime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
  `fangyuanmingcheng` varchar(200) DEFAULT NULL COMMENT '房源名称',
  `fangwuhuxing` varchar(200) DEFAULT NULL COMMENT '房屋户型',
  `fangyuantupian` longtext COMMENT '房源图片',
  `suozaixiaoqu` varchar(200) DEFAULT NULL COMMENT '所在小区',
  `yuezujin` varchar(200) DEFAULT NULL COMMENT '月租金',
  `fangdongzhanghao` varchar(200) DEFAULT NULL COMMENT '房东账号',
  `fangdongxingming` varchar(200) DEFAULT NULL COMMENT '房东姓名',
  `lianxidianhua` varchar(200) DEFAULT NULL COMMENT '联系电话',
  `hetongfujian` longtext COMMENT '合同附件',
  `zhanghao` varchar(200) DEFAULT NULL COMMENT '账号',
  `xingming` varchar(200) DEFAULT NULL COMMENT '姓名',
  `qiandingriqi` date DEFAULT NULL COMMENT '签订日期',
  `qiandingbeizhu` longtext COMMENT '签订备注',
  `ispay` varchar(200) DEFAULT '未支付' COMMENT '是否支付',
  PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=79 DEFAULT CHARSET=utf8 COMMENT='合同信息';
/*!40101 SET character_set_client = @saved_cs_client */;

源码及文档获取

文章下方名片联系我即可~
大家点赞、收藏、关注、评论啦 、查看👇🏻获取联系方式👇🏻
精彩专栏推荐订阅:在下方专栏👇🏻

最新计算机毕业设计选题篇-选题推荐
小程序毕业设计精品项目案例-200套
Java毕业设计精品项目案例-200套
Python毕业设计精品项目案例-200套
大数据毕业设计精品项目案例-200套
💟💟如果大家有任何疑虑,欢迎在下方位置详细交流。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一点毕设

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值