基于springboot的房屋租赁系统

简介: 该系统创作于2022年5月,经过详细的数据库设计。基于springboot技术,数据层为MyBatis,mysql数据库,页面采用html,具有完整的业务逻辑,适合话题:房屋租赁、房屋、酒店、民宿等,项目具有租赁的完整流程。

项目介绍:



该系统创作于2022年5月,经过详细的数据库设计。基于springboot技术,数据层为MyBatis,mysql数据库,页面采用html,具有完整的业务逻辑,适合话题:房屋租赁、房屋、酒店、民宿等,项目具有租赁的完整流程。


项目功能:



登录注册功能,分为三种用户权限(不能注册为管理员)
租户、房东、管理员
租户页面:能够管理个人信息、查看房源(支持条件查找)、查看租房信息和租金信息(不用做出支付功能,有个表格就行)
房东页面:能够管理个人信息、发布房源、修改房源状态(“已签”、“洽谈中”、“已预订”)、管理租金(租客代缴租金、租客已缴租金)
租户和房东都有一个我要反馈功能,反馈给管理员(可做可不做)
管理员:用户管理(修改用户账号信息和用户权限)、房源管理、查看反馈、简单的统计报表查看
可视界面不要求过分复杂,简洁明了即可



数据库表结构文档:



0cb0582e926642189fa5ef85ef97ecd6.png


系统包含技术:



后端:springBoot、mybatis

前端:bootstrap、js、css等,html页面

开发工具:idea

数据库:mysql 5.7

JDK版本:jdk1.8


部分截图说明:



下面是用户首页,展示最新的房屋信息


46bef8af0e2d44fea43f46ae24f57b68.png


下面是房屋列表,分页展示,也可以筛选


72cb3a53667740a188e405b054e9d79f.png


房源详情,有详细的介绍


d68a4e451ead4b759a6abb76addf664f.png


下面是后台登录,管理员和房东可以登录


009b5ae9a6c843fcac8dacb38d324168.png


管理员首页


0a6109561ae240baa2878078aac070f8.png


管理员对房源的管理,不能添加,由房东添加房源


588e916f2ab043099bca1697d3a4cfe3.png


管理员对房东维护


88909b5c435340d1b4d739c79c6c613e.png


管理员查看统计信息


df0cbebf76904b3b864788518ed9a851.png


房东新增房源信息,可以维护基本信息以及图片


ad88a4ea46ac4e0bb0ce97dfa9d9e371.png


部分代码:



 /**进入列表页面*/
    @GetMapping("/feedback")
    public String userIframe(){
        return "FeedbackList";
    }
    /**列表数据*/
    @GetMapping("/list")
    @ResponseBody
    public PageResultVo findFeedback(Feedback feedback, Integer limit, Integer page, HttpSession session){
        String type = (String)session.getAttribute("type");
        if(type.equals("02")){
            Manage manage = (Manage)session.getAttribute("userInfo");
            feedback.setType("01");
            feedback.setHmid(String.valueOf(manage.getId()));
        }
        if(type.equals("03")){
            User user = (User)session.getAttribute("userInfo");
            feedback.setType("02");
            feedback.setHmid(String.valueOf(user.getId()));
        }
        PageHelper.startPage(page,limit);
        List<Feedback> feedbackList = feedbackService.selectByCondition(feedback);
        for(int i=0;i<feedbackList.size();i++){
            if(feedbackList.get(i).getHmid()!=null){
                if(feedbackList.get(i).getType().equals("01")){
                    Manage manage = manageService.selectById(feedbackList.get(i).getHmid());
                    feedbackList.get(i).setHmname(manage.getRealname());
                }else{
                    User user = userService.selectById(feedbackList.get(i).getHmid());
                    feedbackList.get(i).setHmname(user.getRealname());
                }
            }
        }
        PageInfo<Feedback> pages = new PageInfo<>(feedbackList);
        return JsonData.table(feedbackList,pages.getTotal());
    }
    /**编辑详情*/
    @GetMapping("/edit")
    @ResponseBody
    public Feedback edit(Model model, String id){
        return feedbackService.selectById(id);
    }
    /**编辑*/
    @PostMapping("/edit")
    @ResponseBody
    public JsonData edit(Feedback feedback){
        int a = feedbackService.updateById(feedback);
        if (a > 0) {
          return JsonData.success(null,"编辑成功!");
        } else {
          return JsonData.fail("编辑失败");
        }
    }
    /**删除*/
    @PostMapping("/del")
    @ResponseBody
    public JsonData del(String id){
        try{
          feedbackService.deleteById(Integer.parseInt(id));
        }catch(Exception ex){
          JsonData.fail("出现错误");
        }
        return JsonData.success(null,"删除成功");
    }
    /**新增*/
    @PostMapping("/add")
    @ResponseBody
    public JsonData add(Feedback feedback, HttpSession session){
        Date date = new Date();
        feedback.setCreateTime(date);
        String type = (String)session.getAttribute("type");
        if(type.equals("02")){
            Manage manage = (Manage)session.getAttribute("userInfo");
            feedback.setHmid(String.valueOf(manage.getId()));
            feedback.setType("01");
        }
        if(type.equals("03")){
            User user = (User)session.getAttribute("userInfo");
            feedback.setHmid(String.valueOf(user.getId()));
            feedback.setType("02");
        }
        int num = feedbackService.addByCondition(feedback);
        if(num > 0){
          return JsonData.success(null,"添加成功");
        }else {
          return JsonData.fail("添加失败");
        }
    }


下面是文件上传的核心代码:


 /**
     * 文件上传
     * @param dropFile
     * @param request
     * @return
     */
    @ResponseBody
    @RequestMapping(value = "/avatar", method = RequestMethod.POST)
    public Map<String, Object> acticleAvatar(MultipartFile dropFile, HttpServletRequest request) throws IOException {
        Map<String, Object> result = new HashMap<>();
        //获取文件后缀
        String fileName = dropFile.getOriginalFilename();
        String fileSuffix = fileName.substring(fileName.lastIndexOf('.'));
        //文件存放路径
        String fileDirPath = new String(uploadDir);
        File fileDir = new File(fileDirPath);
        //判断文件是否存在
        if (!fileDir.exists()){
            fileDir.mkdirs();
        }
        File file = new File(fileDir.getAbsolutePath()+ File.separator+ UUID.randomUUID() + fileSuffix);
        try {
            dropFile.transferTo(file);
        } catch (IOException e) {
            e.printStackTrace();
        }
        //传到前端
        result.put("fileName", "http://localhost:"+port+"/upload/"+file.getName());
        return result;
    }
    /**
     * 后台内容图片上传
     * @param dropFile
     * @param request
     * @return
     */
    @RequestMapping(value = "/ContentUpload", method = RequestMethod.POST)
    @ResponseBody
    public Map<String, Object> hotelContentUpload(MultipartFile dropFile, HttpServletRequest request) {
        Map<String, Object> result = new HashMap<>();
        //获取文件后缀
        String fileName = dropFile.getOriginalFilename();
        String fileSuffix = fileName.substring(fileName.lastIndexOf('.'));
        //文件存放路径
        String fileDirPath = new String(uploadDir);
        File fileDir = new File(fileDirPath);
        //判断文件是否存在
        if (!fileDir.exists()){
            fileDir.mkdirs();
        }
        File file = new File(fileDir.getAbsolutePath()+ File.separator+ UUID.randomUUID() + fileSuffix);
        try {
            dropFile.transferTo(file);
        } catch (IOException e) {
            e.printStackTrace();
        }
        //传到前端
        result.put("errno",0);
        result.put("data",new String[] {"http://localhost:"+port+"/upload/" + file.getName()});
        return result;
    }


用户登录功能:


/**
   * 登录
   * 将提交数据(username,password)写入Admin对象
   */
  @RequestMapping(value = "/login")
  @ResponseBody
  public String login(String username, String password, String type, Model model, HttpSession session) {
    Map mp = new HashMap();
    if(username.equals("") || password.equals("")){
      return "202";
    }
    if(type.equals("01")){
      mp.put("username",username);
      mp.put("password",password);
      List<Admin> admins = adminService.queryFilter(mp);
      if(admins!=null && admins.size()==1){
        session.setAttribute("userInfo", admins.get(0));
        session.setAttribute("type", "01");
      }else{
        return "201";
      }
    }else if(type.equals("02")){
      mp.put("phone",username);
      mp.put("password",password);
      mp.put("type","01");
      List<Manage> manages = manageService.queryFilter(mp);
      if(manages!=null && manages.size()==1){
        session.setAttribute("userInfo", manages.get(0));
        session.setAttribute("type", "02");
      }else{
        return "201";
      }
    }else{
      mp.put("phone",username);
      mp.put("password",password);
      mp.put("type","02");
      List<User> users = userService.queryFilter(mp);
      if(users!=null && users.size()==1){
        session.setAttribute("userInfo", users.get(0));
        session.setAttribute("type", "03");
        return "203";
      }else{
        return "201";
      }
    }
    return "200";
  }


以上就是部分功能展示,从整体上来看,本系统功能是十分完整的,界面设计简洁大方,交互友好,数据库设计也很合理,规模适中,代码工整,清晰,适合学习使用。


好了,今天就到这儿吧,小伙伴们点赞、收藏、评论,一键三连走起呀,下期见~~

相关文章
|
6天前
|
JavaScript Java 项目管理
Java毕设学习 基于SpringBoot + Vue 的医院管理系统 持续给大家寻找Java毕设学习项目(附源码)
基于SpringBoot + Vue的医院管理系统,涵盖医院、患者、挂号、药物、检查、病床、排班管理和数据分析等功能。开发工具为IDEA和HBuilder X,环境需配置jdk8、Node.js14、MySQL8。文末提供源码下载链接。
|
16天前
|
存储 安全 Java
打造智能合同管理系统:SpringBoot与电子签章的完美融合
【10月更文挑战第7天】 在数字化转型的浪潮中,电子合同管理系统因其高效、环保和安全的特点,正逐渐成为企业合同管理的新宠。本文将分享如何利用SpringBoot框架实现一个集电子文件签字与合同管理于一体的智能系统,探索技术如何助力合同管理的现代化。
47 4
|
16天前
|
前端开发 Java Apache
SpringBoot实现电子文件签字+合同系统!
【10月更文挑战第15天】 在现代企业运营中,合同管理和电子文件签字成为了日常活动中不可或缺的一部分。随着技术的发展,电子合同系统因其高效性、安全性和环保性,逐渐取代了传统的纸质合同。本文将详细介绍如何使用SpringBoot框架实现一个电子文件签字和合同管理系统。
36 1
|
18天前
|
文字识别 安全 Java
SpringBoot3.x和OCR构建车牌识别系统
本文介绍了一个基于Java SpringBoot3.x框架的车牌识别系统,详细阐述了系统的设计目标、需求分析及其实现过程。利用Tesseract OCR库和OpenCV库,实现了车牌图片的识别与处理,确保系统的高准确性和稳定性。文中还提供了具体的代码示例,展示了如何构建和优化车牌识别服务,以及如何处理特殊和异常车牌。通过实际应用案例,帮助读者理解和应用这一解决方案。
|
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 的前后端分离的后台管理系统
19 0
|
22天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 实现动态路由和菜单功能,快速搭建前后端分离的应用框架。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,包括版本兼容性、安全性、性能调优等方面。
113 1
|
2月前
|
前端开发 JavaScript Java
基于Java+Springboot+Vue开发的服装商城管理系统
基于Java+Springboot+Vue开发的服装商城管理系统(前后端分离),这是一项为大学生课程设计作业而开发的项目。该系统旨在帮助大学生学习并掌握Java编程技能,同时锻炼他们的项目设计与开发能力。通过学习基于Java的服装商城管理系统项目,大学生可以在实践中学习和提升自己的能力,为以后的职业发展打下坚实基础。
136 2
基于Java+Springboot+Vue开发的服装商城管理系统
|
2月前
|
前端开发 JavaScript Java
SpringBoot项目部署打包好的React、Vue项目刷新报错404
本文讨论了在SpringBoot项目中部署React或Vue打包好的前端项目时,刷新页面导致404错误的问题,并提供了两种解决方案:一是在SpringBoot启动类中配置错误页面重定向到index.html,二是将前端路由改为hash模式以避免刷新问题。
184 1
|
6天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个具有动态路由和菜单功能的前后端分离应用。首先,创建并配置 Spring Boot 项目,实现后端 API;然后,使用 Ant Design Pro Vue 创建前端项目,配置动态路由和菜单。通过具体案例,展示了如何快速搭建高效、易维护的项目框架。
84 62
|
4天前
|
JavaScript 安全 Java
如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能
本文介绍了如何使用 Spring Boot 和 Ant Design Pro Vue 构建一个前后端分离的应用框架,实现动态路由和菜单功能。首先,确保开发环境已安装必要的工具,然后创建并配置 Spring Boot 项目,包括添加依赖和配置 Spring Security。接着,创建后端 API 和前端项目,配置动态路由和菜单。最后,运行项目并分享实践心得,帮助开发者提高开发效率和应用的可维护性。
13 2