微信小程序开发 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)

大家都在看

  • Maven 依赖调解源码解析(四):传递依赖,第一声明者优先

    本文是系列文章《Maven 源码解析:依赖调解是如何实现的?》第四篇,主要介绍依赖调解的第二条原则:传递依赖,第一声明者优先。请按顺序阅读其他系列文章,系列文章总目录参见:http…

    Java 2023年6月16日
    095
  • manjaro 安装后的基本配置

    第一步:设置官方镜像源 sudo pacman-mirrors -i -c China -m rank # 输入以上命令后会有弹出框,选择一个国内镜像(推荐 https://mir…

    Java 2023年6月6日
    065
  • 非自交任意多边形与矩形框的交集面积计算方法

    非自交任意多边形与矩形框的交集面积计算方法 1、应用背景 在对象识别的AI计算时,有时需要限定检测区域,即目标对象落在限定区域内有效,在区域外忽略。转换为数学模型为:目标检测框与限…

    Java 2023年6月14日
    068
  • SpringBoot整合WebService(实用版)

    SpringBoot整合WebService 简介 WebService就是一种跨编程语言和跨操作系统平台的远程调用技术 此处就不赘述WebService相关概念和原理了,可以参考…

    Java 2023年6月8日
    0104
  • 全文检索原理及实现方式

    一、总论 根据http://lucene.apache.org/java/docs/index.html 定义: “Apache Lucene(TM) is a hig…

    Java 2023年6月6日
    069
  • JavaScript中Date对象的使用

    注意:JS 的 Date 对象中有一个坑,它的月份是从 0 开始计算的。即 现实中的 1 月份为 Date 对象中的 0 月份 1. Date 对象的创建方式 无参构造 new 出…

    Java 2023年6月5日
    068
  • CompletableFuture的入门

    runAsync 和 supplyAsync runAsync接受一个Runable的实现,无返回值 CompletableFuture.runAsync(()->Syste…

    Java 2023年6月9日
    069
  • ConcurrentHashMap(1.8)分析

    在ConcurrentHashMap(1.8)中与HashMap非常相似,只不过它是线程安全的,在这里主要分析一下putVal()方法,看看与HashMap的区别。 final V…

    Java 2023年6月6日
    068
  • 数字化来势汹汹,低代码起势,JNPF助力企业定制专属BIM

    引言 当前的中国建筑市场极大,而建筑行业在迅速发展的同时也需要科学的可持续发展,所以施工企业面临着极其严峻的竞争挑战。在此背景下,国内企业运用BIM的比例持续升高是发展的必然。BI…

    Java 2023年6月5日
    092
  • Delphi 多线程的例子

    unit Unit1; interface uses Windows, Messages, SysUtils, Variants, Classes, Graphics, Contr…

    Java 2023年5月29日
    075
  • springboot2.3.x whitelabel error page 404

    一般资料都提3个问题 controller 位置不对 未添加依赖 注释 我的问题是 properties 要用 thymeleaf-spring5.version Original…

    Java 2023年5月30日
    063
  • Elasticsearch 入门实战(4)–Java Low Level REST Client 使用

    本文主要介绍 Elasticsearch Java Low Level REST Client 的使用,相关的环境及软件信息如下:CentOS 7.6.1810、Java 1.8….

    Java 2023年6月16日
    079
  • Stream流使用(Lamdba表达式重点场景)

    类型二: 数组:Arrays.stream(数组)或者使用Stream.of来创建 类型三:双列集合:转换成单列集合后创建 2)中间操作 filter( ) // 用作过滤集合元素…

    Java 2023年6月15日
    057
  • session204 imessageApp sticker part I要点

    session204 imessageApp sticker partI 这位老兄说话有点不清楚啊 给系统短信App创建表情包。 有两个方式:1.单独的纯图片2.含代码。 表情可以…

    Java 2023年5月30日
    073
  • Lambda表达式基础语法

    前言: Lambda作为匿名函数,与普通函数无异,所以与普通函数结构类似:(返回值类型 + 方法名 + 参数列表 + 方法体) 因为是匿名函数,所以可以进一步忽略,返回值类型、方法…

    Java 2023年6月15日
    063
  • 设置Typora自适应宽度以及图片居左

    前提: 已安装好Typora 一、设置Typora自适应宽度 Typora在最大化窗口后,书写区域没有跟随最大化,还处于中间位置,不太人性化 2、调整Typora书写区域为自适应宽…

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