微信小程序开发 Java 开发校园报修系统
<p><span data-cke-copybin-start="1">此项目不定期分享进度</span></p><h2>绪论</h2>
<p> 随着高校每年的扩大招生,学校人数越来越多,学校后勤报修管理的工作量也越水越繁重。使用传统的管理手段和方法,很难完成大量的信息分析和处理。因此,充分利用网络资源和信息化技术,建设一套基于校园网的学校后勤报修管理系统,提高后勤管理水平、效率和质量,使学校后勤管理科学化、信息化、现代化,是新时期学校后勤管理工作面临的一个新的课题。</p>
<p> 设计开发学校后勤报修管理系统,主要有一下几方面的原因:<br> 1、传统的报修、维修环节,存在着方法落后、手续烦琐、工作量大的缺点,以不能适应新形势的要求;<br> 2、 高校不断扩招,学校的设备也不断增多,需利用现代化手段进行管理;<br> 3、赶上新时代的步伐,实现后勤报修管理的规范化、信息化,提高后勤报修管理的服务质量和服务效率,基于以上的原因,原有的后勤报修维修手段,以不能适应新情况要求,为提高后勤管理效率和质量,降低后勤管理的人力、物力和财力,方便广大师生生活和学习,开发一个学校后勤报修管理系统十分重要。</p>
<h2>研究背景及现状</h2>
<p> 在信息化社会迎来知识经济的时代,校园的信息化和数字化建设成为国内外高校建设的热点.它的基本特征体现为高起点、高投资和快速,相对于国内高校而言,还存在起步早的特点。在一个多世纪以前,美国的一所大学就提出了数宇化校园的概念,随后美国的麻省理工学院对这个概念,经过多年的努力研究,设计、构建出一个比较成熟的数字化校园的模型。调查显示,在西方的发达国家中一些著名的世界大学,己经于上世纪末成功地建设好了数字化校园。此外,我国在现阶段的信息数字化方面的工作,也开始进入一个全新的发展时期。尤其是在信息化高校的建设方面,己经步入了全面的发展阶段。许多高校都意识到信息化建设,是提高管理手段和水平,保证管理效率和质量的重要渠道。然而,就信息化高校建设的整体上而言,我国的高等教育信息化、数字化、现代化,仍然处于社会主义初级阶段。</p>
<h2>需求分析</h2>
<h3>技术需求分析</h3>
<p> 本课题为《基于java的校园报修微信小程序系统的设计与实现》。本系统采用B/S架构实现系统功能。主要使用微信小程序、vue和JAVA语音处理完成。系统的后台则利用mysql数据库作为数据库服务器。系统的开发利用idea或者eclipse工具完成代码编写、调试和运行,利用本机作为服务器模拟实现系统功能。</p>
<h3>功能需求分析</h3>
<p> 根据调查,发现原来的校园报修的方法,都是通过手工登记信息、人工传递信息、人工通知维修员、人工处理结果,手段落后,过程繁琐,效率不高。小程序作为新兴产业,他有着app无法企及的优点,随用随开,不用下载,它实现对应用的触手可及,方便用户使用。鉴于此,我决定开发基于微信小程序的校园报修系统,应该具有以下功能:</p>
<p> 1. 首先,系统需要设置三种权限的用户:系统管理员、维修人员和普通人员(学生)。</p>
<p> 2. 管理员的功能:系统功能、用户管理,其中对学生的管理(禁用、启用)、维修人员的管理(设置维修人员)、报修设备管理、报修审核管理(派单)</p>
<p> 3. 维修人员:查询和修改个人信息、对故障设备进行维修管理</p>
<p> 4. 普通用户(学生):查询修改个人信息,对设置进行报修、评价等</p>
<h2>系统设计</h2>
<p> </p>
<h3>1.系统总框架设计</h3>
<p> 从系统功能的角度上看,本系统主要设计了两大模块,客户端,即系统前台;管理端,即系统后台。系统前台分为维修人员和学生,设计了提交报修、我的报修、处理报修、意见建议等。在系统后台,设计了两种权限的管理用户:超级管理员和管理员。每种用户都有属于自己的后台界面,每种用户的后台设计模块说吗如下:</p>
<p> 1. 超级管理员后台</p>
<p> 在超级管理员后台,设计了6个功能模块,分别是:系统管理、用户管理、维修人员管理、意见反馈管理、报修管理、通知公告管理。</p>
<p> 2.管理员后台</p>
<p> 在管理员后台,设计了4个功能模块,分别是:用户管理、维修人员管理、设备信息管理、报修管理。</p>
<p><span class="cke_widget_wrapper cke_widget_inline cke_widget_image cke_image_nocaption cke_widget_selected" data-cke-display-name="图像" data-cke-filter="off" data-cke-widget-id="2" data-cke-widget-wrapper="1"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425934-873895823.png" alt="" class="cke_widget_element" height="151" width="700" src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425934-873895823.png" data-cke-widget-data="%7B%22hasCaption%22%3Afalse%2C%22src%22%3A%22https%3A%2F%2Fimg-blog.csdnimg.cn%2F752329c748094fceb3be74b489bb82f2.png%22%2C%22alt%22%3A%22%22%2C%22width%22%3A%22700%22%2C%22height%22%3A%22151%22%2C%22lock%22%3Atrue%2C%22align%22%3A%22none%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="image"><span class="cke_reset cke_widget_drag_handler_container"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702142730987-1020751386.gif" class="cke_reset cke_widget_drag_handler" height="15" width="15" data-cke-widget-drag-handler="1"></span><span class="cke_image_resizer" title="点击并拖拽以改变尺寸"></span><span class="cke_widget_edit_container" title="编辑图片"><br></span></span></p>
<p>后台结构图 </p>
<p> 本系统前台对学生和维修人员开发,采用微信小程序,在第一次进入系统时,系统获取用户的openid去判断是那种角色,用于展示不同的功能入口。在未授权状态下可以查看公告等。如果对故障设备进行报修和维修需求进行授权登录才能操作。</p>
<p><span class="cke_widget_wrapper cke_widget_inline cke_widget_image cke_image_nocaption cke_widget_selected" data-cke-display-name="图像" data-cke-filter="off" data-cke-widget-id="1" data-cke-widget-wrapper="1"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425846-1660738773.png" alt="" class="cke_widget_element" height="1146" width="1200" src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425846-1660738773.png" data-cke-widget-data="%7B%22hasCaption%22%3Afalse%2C%22src%22%3A%22https%3A%2F%2Fimg-blog.csdnimg.cn%2F21bb2ecb64ce436c8707029baee2f284.png%22%2C%22alt%22%3A%22%22%2C%22width%22%3A%221200%22%2C%22height%22%3A%221146%22%2C%22lock%22%3Atrue%2C%22align%22%3A%22none%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="image"><span class="cke_reset cke_widget_drag_handler_container"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702142730987-1020751386.gif" class="cke_reset cke_widget_drag_handler" height="15" width="15" data-cke-widget-drag-handler="1"></span><span class="cke_widget_edit_container" title="编辑图片"><br></span></span></p>
<h2>系统实现</h2>
<h3>微信小程序部分</h3>
<p><span data-cke-copybin-start="1"><span class="cke_widget_wrapper cke_widget_inline cke_widget_image cke_image_nocaption cke_widget_selected" data-cke-display-name="图像" data-cke-filter="off" data-cke-widget-id="4" data-cke-widget-wrapper="1"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425755-598058146.png" alt="" class="cke_widget_element" height="536" width="256" src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425755-598058146.png" data-cke-widget-data="%7B%22hasCaption%22%3Afalse%2C%22src%22%3A%22https%3A%2F%2Fimg-blog.csdnimg.cn%2F0530abd8b0e847e3bf2fe611d1e5f00d.png%22%2C%22alt%22%3A%22%22%2C%22width%22%3A%22256%22%2C%22height%22%3A%22536%22%2C%22lock%22%3Atrue%2C%22align%22%3A%22none%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="image"><span class="cke_reset cke_widget_drag_handler_container"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702143011212-1809406684.gif" class="cke_reset cke_widget_drag_handler" height="15" width="15" data-cke-widget-drag-handler="1"></span><span class="cke_image_resizer" title="点击并拖拽以改变尺寸"></span><span class="cke_widget_edit_container" title="编辑图片"><br></span></span></span></p>
<p><span id="cke_bm_333S"> </span></p>
<p><span class="cke_widget_wrapper cke_widget_inline cke_widget_image cke_image_nocaption cke_widget_selected" data-cke-display-name="图像" data-cke-filter="off" data-cke-widget-id="3" data-cke-widget-wrapper="1"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425780-916893502.png" alt="" class="cke_widget_element" height="521" width="264" src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425780-916893502.png" data-cke-widget-data="%7B%22hasCaption%22%3Afalse%2C%22src%22%3A%22https%3A%2F%2Fimg-blog.csdnimg.cn%2F0658d7e4e9414298b53dad4354fd6d8d.png%22%2C%22alt%22%3A%22%22%2C%22width%22%3A%22264%22%2C%22height%22%3A%22521%22%2C%22lock%22%3Atrue%2C%22align%22%3A%22none%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="image"><span class="cke_reset cke_widget_drag_handler_container"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702143011212-1809406684.gif" class="cke_reset cke_widget_drag_handler" height="15" width="15" data-cke-widget-drag-handler="1"></span><span class="cke_image_resizer" title="点击并拖拽以改变尺寸"></span><span class="cke_widget_edit_container" title="编辑图片"><br></span></span></p>
<p>提交报修页面</p>
<p> <span class="cke_widget_wrapper cke_widget_inline cke_widget_image cke_image_nocaption cke_widget_selected" data-cke-display-name="图像" data-cke-filter="off" data-cke-widget-id="2" data-cke-widget-wrapper="1"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425875-1907471182.png" alt="" class="cke_widget_element" height="480" width="235" src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425875-1907471182.png" data-cke-widget-data="%7B%22hasCaption%22%3Afalse%2C%22src%22%3A%22https%3A%2F%2Fimg-blog.csdnimg.cn%2F3b0d6dc5b7a3443c919f25a9b86816a6.png%22%2C%22alt%22%3A%22%22%2C%22width%22%3A%22235%22%2C%22height%22%3A%22480%22%2C%22lock%22%3Atrue%2C%22align%22%3A%22none%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="image"><span class="cke_reset cke_widget_drag_handler_container"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702143011212-1809406684.gif" class="cke_reset cke_widget_drag_handler" height="15" width="15" data-cke-widget-drag-handler="1"></span><span class="cke_image_resizer" title="点击并拖拽以改变尺寸"></span><span class="cke_widget_edit_container" title="编辑图片"><br></span></span></p>
<p>我的报修部分</p>
<p> <span class="cke_widget_wrapper cke_widget_inline cke_widget_image cke_image_nocaption cke_widget_selected" data-cke-display-name="图像" data-cke-filter="off" data-cke-widget-id="1" data-cke-widget-wrapper="1"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425847-1357436263.png" alt="" class="cke_widget_element" height="466" width="235" src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425847-1357436263.png" data-cke-widget-data="%7B%22hasCaption%22%3Afalse%2C%22src%22%3A%22https%3A%2F%2Fimg-blog.csdnimg.cn%2F2c95e5848d894797a4402e95a01eeb46.png%22%2C%22alt%22%3A%22%22%2C%22width%22%3A%22235%22%2C%22height%22%3A%22466%22%2C%22lock%22%3Atrue%2C%22align%22%3A%22none%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="image"><span class="cke_reset cke_widget_drag_handler_container"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702143011212-1809406684.gif" class="cke_reset cke_widget_drag_handler" height="15" width="15" data-cke-widget-drag-handler="1"></span><span class="cke_widget_edit_container" title="编辑图片"><br></span></span></p>
<p>报修详情 </p>
<p> <span class="cke_widget_wrapper cke_widget_inline cke_widget_image cke_image_nocaption cke_widget_selected" data-cke-display-name="图像" data-cke-filter="off" data-cke-widget-id="0" data-cke-widget-wrapper="1"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425757-1137618977.png" alt="" class="cke_widget_element" height="473" width="236" src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702144425757-1137618977.png" data-cke-widget-data="%7B%22hasCaption%22%3Afalse%2C%22src%22%3A%22https%3A%2F%2Fimg-blog.csdnimg.cn%2Fc80ce8b5a3e04097ac36780da4d359a2.png%22%2C%22alt%22%3A%22%22%2C%22width%22%3A%22238%22%2C%22height%22%3A%22477%22%2C%22lock%22%3Atrue%2C%22align%22%3A%22none%22%2C%22classes%22%3Anull%7D" data-cke-widget-keep-attr="0" data-cke-widget-upcasted="1" data-widget="image"><span class="cke_reset cke_widget_drag_handler_container"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220702143011212-1809406684.gif" class="cke_reset cke_widget_drag_handler" height="15" width="15" data-cke-widget-drag-handler="1"></span><span class="cke_widget_edit_container" title="编辑图片"><br></span></span></p>
<p>学生端这块,暂时写了这么多。</p>
<p><span data-cke-copybin-end="1"></span></p>
<h3>后台部分</h3>
<blockquote>
<p>renren-fast是一个轻量级的Spring Boot2.1快速开发平台,其设计目标是开发迅速、学习简单、轻量级、易扩展;使用Spring Boot、Shiro、MyBatis、Redis、Bootstrap、Vue2.x等框架,包含:管理员列表、角色管理、菜单管理、定时任务、参数管理、代码生成器、日志管理、云存储、API模块(APP接口开发利器)、前后端分离等。</p>
<p>https://gitee.com/renrenio/renren-fast</p>
</blockquote>
<p> <img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220703132833089-830051044.png" alt="" height="357" width="777"></p>
<h4>文件上传实现</h4>
<p><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220703141146736-1763456241.png" height="506" width="249"><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220703214731891-1458171870.png" height="271" width="447"></p>
<p>小程序代码 小程序使用的vant-ui作为前端框架</p>
<p><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220703213733341-1006679829.png" height="391" width="849"></p>
<pre class="language-html highlighter-hljs"><code><van-uploader file-list="{{ fileList }}" bind:after-read="afterRead" /></code></pre>
<p><span data-cke-copybin-end="1">js</span></p>
<pre class="language-javascript highlighter-hljs"><code>afterRead(event){
const { file } = event.detail;
// 当设置 mutiple 为 true 时, file 为数组格式,否则为对象格式
// 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: '上传失败,请重试',
icon: 'warning',
duration: 2000
})
}
}).catch(e=>{
wx.showToast({
title: '上传失败,请重试',
icon: 'warning',
duration: 2000
})
})
},</code></pre>
<p>我封装了上传文件的方法</p>
<p><img src="https://img2022.cnblogs.com/blog/1508053/202207/1508053-20220703213928802-1568403031.png" height="581" width="987"> </p>
<pre class="language-javascript highlighter-hljs"><code>/**
* @description 上传文件
* @param {*} url 请求地址
* @param {*} data 参数
*/
function upLoad(url,file, data = {}) {
return new Promise((resolve, reject) => {
wx.uploadFile({
url: URL.BASE_URL +url, // 仅为示例,非真实的接口地址
filePath: file.url,
name: 'file',
header:{"content-type":"application/json;charset=utf-8"},
formData: data,
success(res) {
// 上传完成需要更新 fileList
resolve(JSON.parse(res.data));
},
fail(e){
reject(e);
}
});
})
}</code></pre>
<p>前端的代码就这么多了</p>
<p>后端上传这块核心的方法是一个上传方法和读取文件的方法(这块我是使用的返回文件流的方式返回给前端)你可以选择其他的方式也可以实现 业务层代码如下</p>
<pre class="language-java highlighter-hljs"><code>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;
/**
* 对文件的操作
*/
@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数组用于存放图片字节数据
byte[] buff = new byte;
inputStream.read(buff);
//记得关闭输入流
inputStream.close();
//设置发送到客户端的响应内容类型
response.setContentType("image/*");
OutputStream out = response.getOutputStream();
out.write(buff);
//关闭响应输出流
out.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}</code></pre>
<p> </p><br><br>
来源:https://www.cnblogs.com/huyande/p/16437542.html
頁:
[1]