一、前言
快速发展的社会中,人们的生活水平都在提高,生活节奏也在逐渐加快。为了节省时间和提高工作效率,越来越多的人选择利用互联网进行线上打理各种事务,然后线上管理系统也就相继涌现。与此同时,人们开始接受方便的生活方式。他们不仅希望页面简单大方,还希望操作方便,可以快速锁定他们需要的线上管理方式。基于这种情况,我们需要这样一个界面简单大方、功能齐全的系统来解决用户问题,满足用户需求。
课题主要分为三大模块:即管理员模块和用户、家教模块,主要功能包括:用户信息、家教信息、家教预约、家教需求、家教申请、支付押金、支付尾款、擅长科目、留言板等功能信息;
网络发展的越来越迅速,它深刻的影响着每一个人生活的各个方面。每一种新型事务的兴起都是为了使人们的生活更加方便。“众优”大学生家教平台是一种低成本、更加高效的电子商务方式,它已慢慢的成为一种全新的管理模式。人们不再满足于在互联网上浏览、发布信息和人与人之间的聊天,而是希望互联网能为人们的生活带来更多便利。伴随着网络的崛起,“众优”大学生家教开始变得越来越普遍[2]。
互联网发展的越来越快了,在当下社会节点,人们也开始越来越依赖互联网。通过互联网信息和数据,极大地满足用户要求[5]。“众优”大学生家教平台使用了B/S模式,并且不需要安装第三方插件,他们甚至能直接在电脑上随机随地实现“众优”大学生家教,还能实现更加准确的提供家教信息。现社会无论各行各业都应尽量摒弃传递错误信息,尤其是口头传输信息。而网络却并不会像电话那样一次只能传输一次,效率低下还间连不断,如果利用网络来处理信息也就会更加的容易。我们甚至可以通过网络技术节省时间和人力成本。于是传统的管理方式得到了更好的改进。从而提高了整体的工作效率[6]。
二、开发环境
开发语言:Java
框架:ssm
技术:JSP
JDK版本:JDK1.8
服务器:tomcat7
数据库:mysql 5.7(一定要5.7版本)
数据库工具:Navicat11
开发软件:eclipse/myeclipse/idea
Maven包:Maven3.3.9
浏览器:谷歌浏览器
三、系统功能效果
四、核心代码
package com.service;
import java.util.List;
import java.util.Map;
public interface CommonService {
List<String> getOption(Map<String, Object> params);
Map<String, Object> getFollowByOption(Map<String, Object> params);
void sh(Map<String, Object> params);
int remindCount(Map<String, Object> params);
Map<String, Object> selectCal(Map<String, Object> params);
List<Map<String, Object>> selectGroup(Map<String, Object> params);
List<Map<String, Object>> selectValue(Map<String, Object> params);
List<Map<String, Object>> selectTimeStatValue(Map<String, Object> params);
}
package com.controller;
import java.math.BigDecimal;
import java.text.SimpleDateFormat;
import java.text.ParseException;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Map;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Date;
import java.util.List;
import javax.servlet.http.HttpServletRequest;
import java.io.IOException;
import com.utils.ValidatorUtils;
import org.apache.commons.lang3.StringUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.transaction.annotation.Transactional;
import org.springframework.format.annotation.DateTimeFormat;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.baomidou.mybatisplus.mapper.Wrapper;
import com.annotation.IgnoreAuth;
import com.entity.JiajiaoshenqingEntity;
import com.entity.view.JiajiaoshenqingView;
import com.service.JiajiaoshenqingService;
import com.service.TokenService;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.MD5Util;
import com.utils.MPUtil;
import com.utils.CommonUtil;
/**
* 家教申请
* 后端接口
* @author
* @email
* @date 2023-03-28 10:46:34
*/
@RestController
@RequestMapping("/jiajiaoshenqing")
public class JiajiaoshenqingController {
@Autowired
private JiajiaoshenqingService jiajiaoshenqingService;
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,JiajiaoshenqingEntity jiajiaoshenqing,
HttpServletRequest request){
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("yonghu")) {
jiajiaoshenqing.setShoujihao((String)request.getSession().getAttribute("username"));
}
if(tableName.equals("jiajiao")) {
jiajiaoshenqing.setJiajiaozhanghao((String)request.getSession().getAttribute("username"));
}
EntityWrapper<JiajiaoshenqingEntity> ew = new EntityWrapper<JiajiaoshenqingEntity>();
PageUtils page = jiajiaoshenqingService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiajiaoshenqing), params), params));
request.setAttribute("data", page);
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@IgnoreAuth
@RequestMapping("/list")
public R list(@RequestParam Map<String, Object> params,JiajiaoshenqingEntity jiajiaoshenqing,
HttpServletRequest request){
EntityWrapper<JiajiaoshenqingEntity> ew = new EntityWrapper<JiajiaoshenqingEntity>();
PageUtils page = jiajiaoshenqingService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, jiajiaoshenqing), params), params));
request.setAttribute("data", page);
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( JiajiaoshenqingEntity jiajiaoshenqing){
EntityWrapper<JiajiaoshenqingEntity> ew = new EntityWrapper<JiajiaoshenqingEntity>();
ew.allEq(MPUtil.allEQMapPre( jiajiaoshenqing, "jiajiaoshenqing"));
return R.ok().put("data", jiajiaoshenqingService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(JiajiaoshenqingEntity jiajiaoshenqing){
EntityWrapper< JiajiaoshenqingEntity> ew = new EntityWrapper< JiajiaoshenqingEntity>();
ew.allEq(MPUtil.allEQMapPre( jiajiaoshenqing, "jiajiaoshenqing"));
JiajiaoshenqingView jiajiaoshenqingView = jiajiaoshenqingService.selectView(ew);
return R.ok("查询家教申请成功").put("data", jiajiaoshenqingView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
JiajiaoshenqingEntity jiajiaoshenqing = jiajiaoshenqingService.selectById(id);
return R.ok().put("data", jiajiaoshenqing);
}
/**
* 前端详情
*/
@IgnoreAuth
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
JiajiaoshenqingEntity jiajiaoshenqing = jiajiaoshenqingService.selectById(id);
return R.ok().put("data", jiajiaoshenqing);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody JiajiaoshenqingEntity jiajiaoshenqing, HttpServletRequest request){
jiajiaoshenqing.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(jiajiaoshenqing);
jiajiaoshenqingService.insert(jiajiaoshenqing);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody JiajiaoshenqingEntity jiajiaoshenqing, HttpServletRequest request){
jiajiaoshenqing.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(jiajiaoshenqing);
jiajiaoshenqingService.insert(jiajiaoshenqing);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
@Transactional
public R update(@RequestBody JiajiaoshenqingEntity jiajiaoshenqing, HttpServletRequest request){
//ValidatorUtils.validateEntity(jiajiaoshenqing);
jiajiaoshenqingService.updateById(jiajiaoshenqing);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
jiajiaoshenqingService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
/**
* 提醒接口
*/
@RequestMapping("/remind/{columnName}/{type}")
public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request,
@PathVariable("type") String type,@RequestParam Map<String, Object> map) {
map.put("column", columnName);
map.put("type", type);
if(type.equals("2")) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
Calendar c = Calendar.getInstance();
Date remindStartDate = null;
Date remindEndDate = null;
if(map.get("remindstart")!=null) {
Integer remindStart = Integer.parseInt(map.get("remindstart").toString());
c.setTime(new Date());
c.add(Calendar.DAY_OF_MONTH,remindStart);
remindStartDate = c.getTime();
map.put("remindstart", sdf.format(remindStartDate));
}
if(map.get("remindend")!=null) {
Integer remindEnd = Integer.parseInt(map.get("remindend").toString());
c.setTime(new Date());
c.add(Calendar.DAY_OF_MONTH,remindEnd);
remindEndDate = c.getTime();
map.put("remindend", sdf.format(remindEndDate));
}
}
Wrapper<JiajiaoshenqingEntity> wrapper = new EntityWrapper<JiajiaoshenqingEntity>();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
String tableName = request.getSession().getAttribute("tableName").toString();
if(tableName.equals("yonghu")) {
wrapper.eq("shoujihao", (String)request.getSession().getAttribute("username"));
}
if(tableName.equals("jiajiao")) {
wrapper.eq("jiajiaozhanghao", (String)request.getSession().getAttribute("username"));
}
int count = jiajiaoshenqingService.selectCount(wrapper);
return R.ok().put("count", count);
}
}