文末获取源码
开发语言:Java
使用框架:spring boot
前端技术:JavaScript、Vue.js 、css3
开发工具:IDEA/MyEclipse/Eclipse、Visual Studio Code
数据库:MySQL 5.7/8.0
数据库管理工具:phpstudy/Navicat
JDK版本:Java jdk8
Maven:apache-maven 3.8.1-bin
目录
本系统前端框架采用了比较流行的渐进式JavaScript框架Vue.js。使用Vue-Router和Vuex实现动态路由和全局状态管理,Ajax实现前后端通信,Element UI组件库使页面快速成型。后端部分:采用springboot作为开发框架,同时集成MyBatis、Redis等相关技术。
校园防疫管理,主要的模块包括查看首页、用户管理(管理员、操作员、)更多管理(采购计划、物资信息、分类管理、入库管理、出库管理、供应商信息、公告信息、疫情数据)等功能。系统中管理员主要是为了安全有效地存储和管理各类信息,还可以对系统进行管理与更新维护等操作,并且对后台有相应的操作权限。
要想实现校园防疫管理的各项功能,需要后台数据库的大力支持。管理员验证注册信息,收集的用户信息,并由此分析得出的关联信息等大量的数据都由数据库管理系统管理。本文中数据库服务器端采用了Mysql作为后台数据库,使Web与数据库紧密联系起来。在设计过程中,充分保证了系统代码的良好可读性、实用性、易扩展性、通用性、便于后期维护、操作方便以及页面简洁等特点。
本系统的开发使获取校园防疫管理信息能够更加方便快捷,同时也使校园防疫管理管理信息变的更加系统化、有序化。系统界面较友好,易于操作。
本校园防疫管理采用Java技术,Mysql数据库开发,充分保证了系统稳定性、完整性。
校园防疫管理的设计与实现的设计思想如下:
操作简单方便、系统界面安全良好:简单明了的页面布局,方便查询校园防疫管理管理的相关信息。
2、即时可见:对校园防疫管理信息的处理将立马在对应地点可以查询到,从而实现“即时发布、即时见效”的系统功能。
3、功能的完善性:可以管理首页、用户管理(管理员、操作员、)更多管理(采购计划、物资信息、分类管理、入库管理、出库管理、供应商信息、公告信息、疫情数据)系统管理模块的修改和维护操作。
- @RequestMapping(value = {"/count_group", "/count"})
-
- public Map<String, Object> count(HttpServletRequest request) {
- Query count = service.count(service.readQuery(request), service.readConfig(request));
-
- return success(count.getResultList());
-
- }
- @PostMapping("/add")
-
- @Transactional
-
- public Map<String, Object> add(HttpServletRequest request) throws IOException {
- service.insert(service.readBody(request.getReader()));
-
- return success(1);
-
- }
-
- @Transactional
-
- public Map<String, Object> addMap(Map<String,Object> map){
- service.insert(map);
-
- return success(1);
-
- }
-
- public Map<String,Object> readBody(BufferedReader reader){
- BufferedReader br = null;
-
- StringBuilder sb = new StringBuilder("");
-
- try{
- br = reader;
-
- String str;
-
- while ((str = br.readLine()) != null){
- sb.append(str);
-
- }
-
- br.close();
-
- String json = sb.toString();
-
- return JSONObject.parseObject(json, Map.class);
-
- }catch (IOException e){
- e.printStackTrace();
-
- }finally{
- if (null != br){
- try{
- br.close();
-
- }catch (IOException e){
- e.printStackTrace();
-
- }
-
- }
-
- }
-
- return null;
-
- }
-
- public void insert(Map<String,Object> body){
- StringBuffer sql = new StringBuffer("INSERT INTO ");
-
- sql.append("`").append(table).append("`").append(" (");
-
- for (Map.Entry<String,Object> entry:body.entrySet()){
- sql.append("`"+humpToLine(entry.getKey())+"`").append(",");
-
- }
-
- sql.deleteCharAt(sql.length()-1);
-
- sql.append(") VALUES (");
-
- for (Map.Entry<String,Object> entry:body.entrySet()){
- Object value = entry.getValue();
-
- if (value instanceof String){
- sql.append("'").append(entry.getValue()).append("'").append(",");
-
- }else {
- sql.append(entry.getValue()).append(",");
-
- }
-
- }
-
- sql.deleteCharAt(sql.length() - 1);
-
- sql.append(")");
-
- log.info("[{}] - 插入操作:{}",table,sql);
-
- Query query = runCountSql(sql.toString());
-
- query.executeUpdate();
-
- }
- @PostMapping("/set")
-
- @Transactional
-
- public Map<String, Object> set(HttpServletRequest request) throws IOException {
-
- service.update(service.readQuery(request), service.readConfig(request), service.readBody(request.getReader()));
-
- return success(1);
-
- }
-
- public Map<String,String> readConfig(HttpServletRequest request){
-
- Map<String,String> map = new HashMap<>();
-
- map.put(FindConfig.PAGE,request.getParameter(FindConfig.PAGE));
-
- map.put(FindConfig.SIZE,request.getParameter(FindConfig.SIZE));
-
- map.put(FindConfig.LIKE,request.getParameter(FindConfig.LIKE));
-
- map.put(FindConfig.ORDER_BY,request.getParameter(FindConfig.ORDER_BY));
-
- map.put(FindConfig.FIELD,request.getParameter(FindConfig.FIELD));
-
- map.put(FindConfig.GROUP_BY,request.getParameter(FindConfig.GROUP_BY));
-
- map.put(FindConfig.MAX_,request.getParameter(FindConfig.MAX_));
-
- map.put(FindConfig.MIN_,request.getParameter(FindConfig.MIN_));
-
- return map;
-
- }
-
- public Map<String,String> readQuery(HttpServletRequest request){
-
- String queryString = request.getQueryString();
-
- if (queryString != null && !"".equals(queryString)) {
-
- String[] querys = queryString.split("&");
-
- Map<String, String> map = new HashMap<>();
-
- for (String query : querys) {
-
- String[] q = query.split("=");
-
- map.put(q[0], q[1]);
-
- }
-
- map.remove(FindConfig.PAGE);
-
- map.remove(FindConfig.SIZE);
-
- map.remove(FindConfig.LIKE);
-
- map.remove(FindConfig.ORDER_BY);
-
- map.remove(FindConfig.FIELD);
-
- map.remove(FindConfig.GROUP_BY);
-
- map.remove(FindConfig.MAX_);
-
- map.remove(FindConfig.MIN_);
-
- return map;
-
- }else {
-
- return new HashMap<>();
-
- }
-
- }
-
- @Transactional
-
- public void update(Map<String,String> query,Map<String,String> config,Map<String,Object> body){
-
- StringBuffer sql = new StringBuffer("UPDATE ").append("`").append(table).append("`").append(" SET ");
-
- for (Map.Entry<String,Object> entry:body.entrySet()){
-
- Object value = entry.getValue();
-
- if (value instanceof String){
-
- sql.append("`"+humpToLine(entry.getKey())+"`").append("=").append("'").append(value).append("'").append(",");
-
- }else {
-
- sql.append("`"+humpToLine(entry.getKey())+"`").append("=").append(value).append(",");
-
- }
-
- }
-
- sql.deleteCharAt(sql.length()-1);
-
- sql.append(toWhereSql(query,"0".equals(config.get(FindConfig.LIKE))));
-
- log.info("[{}] - 更新操作:{}",table,sql);
-
- Query query1 = runCountSql(sql.toString());
-
- query1.executeUpdate();
-
- }
-
- public String toWhereSql(Map<String,String> query, Boolean like) {
-
- if (query.size() > 0) {
-
- try {
-
- StringBuilder sql = new StringBuilder(" WHERE ");
-
- for (Map.Entry<String, String> entry : query.entrySet()) {
-
- if (entry.getKey().contains(FindConfig.MIN_)) {
-
- String min = humpToLine(entry.getKey()).replace("_min", "");
-
- sql.append("`"+min+"`").append(" >= '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("' and ");
-
- continue;
-
- }
-
- if (entry.getKey().contains(FindConfig.MAX_)) {
-
- String max = humpToLine(entry.getKey()).replace("_max", "");
-
- sql.append("`"+max+"`").append(" <= '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("' and ");
-
- continue;
-
- }
-
- if (like == true) {
-
- sql.append("`"+humpToLine(entry.getKey())+"`").append(" LIKE '%").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("%'").append(" and ");
-
- } else {
-
- sql.append("`"+humpToLine(entry.getKey())+"`").append(" = '").append(URLDecoder.decode(entry.getValue(), "UTF-8")).append("'").append(" and ");
-
- }
-
- }
-
- sql.delete(sql.length() - 4, sql.length());
-
- sql.append(" ");
-
- return sql.toString();
-
- } catch (UnsupportedEncodingException e) {
-
- log.info("拼接sql 失败:{}", e.getMessage());
-
- }
-
- }
-
- return "";
-
- }