基于javaweb+mysql的springboot校园物资管理系统(java+springboot+javascript+layui+mysql)
运行环境
Java≥8、MySQL≥5.7
开发工具
eclipse/idea/myeclipse/sts等均可配置运行
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明
基于javaweb+mysql的SpringBoot校园物资管理系统(java+springboot+javascript+layui+mysql)
项目介绍
本项目有物资管理员与教师两种角色;
普通员工具有以下功能:申领物资;撤销申请;查看待领任务。 (1)申领物资:提交物资领取申请。 (2)撤销申请:对于物资管理员还未审核的申请,可以撤销;已审核的申请则不能撤销。 (3)查看待领任务:查看已通过审核的申请和物资管理员发起的领取任务。
物资管理员拥有以下功能:物资信息管理;物资入库;物资发放;查看物资库存;审批申请。 (1)物资信息管理:添加物资类别;添加、修改、删除物资信息;按名称或类别或编号查询物资信息。 (2)物资入库:增加物资的库存量;可以按入库时间来查看入库信息。 (3)物资发放:向指定人发放一定数量的物资,并在其领取后进行登记。 (4)查看物资库存:查看所有物资的库存量。 (5)审批申请:查看和审批物资领取申请,同意则员工可以领取物资,不同意则驳回该申请,不允许领取物资。
环境需要
1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA; 3.tomcat环境:Tomcat 7.x,8.x,9.x版本均可 4.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 5.数据库:MySql 8.0/5.7版本; 6.是否Maven项目:是;
技术栈
springboot+mysql+layui+CSS+JavaScript
使用说明
- 使用Navicat或者其它工具,在mysql中创建对应名称的数据库,并导入项目的sql文件; 2. 使用IDEA/Eclipse/MyEclipse导入项目,导入成功后请执行maven clean;maven install命令,然后运行; 3. 将项目中application.properties配置文件中的数据库配置改为自己的配置; 4. 运行项目,在浏览器中输入http://localhost:8080 访问
* 获取普通员工
* @return
*/
@RequestMapping(value = "/distribute/getUname.action")
@ResponseBody
public String getUname(){
Map<String, Object> map = new HashMap<>();
Integer utype = 0;
List<User> list = indexService.getUname(utype);
if (list != null) {
map.put("success", true);
map.put("data", list);
* 上传物资图片
* @param file
* @param request
* @return
*/
@ResponseBody
@RequestMapping(value = "/info/uploadImage")
public String uploadImage(MultipartFile file, HttpServletRequest request) {
HashMap<String, Object> map = new HashMap<>();
HashMap<String, Object> data = new HashMap<>();
try {
* 获取普通员工
* @return
*/
@RequestMapping(value = "/distribute/getUname.action")
@ResponseBody
public String getUname(){
Map<String, Object> map = new HashMap<>();
Integer utype = 0;
List<User> list = indexService.getUname(utype);
if (list != null) {
map.put("success", true);
map.put("data", list);
} else {
map.put("code", -1);
map.put("msg", "请选择图片!");
return JSON.toJSONString(map);
} catch (Exception e) {
e.printStackTrace();
map.put("code", -1);
map.put("msg", "上传失败,请稍后重试!");
return JSON.toJSONString(map);
/**
* 添加物资信息
* @param mi
* @return
/**
* 物资入库
* @param pi
* @return
*/
@ResponseBody
@RequestMapping(value = "/putin/add")
public String addPutinInfo(Putin pi,HttpServletRequest request) {
HashMap<String, Object> map = new HashMap<>();
// 获取经办人信息
String uname = (String)request.getSession().getAttribute("uname");
pi.setPagent(uname);
// 获取当前日期
} else {
map.put("success", false);
map.put("msg", "登记失败,库存不足或系统错误,请稍后重试!");
return JSON.toJSONString(map);
/**
* 获取普通员工
* @return
*/
@RequestMapping(value = "/distribute/getUname.action")
@ResponseBody
@RequestMapping(value = "/info/update")
public String updateMaterialInfo(Material mi) {
HashMap<String, Object> map = new HashMap<>();
boolean result = materialService.updateMaterialInfo(mi);
if (result) {
map.put("success", true);
map.put("msg", "更改成功!");
} else {
map.put("success", false);
map.put("msg", "更改失败!");
return JSON.toJSONString(map);
/**
// 获取经办人信息
String uname = (String)request.getSession().getAttribute("uname");
pi.setPagent(uname);
// 获取当前日期
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
pi.setPdate(sdf.format(date));
// 生成时间戳,保证主键的唯一性
String pno = String.valueOf(date.getTime());
pi.setPno(pno);
System.out.println(pi);
boolean result = putinService.addPutin(pi);
if (result) {
Date date = new Date();
String fileName = date.getTime() + "-" + originalFilename;
// 类路径
String classPath = "F:/IDEA/workspace/MMS/mms/target/classes/static";
// 父路径
String src = "/upload/";
File directory = new File(classPath, src);
if (!directory.exists()) {
directory.mkdir();
// 文件名
String imagePath = directory.getPath() + "\\" + fileName;
public String login(@RequestBody Map<String, String> request, HttpSession session) {
Map<String, Object> map = new HashMap<>();
String uid = request.get("uid");
String password = request.get("password");
System.out.println("uid:" + uid + "--pwd:" + password);
User user = indexService.findUser(uid, password);
if (user != null) {
session.setAttribute("uid", uid);
session.setAttribute("uname", user.getUname());
session.setAttribute("utype", user.getUtype());
map.put("msg","登录成功");
// 领用日期
Date date = new Date();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
rt.setRtaketime(sdf.format(date));
HashMap<String, Object> map = new HashMap<>();
boolean result = requisitionService.received(rt);
if (result) {
map.put("success", true);
map.put("msg", "登记成功!");
} else {
map.put("success", false);
map.put("msg", "登记失败,库存不足或系统错误,请稍后重试!");
} else {
map.put("success", false);
map.put("msg", "提交申请失败,请稍后再试!");
return JSON.toJSONString(map);
/**
* 撤销申请
* @param rid
* @return
*/
@ResponseBody
@RequestMapping(value = "/apply/revoke")
public String revoke(@RequestParam("rid") String rid) {
map.put("success", false);
Kind kind = new Kind("005", "其它");
map.put("data", kind);
System.out.println(map);
return JSON.toJSONString(map);
/**
* 上传物资图片
* @param file
* @param request
* @return
* @param session
* @return 返回到登录界面
*/
@RequestMapping(value = "/logout.action")
public String logout(HttpSession session) {
// 清空session中的属性
session.removeAttribute("uid");
session.removeAttribute("uname");
session.removeAttribute("utype");
//让session无效
*/
@RequestMapping(value = "/putin/list")
@ResponseBody
public DataGridViewResult findPutinList(PutinVo pv){
// 设置分页信息
PageHelper.startPage(pv.getPage(), pv.getLimit());
// 查询
List<Putin> list = putinService.findPutinList(pv);
// 创建分页对象
PageInfo<Putin> pageInfo = new PageInfo<Putin>(list);
// 按接口要求返回数据
@ResponseBody
@RequestMapping(value = "/info/list")
public DataGridViewResult materialInfoList(MaterialVo mv) {
// 设置分页信息
PageHelper.startPage(mv.getPage(), mv.getLimit());
// 查询
List<Material> list = materialService.findMaterialInfoListByPage(mv);
// 创建分页对象
PageInfo<Material> pageInfo = new PageInfo<Material>(list);
// 按接口要求返回数据
DataGridViewResult data = new DataGridViewResult(pageInfo.getTotal(), pageInfo.getList());
return data;
if (file != null) {
String originalFilename = file.getOriginalFilename();
Date date = new Date();
String fileName = date.getTime() + "-" + originalFilename;
// 类路径
String classPath = "F:/IDEA/workspace/MMS/mms/target/classes/static";
// 父路径
String src = "/upload/";
File directory = new File(classPath, src);
if (!directory.exists()) {
directory.mkdir();
boolean result = requisitionService.revoke(rid);
if (result) {
map.put("success", true);
map.put("msg", "撤销成功!");
} else {
map.put("success", false);
map.put("msg", "撤销失败,请稍后重试!");
return JSON.toJSONString(map);
@RequestMapping(value = "/todo.html")
public String todo(){
return "/staff/todo.html";
/**
* 待领取列表