基于Spring Boot的宠物领养系统(毕设)

项目背景介绍

本课题的研究是基于Spring Boot的宠物领养系统的设计与实现,采用目前主流的Java语言进行编写;整个系统使用MVC设计模式,将业务逻辑与显示界面分离,实现前后端分离;前端使用Vue框架,配合Element中的UI组件库进行开发,后端利用Spring Boot框架进行逻辑控制,并使用MySQL数据库存储管理数据。

一、项目主要功能

本系统分为用户端和管理员端:
用户端包括以下模块:宠物喂养、流浪宠物救助、宠物喂养点、丢失宠物查看、流浪宠物救助站、宠物论坛、宠物捐赠、科普文章和热门活动;
管理员端包括以下模块:流浪动物管理、申请领养管理、评论管理、流浪动物救助管理、喂养点管理、动物走失管理、救助站管理、帖子管理、捐赠管理、公告管理、科普文章管理和活动管理。

二、项目研究背景

宠物在人类生活中扮演着越来越重要的角色,它们不仅能给人们带来欢乐和陪伴,还能减轻人们的压力和孤独感。同时,随着城市化进程的加快,越来越多的宠物流浪到了城市街头,给城市管理和环境卫生带来了一定的困扰。

为了解决这些问题,宠物领养成为了一种非常有意义的活动。它不仅可以帮助流浪动物找到新的家,还可以提高流浪动物的生活质量和幸福指数。然而,宠物领养需要一定的时间和经济成本,而且领养过程中还需要考虑到宠物和领养人之间的匹配度,因此需要一种更加智能化和高效的宠物领养系统。

宠物领养的意义是为收养机构提供一个方便且便捷的管理系统,包括宠物信息管理、领养者信息管理、宠物收养申请处理等功能,减少手工管理的工作量和人工错误;为领养者提供一个方便的查找和筛选宠物的平台,可以根据不同的需求和条件搜索符合要求的宠物信息,减少了去收容所实地寻找的时间和成本;为领养者和收养机构提供一个方便、可靠的联系渠道,可以在系统内进行咨询、预约和预览等交流活动,提高领养者和收养机构之间的沟通效率和信任度;为公众提供一个重要的宣传渠道,可以通过系统展示领养宠物的信息和照片,传递动物保护的理念和宠物领养的重要性,提高公众的意识和参与度。

项目部分截图

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

项目功能分析

用户端:
首页:播放宠物视频,展示公告列表,介绍流浪宠物。
宠物领养:用户搜索想要领养宠物,申请领养,查看自己领养的宠物。
流浪宠物救助:用户能够看到需要救助的流浪宠物,并能够新增新的流浪宠物信息。
宠物喂养点:用户能够看到需要喂养的流浪宠物的地点,并展示出地点环境。
丢失宠物查看:用户能够看到其他用户丢失的宠物和失主的信息。
流浪宠物救助站:展示宠物救助站地点、负责人和联系方式。
宠物论坛:用户能够在此页面交流宠物领养的心得,评论别人发的帖子。
宠物捐赠:用户联系负责人,对流浪宠物捐赠。
科普文章:用户能够阅读宠物相关的文章。
热门活动:管理员会发布宠物相关的热门活动,宠物爱好者可以了解并参加。
管理员端:
主页:展示宠物领养系统各季度注册的人数,通过柱状图、折线图和饼图显示出来。
用户管理:对注册用户的信息管理。
角色管理:管理员为注册的用户分配系统菜单。
菜单管理:管理员对宠物领养系统后台菜单管理。
文件管理:管理员统一管理系统文件,并将系统文件存放于电脑磁盘中。
流浪动物管理:管理员通过管理流浪宠物模块,发布流浪宠物的详细信息并在用户端的页面进行展示。
待绝育动物管理:管理流浪动物的健康信息。
申请领养管理:管理员处理用户领养信息。
评论管理:管理员对宠物论坛的用户评论管理。
流浪动物救助:管理员发布需要救助的流浪动物,处理已经解决的流浪动物。
喂养点管理:管理员管理宠物喂养点。
动物走失管理:管理员管理丢失的动物。
救助站管理:管理员管理流浪动物的救助站。
帖子管理:管理员管理宠物论坛的帖子。
捐赠管理:管理员添加捐赠人的信息。
公告管理:管理员管理用户端首页公告。
科普文章管理:管理员管理用户端的科普文章展示。
活动管理:管理员管理宠物相关的活动,并发布到用户端的热门活动模块。

系统整体功能结构

在这里插入图片描述

部分参考代码

package com.example.controller;

import cn.hutool.core.date.DateUtil;
import cn.hutool.poi.excel.ExcelUtil;
import cn.hutool.poi.excel.ExcelReader;
import cn.hutool.poi.excel.ExcelWriter;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.ServletOutputStream;
import java.net.URLEncoder;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.example.common.Result;
import com.example.config.interceptor.AuthAccess;
import com.example.entity.Animal;
import com.example.entity.User;
import com.example.service.IAnimalService;
import com.example.utils.TokenUtils;
import org.springframework.web.bind.annotation.*;
import javax.annotation.Resource;
import java.io.InputStream;
import java.util.List;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import org.springframework.web.multipart.MultipartFile;

import org.springframework.web.bind.annotation.RestController;

/**
 * <p>
 *  前端控制器
 * </p>
 *
 * @author
 * @since 2022-04-02
 */
@RestController
@RequestMapping("/animal")
public class AnimalController {

    @Resource
    private IAnimalService animalService;

    private final String now = DateUtil.now();

    // 新增或者更新
    @PostMapping
    public Result save(@RequestBody Animal animal) {
        animalService.saveOrUpdate(animal);
        return Result.success();
    }

    @DeleteMapping("/{id}")
    public Result delete(@PathVariable Integer id) {
        animalService.removeById(id);
        return Result.success();
    }

    @PostMapping("/del/batch")
    public Result deleteBatch(@RequestBody List<Integer> ids) {
        animalService.removeByIds(ids);
        return Result.success();
    }

    @GetMapping
    public Result findAll() {
        return Result.success(animalService.list());
    }

    @GetMapping("/{id}")
    public Result findOne(@PathVariable Integer id) {
        return Result.success(animalService.getById(id));
    }

    @AuthAccess
    @GetMapping("/page/user")
    public Result findPage(@RequestParam(defaultValue = "") String name,
                           @RequestParam Integer pageNum,
                           @RequestParam Integer pageSize) {
        QueryWrapper<Animal> queryWrapper = new QueryWrapper<>();
        queryWrapper.orderByDesc("id");
        if (!"".equals(name)) {
            queryWrapper.like("nickname", name);
        }
        queryWrapper.eq("adopt", "可领养");
        return Result.success(animalService.page(new Page<>(pageNum, pageSize), queryWrapper));
    }

    @AuthAccess
    @GetMapping("/page")
    public Result findPage(@RequestParam(defaultValue = "") String name,
                           @RequestParam(defaultValue = "") String adopt,
                           @RequestParam Integer pageNum,
                           @RequestParam Integer pageSize) {
        QueryWrapper<Animal> queryWrapper = new QueryWrapper<>();
        queryWrapper.orderByDesc("id");
        if (!"".equals(name)) {
            queryWrapper.like("nickname", name);
        }
        if (!"".equals(adopt)) {
            queryWrapper.eq("adopt", adopt);
        }
        return Result.success(animalService.page(new Page<>(pageNum, pageSize), queryWrapper));
    }

    /**
    * 导出接口
    */
    @GetMapping("/export")
    public void export(HttpServletResponse response) throws Exception {
        // 从数据库查询出所有的数据
        List<Animal> list = animalService.list();
        // 在内存操作,写出到浏览器
        ExcelWriter writer = ExcelUtil.getWriter(true);

        // 一次性写出list内的对象到excel,使用默认样式,强制输出标题
        writer.write(list, true);

        // 设置浏览器响应的格式
        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8");
        String fileName = URLEncoder.encode("Animal信息表", "UTF-8");
        response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx");

        ServletOutputStream out = response.getOutputStream();
        writer.flush(out, true);
        out.close();
        writer.close();

        }

    /**
     * excel 导入
     * @param file
     * @throws Exception
     */
    @PostMapping("/import")
    public Result imp(MultipartFile file) throws Exception {
        InputStream inputStream = file.getInputStream();
        ExcelReader reader = ExcelUtil.getReader(inputStream);
        // 通过 javabean的方式读取Excel内的对象,但是要求表头必须是英文,跟javabean的属性要对应起来
        List<Animal> list = reader.readAll(Animal.class);

        animalService.saveBatch(list);
        return Result.success();
    }

    private User getUser() {
        return TokenUtils.getCurrentUser();
    }

}


三、总结

本课题旨在设计和实现一个宠物领养系统。前端使用Vue框架,通过Element-ui组件库的配合使用构建前端的页面;后端使用Spring Boot框架,通过使用Java语言实现后端的逻辑控制。本系统还使用Maven插件实现项目的目录构建,更加方便且便于扩展。AJAX技术的使用让系统的数据交互使用更加便捷,更有利于用户流畅的使用系统。
本系统在用户端提供了首页、宠物喂养、流浪宠物救助、宠物喂养点、丢失宠物查看、流浪宠物救助站、宠物论坛、宠物捐赠、科普文章和热门活动等模块。前台的功能模块提供的在线聊天宠物论坛和线下宠物热门活动交流等交流方式,帮助用户更好地了解和照顾宠物。在管理员端本系统提供了主页、系统管理、流浪动物管理、待绝育动物管理、申请领养管理、评论管理、流浪动物救助管理、喂养点管理、动物走失管理、救助站管理、帖子管理、捐赠管理、公告管理、科普文章管理和活动管理等模块。后台简便、易上手的功能模块能够更加高效便捷的帮助管理员管理整个系统,避免繁琐的步骤。
本课题的主要贡献是开发一种更加智能化和高效的宠物领养系统,能够帮助领养人更快捷、更精确地找到适合自己的宠物,同时还可以提高流浪动物的领养率和幸福指数。这对于推广宠物领养,提高流浪动物的生活质量和减少流浪动物数量具有重要的现实意义。
当然本系统还有诸多不足之处需要完善,如果能够实现宠物和领养人之间的高匹配度,系统自动推荐合适领养人性格的宠物,这会使得系统更加全面。诸如此类的问题,需要在以后的学习中不断进步改善。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值