灾区物资救助系统|基于Springboot开发实现灾区物资救助系统

作者简介:Java、前端、Python开发多年,做过高程,项目经理,架构师

主要内容:Java项目开发、Python项目开发、大学数据和AI项目开发、单片机项目设计、面试技术整理、最新技术分享

收藏点赞不迷路  关注作者有好处

文末获得源码

 项目编号:BS-XX-198

一,环境介绍

语言环境:Java:  jdk1.8

数据库:Mysql: mysql5.7

应用服务器:Tomcat:  tomcat8.5.31

开发工具:IDEA或eclipse

开发技术:Springboot+JSP

二,项目简介

本基目主要基于Java开发技术实现一个灾区物资救助管理系统,用户注册后登录系统后可以在线申请救助,由管理员进行审批,也可以对别人的求助进行帮助,同时可以查看相关的灾区新闻信息,管理个人信息等。平台管理员登录系统后可以审核相关的求助信息,救助信息等,同时管理相关资讯信息,账号信息,轮播图信息,查看相关的图形报表统计数据等。具体的功能如下面展示。

三,系统展示

用户登录

轮播图及新闻展示

个人中心管理

我要求助

我来帮助

我的相关申请

求助审核

账号管理

新闻资讯

轮播图管理

数据统计

四,核心代码展示

package com.liuyang.controller;


import cn.hutool.core.date.DateUtil;
import cn.hutool.crypto.SecureUtil;
import com.liuyang.common.Result;
import com.liuyang.entity.Account;
import com.liuyang.service.AccountService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;

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

import java.util.Date;

/**
 * <p>
 *  前端控制器
 * </p>
 *
 * @author 作者:me
 * @since 2022-02-22
 */
@RestController
@RequestMapping("/system/account")
public class AccountController {

    @Autowired
    private AccountService accountService;

    /**
     * 编辑个人中心
     * @param account
     * @return
     */
    @PostMapping("/editAccount")
    public Result editAccount(Account account) {
        account.setAccountPassword(SecureUtil.md5(account.getAccountPassword()));
        accountService.saveOrUpdate(account);
        return Result.succ("更新成功...");
    }

}

package com.liuyang.controller;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;

import javax.servlet.http.HttpSession;

@Controller
public class IndexController {

    // 首页
    @GetMapping("/index")
    public String index() {
        return "index";
    }

    // 注册页
    @GetMapping("/register")
    public String register() {
        return "register";
    }

    // 后台主页
    @GetMapping("/system/index")
    public String systemIndex() {
        return "system/index";
    }

    // 后台菜单
    @GetMapping("/system/menu")
    public String systemMenu() {
        return "system/menu";
    }

    // 我的首页
    @GetMapping("/system/welcome")
    public String systemWelcome() {
        return "system/welcome";
    }

    // 我要求助
    @GetMapping("/system/sendHelp")
    public String systemSendHelp() {
        return "system/send-help";
    }

    // 我来帮助
    @GetMapping("/system/receiveHelp")
    public String systemReceiveHelp() {
        return "system/receive-help";
    }

    // 个人中心
    @GetMapping("/system/userInfo")
    public String systemUserInfo() {
        return "system/user-info";
    }

    // 我的申请 - 求助申请
    @GetMapping("/system/userApply")
    public String systemUserApply() {
        return "system/user-apply";
    }

    // 我的申请 - 帮助申请
    @GetMapping("/system/userHelp")
    public String systemUserHelp() {
        return "system/user-help";
    }

    // 注销
    @GetMapping("/logout")
    public String logout(HttpSession session) {
        session.invalidate();
        return "index";
    }

    // 物资详情
    @GetMapping("/system/ReceiveDetailHelp")
    public String systemReceiveDetailHelp() {
        return "system/receive-detail-help";
    }

    // 求助审核
    @GetMapping("/system/checkApply")
    public String systemCheckApply() {
        return "system/check-apply";
    }

    // 账号管理
    @GetMapping("/system/accountManage")
    public String systemAccountManage() {
        return "system/account-manage";
    }

    // 新闻资讯
    @GetMapping("/system/newsManage")
    public String systemNewsManage() {
        return "system/news-manage";
    }

    // 数据统计
    @GetMapping("/system/statisticsManage")
    public String systemStatisticsManage() {
        return "system/statistics-manage";
    }

    // 轮播图
    @GetMapping("/system/carouselManage")
    public String systemCarouselManage() {
        return "system/carousel-manage";
    }

    // 日志
    @GetMapping("/system/logsManage")
    public String systemLogsManage() {
        return "system/logs-manage";
    }
}
package com.liuyang.controller;

import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.date.DateUtil;
import cn.hutool.core.lang.Snowflake;
import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.liuyang.common.Result;
import com.liuyang.common.TableResult;
import com.liuyang.entity.Disasterimg;
import com.liuyang.entity.Materials;
import com.liuyang.entity.Materialsimg;
import com.liuyang.service.DisasterimgService;
import com.liuyang.service.MaterialsService;
import com.liuyang.service.MaterialsimgService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;

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

import java.util.Date;
import java.util.List;
import java.util.Map;

/**
 * <p>
 *  前端控制器
 * </p>
 *
 * @author 作者:me
 * @since 2022-02-23
 */
@RestController
@RequestMapping("/system/materials")
public class MaterialsController {

    @Autowired
    private MaterialsService materialsService;

    @Autowired
    private MaterialsimgService materialsimgService;

    @Autowired
    private DisasterimgService disasterimgService;

    /**
     * 我要求助, 添加需要申请的物资信息
     * @param map
     * @return
     */
    @PostMapping("/addMaterials")
    public Result addMaterials(@RequestBody Map map) {
        if(map.size() == 0) {
            return Result.fail("申请失败");
        }
        Snowflake snowflake = new Snowflake(2,3);
        Materials materials = new Materials();
        String id = snowflake.nextIdStr();
        String applicationTime = DateUtil.format(new Date(), "yyyy-MM-dd");
        materials.setId(id);
        materials.setApplicationTime(applicationTime);
        materials.setStatus("3"); // 处于待帮助状态
        BeanUtil.fillBeanWithMap(map, materials, false);
        materialsService.saveOrUpdate(materials); // 添加物资
        String imgIds = map.get("imgIds").toString();
        List<String> imgIdsList = StrUtil.split(imgIds, ',');
        for(String imgId : imgIdsList) {
//            Materialsimg materialsimg = new Materialsimg();
//            materialsimg.setId(imgId);
//            materialsimg.setMaterialsId(id);
//            materialsimgService.saveOrUpdate(materialsimg);
            Disasterimg disasterimg = new Disasterimg();
            disasterimg.setId(imgId);
            disasterimg.setMaterialsId(id);
            disasterimgService.saveOrUpdate(disasterimg);
        }
        return Result.succ("申请成功");
    }

    /**
     * 我来帮助, 状态3, 3表示处于待接收帮助
     * @return
     */
    @GetMapping("/queryMaterials")
    public TableResult queryMaterials(String applicantId) {
        List<Materials> materialsList = materialsService.list(new QueryWrapper<Materials>().eq("status", "3").ne("applicantId", applicantId));
        TableResult tableResult = new TableResult(0, "ok",materialsList.size(),materialsList);
        return tableResult;
    }

    /**
     * 我的申请 - 求助申请
     * @param applicantId
     * @return
     */
    @GetMapping("/queryMaterialsByApplicantId")
    public TableResult queryMaterialsByApplicantId(String applicantId) {
        List<Materials> list = materialsService.list(new QueryWrapper<Materials>().eq("applicantId", applicantId));
        TableResult tableResult = new TableResult(0,"ok",list.size(),list);
        return tableResult;
    }

    /**
     * 我的申请 - 帮助申请
     * @param helperId
     * @return
     */
    @GetMapping("/queryMaterialsByHelperId")
    public TableResult queryMaterialsByHelperId(String helperId) {
        List<Materials> list = materialsService.list(new QueryWrapper<Materials>().eq("helperId", helperId));
        TableResult tableResult = new TableResult(0,"ok",list.size(),list);
        return tableResult;
    }

    /**
     * 物资详情
     * @param id
     * @return
     */
    @GetMapping("/queryMaterialsById")
    public Result queryMaterialsById(String id) {
        Materials materials = materialsService.queryMaterialsById(id);
        return Result.succ(materials);
    }

    /**
     * 我来帮助, 接受需要帮助物资, 状态置为 0, 表示从状态3变为0, 当前状态处于待审核状态
     * @param id
     * @return
     */
    @PostMapping("/editReceiveMaterialsById")
    public Result editReceiveMaterialsById(String id, String helperId, String helpType, String imgIds) {
        Materials materials = new Materials();
        materials.setId(id);
        materials.setStatus("0");
        materials.setHelperId(helperId);
        materials.setHelpType(helpType);

        List<String> imgIdsList = StrUtil.split(imgIds, ',');
        for(String imgId : imgIdsList) {
            Materialsimg materialsimg = new Materialsimg();
            materialsimg.setId(imgId);
            materialsimg.setMaterialsId(id);
            materialsimgService.saveOrUpdate(materialsimg);
        }
        materialsService.saveOrUpdate(materials);
        return Result.succ("申请帮助成功...");
    }

    /**
     * 求助审核, 对物资状态0, 进行查询
     * @return
     */
    @GetMapping("/queryMaterialsCheckApply")
    public TableResult queryMaterialsCheckApply() {
        List<Materials> list = materialsService.list(new QueryWrapper<Materials>().eq("status", "0"));
        TableResult tableResult = new TableResult(0, "ok",list.size(),list);
        return tableResult;
    }

    @PostMapping("/editMaterialsCheckApply")
    public Result editMaterialsCheckApply(String id, String status, String checkIdea) {
        Materials materials = new Materials();
        materials.setId(id);
        materials.setStatus(status);
        materials.setCheckIdea(checkIdea);
        materialsService.saveOrUpdate(materials);
        return Result.succ("1".equals(status)? "审核通过": "审核不通过");
    }
}

五,相关作品展示

基于Java开发、Python开发、PHP开发、C#开发等相关语言开发的实战项目

基于Nodejs、Vue等前端技术开发的前端实战项目

基于微信小程序和安卓APP应用开发的相关作品

基于51单片机等嵌入式物联网开发应用

基于各类算法实现的AI智能应用

基于大数据实现的各类数据管理和推荐系统

 

 

猜你喜欢

转载自blog.csdn.net/whirlwind526/article/details/133513041