微信小程序开发 Java 开发校园报修系统

​此项目不定期分享进度

绪论

随着高校每年的扩大招生,学校人数越来越多,学校后勤报修管理的工作量也越水越繁重。使用传统的管理手段和方法,很难完成大量的信息分析和处理。因此,充分利用网络资源和信息化技术,建设一套基于校园网的学校后勤报修管理系统,提高后勤管理水平、效率和质量,使学校后勤管理科学化、信息化、现代化,是新时期学校后勤管理工作面临的一个新的课题。

设计开发学校后勤报修管理系统,主要有一下几方面的原因:
1、传统的报修、维修环节,存在着方法落后、手续烦琐、工作量大的缺点,以不能适应新形势的要求;
2、 高校不断扩招,学校的设备也不断增多,需利用现代化手段进行管理;
3、赶上新时代的步伐,实现后勤报修管理的规范化、信息化,提高后勤报修管理的服务质量和服务效率,基于以上的原因,原有的后勤报修维修手段,以不能适应新情况要求,为提高后勤管理效率和质量,降低后勤管理的人力、物力和财力,方便广大师生生活和学习,开发一个学校后勤报修管理系统十分重要。

研究背景及现状

在信息化社会迎来知识经济的时代,校园的信息化和数字化建设成为国内外高校建设的热点.它的基本特征体现为高起点、高投资和快速,相对于国内高校而言,还存在起步早的特点。在一个多世纪以前,美国的一所大学就提出了数宇化校园的概念,随后美国的麻省理工学院对这个概念,经过多年的努力研究,设计、构建出一个比较成熟的数字化校园的模型。调查显示,在西方的发达国家中一些著名的世界大学,己经于上世纪末成功地建设好了数字化校园。此外,我国在现阶段的信息数字化方面的工作,也开始进入一个全新的发展时期。尤其是在信息化高校的建设方面,己经步入了全面的发展阶段。许多高校都意识到信息化建设,是提高管理手段和水平,保证管理效率和质量的重要渠道。然而,就信息化高校建设的整体上而言,我国的高等教育信息化、数字化、现代化,仍然处于社会主义初级阶段。

需求分析

技术需求分析

本课题为《基于java的校园报修微信小程序系统的设计与实现》。本系统采用B/S架构实现系统功能。主要使用微信小程序、vue和JAVA语音处理完成。系统的后台则利用mysql数据库作为数据库服务器。系统的开发利用idea或者eclipse工具完成代码编写、调试和运行,利用本机作为服务器模拟实现系统功能。

功能需求分析

根据调查,发现原来的校园报修的方法,都是通过手工登记信息、人工传递信息、人工通知维修员、人工处理结果,手段落后,过程繁琐,效率不高。小程序作为新兴产业,他有着app无法企及的优点,随用随开,不用下载,它实现对应用的触手可及,方便用户使用。鉴于此,我决定开发基于微信小程序的校园报修系统,应该具有以下功能:

  1. 首先,系统需要设置三种权限的用户:系统管理员、维修人员和普通人员(学生)。

  2. 管理员的功能:系统功能、用户管理,其中对学生的管理(禁用、启用)、维修人员的管理(设置维修人员)、报修设备管理、报修审核管理(派单)

  3. 维修人员:查询和修改个人信息、对故障设备进行维修管理

  4. 普通用户(学生):查询修改个人信息,对设置进行报修、评价等

系统设计

1.系统总框架设计

从系统功能的角度上看,本系统主要设计了两大模块,客户端,即系统前台;管理端,即系统后台。系统前台分为维修人员和学生,设计了提交报修、我的报修、处理报修、意见建议等。在系统后台,设计了两种权限的管理用户:超级管理员和管理员。每种用户都有属于自己的后台界面,每种用户的后台设计模块说吗如下:

  1. 超级管理员后台

在超级管理员后台,设计了6个功能模块,分别是:系统管理、用户管理、维修人员管理、意见反馈管理、报修管理、通知公告管理。

2.管理员后台

在管理员后台,设计了4个功能模块,分别是:用户管理、维修人员管理、设备信息管理、报修管理。

微信小程序开发 Java 开发校园报修系统

后台结构图

本系统前台对学生和维修人员开发,采用微信小程序,在第一次进入系统时,系统获取用户的openid去判断是那种角色,用于展示不同的功能入口。在未授权状态下可以查看公告等。如果对故障设备进行报修和维修需求进行授权登录才能操作。

系统实现

微信小程序部分

微信小程序开发 Java 开发校园报修系统

微信小程序开发 Java 开发校园报修系统

提交报修页面

微信小程序开发 Java 开发校园报修系统

我的报修部分

报修详情

学生端这块,暂时写了这么多。

后台部分

renren-fast是一个轻量级的Spring Boot2.1快速开发平台,其设计目标是开发迅速、学习简单、轻量级、易扩展;使用Spring Boot、Shiro、MyBatis、Redis、Bootstrap、Vue2.x等框架,包含:管理员列表、角色管理、菜单管理、定时任务、参数管理、代码生成器、日志管理、云存储、API模块(APP接口开发利器)、前后端分离等。
https://gitee.com/renrenio/renren-fast

微信小程序开发 Java 开发校园报修系统

文件上传实现

微信小程序开发 Java 开发校园报修系统

小程序代码 小程序使用的vant-ui作为前端框架

微信小程序开发 Java 开发校园报修系统
<van-uploader file-list="{{ fileList }}" bind:after-read="afterRead"></van-uploader>

​js

afterRead(event){
    const { file } = event.detail;
    // &#x5F53;&#x8BBE;&#x7F6E; mutiple &#x4E3A; true &#x65F6;, file &#x4E3A;&#x6570;&#x7EC4;&#x683C;&#x5F0F;&#xFF0C;&#x5426;&#x5219;&#x4E3A;&#x5BF9;&#x8C61;&#x683C;&#x5F0F;
    // console.log(file)
    API.upLoad(file,{}).then(res=>{
        if(res.code==0){
            this.data.fileList.push({url:imgurl+res.name})
            this.setData({
                fileList:this.data.fileList
            })
        }else {
            wx.showToast({
                title: '&#x4E0A;&#x4F20;&#x5931;&#x8D25;&#xFF0C;&#x8BF7;&#x91CD;&#x8BD5;',
                icon: 'warning',
                duration: 2000
            })
        }
    }).catch(e=>{
        wx.showToast({
            title: '&#x4E0A;&#x4F20;&#x5931;&#x8D25;&#xFF0C;&#x8BF7;&#x91CD;&#x8BD5;',
            icon: 'warning',
            duration: 2000
        })
    })
},

我封装了上传文件的方法

微信小程序开发 Java 开发校园报修系统
  /**
   * @description &#x4E0A;&#x4F20;&#x6587;&#x4EF6;
   * @param {*} url &#x8BF7;&#x6C42;&#x5730;&#x5740;
   * @param {*} data &#x53C2;&#x6570;
   */
  function upLoad(url,file, data = {}) {
    return new Promise((resolve, reject) => {
      wx.uploadFile({
        url: URL[envVersion].BASE_URL +url, // &#x4EC5;&#x4E3A;&#x793A;&#x4F8B;&#xFF0C;&#x975E;&#x771F;&#x5B9E;&#x7684;&#x63A5;&#x53E3;&#x5730;&#x5740;
        filePath: file.url,
        name: 'file',
        header:{"content-type":"application/json;charset=utf-8"},
        formData: data,
        success(res) {
          // &#x4E0A;&#x4F20;&#x5B8C;&#x6210;&#x9700;&#x8981;&#x66F4;&#x65B0; fileList
          resolve(JSON.parse(res.data));
        },
        fail(e){
          reject(e);
        }
      });
    })
  }

前端的代码就这么多了

后端上传这块核心的方法是一个上传方法和读取文件的方法(这块我是使用的返回文件流的方式返回给前端)你可以选择其他的方式也可以实现 业务层代码如下

package io.renren.modules.mini.service.impl;

import cn.hutool.core.io.FileUtil;
import io.renren.modules.mini.service.FileService;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Service;
import org.springframework.web.multipart.MultipartFile;

import javax.servlet.http.HttpServletResponse;
import java.io.*;
import java.util.UUID;

/**
 * &#x5BF9;&#x6587;&#x4EF6;&#x7684;&#x64CD;&#x4F5C;
 */
@Service("fileService")
public class FileServiceImpl implements FileService {
    @Value("${file.downpath}")
    private String downPath;

    @Override
    public String uploadFile(MultipartFile file) {
        boolean exist = FileUtil.exist(downPath);
        if(!exist){
            FileUtil.mkdir(downPath);
        }
        String suffix = file.getOriginalFilename().substring(file.getOriginalFilename().lastIndexOf("."));
        String uuid = UUID.randomUUID().toString();
        String filename = uuid+suffix;
        File newFile =  new File(downPath+filename);
        try {
            file.transferTo(newFile);
            return filename;
        } catch (IOException e) {
            e.printStackTrace();
            return null;
        }
    }

    @Override
    public void readImg(String name, HttpServletResponse response) {
        String realPath = downPath+name;
        FileInputStream inputStream = null;
        try {
            inputStream = new FileInputStream(realPath);
            int i = inputStream.available();
            //byte&#x6570;&#x7EC4;&#x7528;&#x4E8E;&#x5B58;&#x653E;&#x56FE;&#x7247;&#x5B57;&#x8282;&#x6570;&#x636E;
            byte[] buff = new byte[i];
            inputStream.read(buff);
            //&#x8BB0;&#x5F97;&#x5173;&#x95ED;&#x8F93;&#x5165;&#x6D41;
            inputStream.close();
            //&#x8BBE;&#x7F6E;&#x53D1;&#x9001;&#x5230;&#x5BA2;&#x6237;&#x7AEF;&#x7684;&#x54CD;&#x5E94;&#x5185;&#x5BB9;&#x7C7B;&#x578B;
            response.setContentType("image/*");
            OutputStream out = response.getOutputStream();
            out.write(buff);
            //&#x5173;&#x95ED;&#x54CD;&#x5E94;&#x8F93;&#x51FA;&#x6D41;
            out.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

Original: https://www.cnblogs.com/huyande/p/16437542.html
Author: yinder
Title: 微信小程序开发 Java 开发校园报修系统

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/587325/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球