当前位置:   article > 正文

失物招领平台|基于Springboot+Vue实现失物招领系统_基于spring boot和vue的寻人启事系统的设计与实现的相关技术和理论基础

基于spring boot和vue的寻人启事系统的设计与实现的相关技术和理论基础

作者主页:编程千纸鹤

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

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

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

文末获得源码

 项目编号:BS-XX-194

一,环境介绍

语言环境:Java:  jdk1.8

数据库:Mysql: mysql5.7

应用服务器:Tomcat:  tomcat8.5.31

开发工具:IDEA或eclipse

开发技术:Springboot+Vue

二,项目简介

目前高校对于信息化系统的应用和普及,己相当普遍,各种有助于教学的线上教学管理平台,有助于教务管理的教务管理系统等等都己被开发和应用起来,通过这些系统的应用和集成,有效的帮助高校实现数字化校园和智慧化校园的建设。本次课题主要实现一款校内的失物招领系统平台,帮助师生快速的找到自己丢失的物品,帮助丢失的物品快速的找到自己的主人,它有效的解决了传统线下黑板报式的失物招领方式,通过互联网的快速传播和信息浏览的方便性,提升了失物招领的效率。

在经过对目前相关失物招领业务流程进行调查研究后,本次毕业设计采用B/S架构设计开发了一款线上失物招领系统,技术上采用SpringBoot框架集成其它框架技术进行开发,数据库采用Mysql5.7进行数据管理,前端采用Vue框架结合ElementUI组件来实现页面布局和人机交互。实现了一款功能完整,界面友好的失物招领系统。

前端用户操作用例:

管理员操作用例

前端用户主要实现的功能具体描述如下。

(1)注册登陆:这是提供的最基本的功能模块,用户只有注册为失物招领系统的用户,才可以登陆进行定餐操作。

(2)公告浏览:可以在线查看系统平台发布的公告详情信息。

(3)在线交流:为师生提供一个在线交流的平台。

(4)失物招领:可以查看平台发布的招领信息,也可以在线发布自己捡拾的物品让失主认领。

(5)物品挂失:可在线查看别人挂失的物品,也可在线发布自己的寻物启示。

(6)宣传视频:可以在线查看平台发布的一些公益性的宣传视频。

(7)个人中心:可以管理个人的基本信息。

后台管理员功能介绍描述如下。

(1)管理员管理:对于线上订餐来讲,餐品是本系统的核心业务数据,系统平台提供的后台管理模块,可以实现对餐品的添加和管理操作功能。

(2)用户管理:对于在失物招领系统中注册的用户信息,后台管理员可以在线进行管理,对其进行删除或修改。

(3)公告管理:主要完成对失物招领系统中发布的公告信息进行管理。

(4)论坛管理:主要管理系统发布的交流贴子信息。

(5)失物招领管理:主要完成对于前端发布的失物招领信息的管理操作。

(6)物品挂失管理:主要完成对于系统展示的挂失物品的编辑和管理操作。

(7)宣传视频管理:完成对前端展示的宣传视频的管理操作。

(8)轮播图管理:完成对前端展示的广告轮播图片的替换。

三,系统展示

用户信息管理

失物招领管理

失物信息

统计信息

挂失管理

公告查看

失物查看

四,核心代码展示

  1. package com.controller;
  2. import java.io.File;
  3. import java.math.BigDecimal;
  4. import java.net.URL;
  5. import java.text.SimpleDateFormat;
  6. import com.alibaba.fastjson.JSONObject;
  7. import java.util.*;
  8. import org.springframework.beans.BeanUtils;
  9. import javax.servlet.http.HttpServletRequest;
  10. import org.springframework.web.context.ContextLoader;
  11. import javax.servlet.ServletContext;
  12. import com.service.TokenService;
  13. import com.utils.*;
  14. import java.lang.reflect.InvocationTargetException;
  15. import com.service.DictionaryService;
  16. import org.apache.commons.lang3.StringUtils;
  17. import com.annotation.IgnoreAuth;
  18. import org.slf4j.Logger;
  19. import org.slf4j.LoggerFactory;
  20. import org.springframework.beans.factory.annotation.Autowired;
  21. import org.springframework.stereotype.Controller;
  22. import org.springframework.web.bind.annotation.*;
  23. import com.baomidou.mybatisplus.mapper.EntityWrapper;
  24. import com.baomidou.mybatisplus.mapper.Wrapper;
  25. import com.entity.*;
  26. import com.entity.view.*;
  27. import com.service.*;
  28. import com.utils.PageUtils;
  29. import com.utils.R;
  30. import com.alibaba.fastjson.*;
  31. /**
  32. * 失物招领
  33. * 后端接口
  34. * @author
  35. * @email
  36. */
  37. @RestController
  38. @Controller
  39. @RequestMapping("/shiwuzhaoling")
  40. public class ShiwuzhaolingController {
  41. private static final Logger logger = LoggerFactory.getLogger(ShiwuzhaolingController.class);
  42. @Autowired
  43. private ShiwuzhaolingService shiwuzhaolingService;
  44. @Autowired
  45. private TokenService tokenService;
  46. @Autowired
  47. private DictionaryService dictionaryService;
  48. //级联表service
  49. @Autowired
  50. private YonghuService yonghuService;
  51. /**
  52. * 后端列表
  53. */
  54. @RequestMapping("/page")
  55. public R page(@RequestParam Map<String, Object> params, HttpServletRequest request){
  56. logger.debug("page方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));
  57. String role = String.valueOf(request.getSession().getAttribute("role"));
  58. if(StringUtil.isEmpty(role))
  59. return R.error(511,"权限为空");
  60. else if("用户".equals(role))
  61. params.put("yonghuId",request.getSession().getAttribute("userId"));
  62. if(params.get("orderBy")==null || params.get("orderBy")==""){
  63. params.put("orderBy","id");
  64. }
  65. PageUtils page = shiwuzhaolingService.queryPage(params);
  66. //字典表数据转换
  67. List<ShiwuzhaolingView> list =(List<ShiwuzhaolingView>)page.getList();
  68. for(ShiwuzhaolingView c:list){
  69. //修改对应字典表字段
  70. dictionaryService.dictionaryConvert(c, request);
  71. }
  72. return R.ok().put("data", page);
  73. }
  74. /**
  75. * 后端详情
  76. */
  77. @RequestMapping("/info/{id}")
  78. public R info(@PathVariable("id") Long id, HttpServletRequest request){
  79. logger.debug("info方法:,,Controller:{},,id:{}",this.getClass().getName(),id);
  80. ShiwuzhaolingEntity shiwuzhaoling = shiwuzhaolingService.selectById(id);
  81. if(shiwuzhaoling !=null){
  82. //entity转view
  83. ShiwuzhaolingView view = new ShiwuzhaolingView();
  84. BeanUtils.copyProperties( shiwuzhaoling , view );//把实体数据重构到view中
  85. //级联表
  86. YonghuEntity yonghu = yonghuService.selectById(shiwuzhaoling.getYonghuId());
  87. if(yonghu != null){
  88. BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段
  89. view.setYonghuId(yonghu.getId());
  90. }
  91. //修改对应字典表字段
  92. dictionaryService.dictionaryConvert(view, request);
  93. return R.ok().put("data", view);
  94. }else {
  95. return R.error(511,"查不到数据");
  96. }
  97. }
  98. /**
  99. * 后端保存
  100. */
  101. @RequestMapping("/save")
  102. public R save(@RequestBody ShiwuzhaolingEntity shiwuzhaoling, HttpServletRequest request){
  103. logger.debug("save方法:,,Controller:{},,shiwuzhaoling:{}",this.getClass().getName(),shiwuzhaoling.toString());
  104. String role = String.valueOf(request.getSession().getAttribute("role"));
  105. if(StringUtil.isEmpty(role))
  106. return R.error(511,"权限为空");
  107. else if("用户".equals(role))
  108. shiwuzhaoling.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));
  109. Wrapper<ShiwuzhaolingEntity> queryWrapper = new EntityWrapper<ShiwuzhaolingEntity>()
  110. .eq("shiwuzhaoling_uuid_number", shiwuzhaoling.getShiwuzhaolingUuidNumber())
  111. .eq("shiwuzhaoling_name", shiwuzhaoling.getShiwuzhaolingName())
  112. .eq("shiwuzhaoling_types", shiwuzhaoling.getShiwuzhaolingTypes())
  113. .eq("status_types", shiwuzhaoling.getStatusTypes())
  114. .eq("yonghu_id", shiwuzhaoling.getYonghuId())
  115. .eq("shiwuzhaoling_dizhi", shiwuzhaoling.getShiwuzhaolingDizhi())
  116. ;
  117. logger.info("sql语句:"+queryWrapper.getSqlSegment());
  118. ShiwuzhaolingEntity shiwuzhaolingEntity = shiwuzhaolingService.selectOne(queryWrapper);
  119. if(shiwuzhaolingEntity==null){
  120. shiwuzhaoling.setCreateTime(new Date());
  121. shiwuzhaolingService.insert(shiwuzhaoling);
  122. return R.ok();
  123. }else {
  124. return R.error(511,"表中有相同数据");
  125. }
  126. }
  127. /**
  128. * 后端修改
  129. */
  130. @RequestMapping("/update")
  131. public R update(@RequestBody ShiwuzhaolingEntity shiwuzhaoling, HttpServletRequest request){
  132. logger.debug("update方法:,,Controller:{},,shiwuzhaoling:{}",this.getClass().getName(),shiwuzhaoling.toString());
  133. String role = String.valueOf(request.getSession().getAttribute("role"));
  134. // if(StringUtil.isEmpty(role))
  135. // return R.error(511,"权限为空");
  136. // else if("用户".equals(role))
  137. // shiwuzhaoling.setYonghuId(Integer.valueOf(String.valueOf(request.getSession().getAttribute("userId"))));
  138. //根据字段查询是否有相同数据
  139. Wrapper<ShiwuzhaolingEntity> queryWrapper = new EntityWrapper<ShiwuzhaolingEntity>()
  140. .notIn("id",shiwuzhaoling.getId())
  141. .andNew()
  142. .eq("shiwuzhaoling_uuid_number", shiwuzhaoling.getShiwuzhaolingUuidNumber())
  143. .eq("shiwuzhaoling_name", shiwuzhaoling.getShiwuzhaolingName())
  144. .eq("shiwuzhaoling_types", shiwuzhaoling.getShiwuzhaolingTypes())
  145. .eq("status_types", shiwuzhaoling.getStatusTypes())
  146. .eq("yonghu_id", shiwuzhaoling.getYonghuId())
  147. .eq("shiwuzhaoling_dizhi", shiwuzhaoling.getShiwuzhaolingDizhi())
  148. ;
  149. logger.info("sql语句:"+queryWrapper.getSqlSegment());
  150. ShiwuzhaolingEntity shiwuzhaolingEntity = shiwuzhaolingService.selectOne(queryWrapper);
  151. if("".equals(shiwuzhaoling.getShiwuzhaolingPhoto()) || "null".equals(shiwuzhaoling.getShiwuzhaolingPhoto())){
  152. shiwuzhaoling.setShiwuzhaolingPhoto(null);
  153. }
  154. if(shiwuzhaolingEntity==null){
  155. // String role = String.valueOf(request.getSession().getAttribute("role"));
  156. // if("".equals(role)){
  157. // shiwuzhaoling.set
  158. // }
  159. shiwuzhaolingService.updateById(shiwuzhaoling);//根据id更新
  160. return R.ok();
  161. }else {
  162. return R.error(511,"表中有相同数据");
  163. }
  164. }
  165. /**
  166. * 删除
  167. */
  168. @RequestMapping("/delete")
  169. public R delete(@RequestBody Integer[] ids){
  170. logger.debug("delete:,,Controller:{},,ids:{}",this.getClass().getName(),ids.toString());
  171. shiwuzhaolingService.deleteBatchIds(Arrays.asList(ids));
  172. return R.ok();
  173. }
  174. /**
  175. * 批量上传
  176. */
  177. @RequestMapping("/batchInsert")
  178. public R save( String fileName){
  179. logger.debug("batchInsert方法:,,Controller:{},,fileName:{}",this.getClass().getName(),fileName);
  180. try {
  181. List<ShiwuzhaolingEntity> shiwuzhaolingList = new ArrayList<>();//上传的东西
  182. Map<String, List<String>> seachFields= new HashMap<>();//要查询的字段
  183. Date date = new Date();
  184. int lastIndexOf = fileName.lastIndexOf(".");
  185. if(lastIndexOf == -1){
  186. return R.error(511,"该文件没有后缀");
  187. }else{
  188. String suffix = fileName.substring(lastIndexOf);
  189. if(!".xls".equals(suffix)){
  190. return R.error(511,"只支持后缀为xls的excel文件");
  191. }else{
  192. URL resource = this.getClass().getClassLoader().getResource("static/upload/" + fileName);//获取文件路径
  193. File file = new File(resource.getFile());
  194. if(!file.exists()){
  195. return R.error(511,"找不到上传文件,请联系管理员");
  196. }else{
  197. List<List<String>> dataList = PoiUtil.poiImport(file.getPath());//读取xls文件
  198. dataList.remove(0);//删除第一行,因为第一行是提示
  199. for(List<String> data:dataList){
  200. //循环
  201. ShiwuzhaolingEntity shiwuzhaolingEntity = new ShiwuzhaolingEntity();
  202. // shiwuzhaolingEntity.setShiwuzhaolingUuidNumber(data.get(0)); //失物编号 要改的
  203. // shiwuzhaolingEntity.setShiwuzhaolingName(data.get(0)); //物品名称 要改的
  204. // shiwuzhaolingEntity.setShiwuzhaolingTypes(Integer.valueOf(data.get(0))); //物品类型 要改的
  205. // shiwuzhaolingEntity.setStatusTypes(Integer.valueOf(data.get(0))); //物品状态 要改的
  206. // shiwuzhaolingEntity.setYonghuId(Integer.valueOf(data.get(0))); //用户 要改的
  207. // shiwuzhaolingEntity.setShiwuzhaolingPhoto("");//照片
  208. // shiwuzhaolingEntity.setShiwuzhaolingTime(new Date(data.get(0))); //拾遗时间 要改的
  209. // shiwuzhaolingEntity.setShiwuzhaolingDizhi(data.get(0)); //拾遗地址 要改的
  210. // shiwuzhaolingEntity.setShiwuzhaolingContent("");//照片
  211. // shiwuzhaolingEntity.setCreateTime(date);//时间
  212. shiwuzhaolingList.add(shiwuzhaolingEntity);
  213. //把要查询是否重复的字段放入map中
  214. //失物编号
  215. if(seachFields.containsKey("shiwuzhaolingUuidNumber")){
  216. List<String> shiwuzhaolingUuidNumber = seachFields.get("shiwuzhaolingUuidNumber");
  217. shiwuzhaolingUuidNumber.add(data.get(0));//要改的
  218. }else{
  219. List<String> shiwuzhaolingUuidNumber = new ArrayList<>();
  220. shiwuzhaolingUuidNumber.add(data.get(0));//要改的
  221. seachFields.put("shiwuzhaolingUuidNumber",shiwuzhaolingUuidNumber);
  222. }
  223. }
  224. //查询是否重复
  225. //失物编号
  226. List<ShiwuzhaolingEntity> shiwuzhaolingEntities_shiwuzhaolingUuidNumber = shiwuzhaolingService.selectList(new EntityWrapper<ShiwuzhaolingEntity>().in("shiwuzhaoling_uuid_number", seachFields.get("shiwuzhaolingUuidNumber")));
  227. if(shiwuzhaolingEntities_shiwuzhaolingUuidNumber.size() >0 ){
  228. ArrayList<String> repeatFields = new ArrayList<>();
  229. for(ShiwuzhaolingEntity s:shiwuzhaolingEntities_shiwuzhaolingUuidNumber){
  230. repeatFields.add(s.getShiwuzhaolingUuidNumber());
  231. }
  232. return R.error(511,"数据库的该表中的 [失物编号] 字段已经存在 存在数据为:"+repeatFields.toString());
  233. }
  234. shiwuzhaolingService.insertBatch(shiwuzhaolingList);
  235. return R.ok();
  236. }
  237. }
  238. }
  239. }catch (Exception e){
  240. return R.error(511,"批量插入数据异常,请联系管理员");
  241. }
  242. }
  243. /**
  244. * 前端列表
  245. */
  246. @IgnoreAuth
  247. @RequestMapping("/list")
  248. public R list(@RequestParam Map<String, Object> params, HttpServletRequest request){
  249. logger.debug("list方法:,,Controller:{},,params:{}",this.getClass().getName(),JSONObject.toJSONString(params));
  250. // 没有指定排序字段就默认id倒序
  251. if(StringUtil.isEmpty(String.valueOf(params.get("orderBy")))){
  252. params.put("orderBy","id");
  253. }
  254. PageUtils page = shiwuzhaolingService.queryPage(params);
  255. //字典表数据转换
  256. List<ShiwuzhaolingView> list =(List<ShiwuzhaolingView>)page.getList();
  257. for(ShiwuzhaolingView c:list)
  258. dictionaryService.dictionaryConvert(c, request); //修改对应字典表字段
  259. return R.ok().put("data", page);
  260. }
  261. /**
  262. * 前端详情
  263. */
  264. @RequestMapping("/detail/{id}")
  265. public R detail(@PathVariable("id") Long id, HttpServletRequest request){
  266. logger.debug("detail方法:,,Controller:{},,id:{}",this.getClass().getName(),id);
  267. ShiwuzhaolingEntity shiwuzhaoling = shiwuzhaolingService.selectById(id);
  268. if(shiwuzhaoling !=null){
  269. //entity转view
  270. ShiwuzhaolingView view = new ShiwuzhaolingView();
  271. BeanUtils.copyProperties( shiwuzhaoling , view );//把实体数据重构到view中
  272. //级联表
  273. YonghuEntity yonghu = yonghuService.selectById(shiwuzhaoling.getYonghuId());
  274. if(yonghu != null){
  275. BeanUtils.copyProperties( yonghu , view ,new String[]{ "id", "createDate"});//把级联的数据添加到view中,并排除id和创建时间字段
  276. view.setYonghuId(yonghu.getId());
  277. }
  278. //修改对应字典表字段
  279. dictionaryService.dictionaryConvert(view, request);
  280. return R.ok().put("data", view);
  281. }else {
  282. return R.error(511,"查不到数据");
  283. }
  284. }
  285. /**
  286. * 前端保存
  287. */
  288. @RequestMapping("/add")
  289. public R add(@RequestBody ShiwuzhaolingEntity shiwuzhaoling, HttpServletRequest request){
  290. logger.debug("add方法:,,Controller:{},,shiwuzhaoling:{}",this.getClass().getName(),shiwuzhaoling.toString());
  291. Wrapper<ShiwuzhaolingEntity> queryWrapper = new EntityWrapper<ShiwuzhaolingEntity>()
  292. .eq("shiwuzhaoling_uuid_number", shiwuzhaoling.getShiwuzhaolingUuidNumber())
  293. .eq("shiwuzhaoling_name", shiwuzhaoling.getShiwuzhaolingName())
  294. .eq("shiwuzhaoling_types", shiwuzhaoling.getShiwuzhaolingTypes())
  295. .eq("status_types", shiwuzhaoling.getStatusTypes())
  296. .eq("yonghu_id", shiwuzhaoling.getYonghuId())
  297. .eq("shiwuzhaoling_dizhi", shiwuzhaoling.getShiwuzhaolingDizhi())
  298. ;
  299. logger.info("sql语句:"+queryWrapper.getSqlSegment());
  300. ShiwuzhaolingEntity shiwuzhaolingEntity = shiwuzhaolingService.selectOne(queryWrapper);
  301. if(shiwuzhaolingEntity==null){
  302. shiwuzhaoling.setCreateTime(new Date());
  303. // String role = String.valueOf(request.getSession().getAttribute("role"));
  304. // if("".equals(role)){
  305. // shiwuzhaoling.set
  306. // }
  307. shiwuzhaolingService.insert(shiwuzhaoling);
  308. return R.ok();
  309. }else {
  310. return R.error(511,"表中有相同数据");
  311. }
  312. }
  313. }

五,相关作品展示

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

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

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

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

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

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

 

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/凡人多烦事01/article/detail/458266
推荐阅读
相关标签
  

闽ICP备14008679号