|
|
|
@ -0,0 +1,219 @@
|
|
|
|
|
package com.controller;
|
|
|
|
|
import java.math.BigDecimal; // 导入BigDecimal类,用于高精度的数学计算
|
|
|
|
|
import java.text.SimpleDateFormat; // 导入SimpleDateFormat类,用于日期格式化
|
|
|
|
|
import java.text.ParseException; // 导入ParseException类,用于处理日期解析异常
|
|
|
|
|
import java.util.ArrayList; // 导入ArrayList类,用于创建动态数组
|
|
|
|
|
import java.util.Arrays; // 导入Arrays类,提供对数组操作的工具方法
|
|
|
|
|
import java.util.Calendar; // 导入Calendar类,用于日期时间操作
|
|
|
|
|
import java.util.Map; // 导入Map接口,用于键值对集合
|
|
|
|
|
import java.util.HashMap; // 导入HashMap类,基于哈希表的Map实现
|
|
|
|
|
import java.util.Iterator; // 导入Iterator接口,用于遍历集合
|
|
|
|
|
import java.util.Date; // 导入Date类,用于日期时间表示
|
|
|
|
|
import java.util.List; // 导入List接口,用于列表集合
|
|
|
|
|
import javax.servlet.http.HttpServletRequest; // 导入HttpServletRequest接口,用于访问HTTP请求信息
|
|
|
|
|
import java.io.IOException; // 导入IOException类,用于处理输入输出异常
|
|
|
|
|
|
|
|
|
|
import com.utils.ValidatorUtils; // 导入ValidatorUtils工具类,用于实体验证
|
|
|
|
|
import org.apache.commons.lang3.StringUtils; // 导入StringUtils类,提供字符串操作的工具方法
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired; // 导入Autowired注解,用于自动注入依赖
|
|
|
|
|
import org.springframework.transaction.annotation.Transactional; // 导入Transactional注解,用于声明事务管理
|
|
|
|
|
import org.springframework.format.annotation.DateTimeFormat; // 导入DateTimeFormat注解,用于日期时间格式化
|
|
|
|
|
import org.springframework.web.bind.annotation.PathVariable; // 导入PathVariable注解,用于将URL中的参数绑定到控制器方法的参数上
|
|
|
|
|
import org.springframework.web.bind.annotation.RequestBody; // 导入RequestBody注解,用于将HTTP请求体绑定到控制器方法的参数上
|
|
|
|
|
import org.springframework.web.bind.annotation.RequestMapping; // 导入RequestMapping注解,用于映射HTTP请求到控制器方法
|
|
|
|
|
import org.springframework.web.bind.annotation.RequestParam; // 导入RequestParam注解,用于将请求参数绑定到控制器方法的参数上
|
|
|
|
|
import org.springframework.web.bind.annotation.RestController; // 导入RestController注解,用于声明一个REST风格的控制器
|
|
|
|
|
|
|
|
|
|
import com.baomidou.mybatisplus.mapper.EntityWrapper; // 导入EntityWrapper类,用于构建查询条件
|
|
|
|
|
import com.baomidou.mybatisplus.mapper.Wrapper; // 导入Wrapper接口,用于封装查询条件
|
|
|
|
|
|
|
|
|
|
import com.annotation.IgnoreAuth; // 导入IgnoreAuth注解,用于标记不需要认证的接口
|
|
|
|
|
|
|
|
|
|
import com.entity.StoreupEntity; // 导入StoreupEntity实体类,代表存储数据
|
|
|
|
|
import com.entity.view.StoreupView; // 导入StoreupView视图类,用于展示存储数据
|
|
|
|
|
|
|
|
|
|
import com.service.StoreupService; // 导入StoreupService接口,用于存储业务操作
|
|
|
|
|
import com.service.TokenService; // 导入TokenService接口,用于令牌操作(未使用)
|
|
|
|
|
import com.utils.PageUtils; // 导入PageUtils工具类,用于分页处理
|
|
|
|
|
import com.utils.R; // 导入R工具类,用于构建统一的响应格式
|
|
|
|
|
import com.utils.MD5Util; // 导入MD5Util工具类,用于MD5加密(未使用)
|
|
|
|
|
import com.utils.MPUtil; // 导入MPUtil工具类,提供MyBatis Plus操作的工具方法
|
|
|
|
|
import com.utils.CommonUtil; // 导入CommonUtil工具类,提供通用的工具方法
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 收藏表
|
|
|
|
|
* 后端接口
|
|
|
|
|
* @author
|
|
|
|
|
* @email
|
|
|
|
|
* @date 2023-02-21 09:46:06
|
|
|
|
|
*/
|
|
|
|
|
@RestController
|
|
|
|
|
@RequestMapping("/storeup")
|
|
|
|
|
public class StoreupController {
|
|
|
|
|
@Autowired
|
|
|
|
|
private StoreupService storeupService;
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 后端列表
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/page")//定义了一个处理HTTP请求的映射,当请求路径为/page时,会调用这个方法
|
|
|
|
|
public R page(@RequestParam Map<String, Object> params,StoreupEntity storeup,HttpServletRequest request)
|
|
|
|
|
{//定义了一个公共方法,接收请求参数、实体对象和HTTP请求对象
|
|
|
|
|
if(!request.getSession().getAttribute("role").toString().equals("管理员"))
|
|
|
|
|
{//检查当前用户的角色是否为管理员,如果不是管理员,则设置用户ID
|
|
|
|
|
storeup.setUserid((Long)request.getSession().getAttribute("userId"));//设置用户ID
|
|
|
|
|
}
|
|
|
|
|
EntityWrapper<StoreupEntity> ew = new EntityWrapper<StoreupEntity>();//创建一个实体包装器对象,用于构建查询条件
|
|
|
|
|
PageUtils page = storeupService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, storeup), params), params));//调用storeupService的queryPage方法,根据查询条件和分页参数进行分页查询,并返回分页结果
|
|
|
|
|
request.setAttribute("data", page);//将分页结果设置到HTTP请求对象中
|
|
|
|
|
return R.ok().put("data", page);//返回一个包含分页结果的响应对象
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 前端列表
|
|
|
|
|
*/
|
|
|
|
|
@IgnoreAuth//定义了一个注解,用于标记不需要权限认证的接口
|
|
|
|
|
@RequestMapping("/list")//定义了一个处理HTTP请求的映射,当请求路径为/list时,会调用这个方法
|
|
|
|
|
public R list(@RequestParam Map<String, Object> params,StoreupEntity storeup,HttpServletRequest request)
|
|
|
|
|
{
|
|
|
|
|
EntityWrapper<StoreupEntity> ew = new EntityWrapper<StoreupEntity>();//创建一个实体包装器对象,用于构建查询条件
|
|
|
|
|
PageUtils page = storeupService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, storeup), params), params));//调用storeupService的queryPage方法,根据查询条件和分页参数进行分页查询,并返回分页结果
|
|
|
|
|
request.setAttribute("data", page);//将分页查询结果设置到HTTP请求对象中
|
|
|
|
|
return R.ok().put("data", page);//返回一个包含分页查询结果的响应对象
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 列表
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/lists")
|
|
|
|
|
public R list( StoreupEntity storeup)//定义了一个公共方法,接收实体对象
|
|
|
|
|
{
|
|
|
|
|
EntityWrapper<StoreupEntity> ew = new EntityWrapper<StoreupEntity>();//创建一个实体包装器对象,用于构建查询条件
|
|
|
|
|
ew.allEq(MPUtil.allEQMapPre( storeup, "storeup")); //使用allEq方法设置查询条件,MPUtil.allEQMapPre方法将实体对象的属性转换为Map,并添加前缀"storeup",allEq方法将Map中的键值对作为查询条件,查询出符合条件的实体对象
|
|
|
|
|
return R.ok().put("data", storeupService.selectListView(ew));//根据查询条件查询出符合条件的实体对象列表,并返回一个包含实体对象列表的响应对象
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 查询
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/query")//定义了一个处理HTTP请求的映射,当请求路径为/query时,会调用这个方法。
|
|
|
|
|
public R query(StoreupEntity storeup)
|
|
|
|
|
{
|
|
|
|
|
EntityWrapper< StoreupEntity> ew = new EntityWrapper< StoreupEntity>();
|
|
|
|
|
//创建一个实体包装器,用于构建查询条件
|
|
|
|
|
ew.allEq(MPUtil.allEQMapPre( storeup, "storeup"));
|
|
|
|
|
//使用allEq方法设置查询条件,MPUtil.allEQMapPre方法将实体对象的属性转换为Map,并添加前缀"storeup",allEq方法将Map中的键值对作为查询条件,查询出符合条件的实体对象。
|
|
|
|
|
StoreupView storeupView = storeupService.selectView(ew);
|
|
|
|
|
//调用服务层的方法查询单个数据,并返回视图对象
|
|
|
|
|
return R.ok("查询收藏表成功").put("data", storeupView);
|
|
|
|
|
//返回一个包含查询结果的响应对象,并附带成功消息
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 后端详情
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/info/{id}")// 定义一个请求映射,当访问 /info/{id} 路径时,会调用这个方法
|
|
|
|
|
public R info(@PathVariable("id") Long id)// 定义一个方法,接收一个路径变量 id,类型为 Long
|
|
|
|
|
{
|
|
|
|
|
StoreupEntity storeup = storeupService.selectById(id);//调用服务层的方法根据ID查询数据,并返回实体对象
|
|
|
|
|
return R.ok().put("data", storeup);//返回一个包含查询结果的 R 对象,其中包含键 "data" 和对应的 storeup 实体对象
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 前端详情
|
|
|
|
|
*/
|
|
|
|
|
@IgnoreAuth//定义了一个注解,用于标记不需要权限认证的接口
|
|
|
|
|
@RequestMapping("/detail/{id}")//定义了一个处理HTTP请求的映射,当请求路径为/detail/{id}时,会调用这个方法
|
|
|
|
|
public R detail(@PathVariable("id") Long id)//定义了一个方法,接收一个路径变量 id,类型为 Long
|
|
|
|
|
{
|
|
|
|
|
StoreupEntity storeup = storeupService.selectById(id);//调用服务层的方法根据ID查询数据,并返回实体对象
|
|
|
|
|
return R.ok().put("data", storeup);//返回一个包含查询结果的响应对象,并附带成功消息
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 后端保存
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/save")//定义了一个处理HTTP请求的映射,当请求路径为/save时,会调用这个方法
|
|
|
|
|
public R save(@RequestBody StoreupEntity storeup, HttpServletRequest request)//定义了一个方法,接收一个JSON格式的请求体,类型为 StoreupEntity,并接收一个 HttpServletRequest 对象
|
|
|
|
|
{
|
|
|
|
|
storeup.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
|
|
|
|
|
//ValidatorUtils.validateEntity(storeup);
|
|
|
|
|
storeup.setUserid((Long)request.getSession().getAttribute("userId"));//从请求的 session 中获取用户ID,并设置到 storeup 实体对象中
|
|
|
|
|
storeupService.insert(storeup);//调用服务层的方法将 storeup 实体对象插入数据库
|
|
|
|
|
return R.ok();//返回一个包含成功信息的 R 对象
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 前端保存
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/add")//定义了一个处理HTTP请求的映射,当请求路径为/add时,会调用这个方法
|
|
|
|
|
public R add(@RequestBody StoreupEntity storeup, HttpServletRequest request) //定义一个方法,接收一个请求体中的 StoreupEntity 对象和 HttpServletRequest 对象
|
|
|
|
|
{
|
|
|
|
|
storeup.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());//生成一个新的唯一ID,由当前时间戳加上一个随机数
|
|
|
|
|
//ValidatorUtils.validateEntity(storeup);
|
|
|
|
|
storeupService.insert(storeup);//调用服务层的方法将 storeup 实体对象插入数据库
|
|
|
|
|
return R.ok();
|
|
|
|
|
}
|
|
|
|
|
/**
|
|
|
|
|
* 修改
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/update")
|
|
|
|
|
@Transactional//定义了一个事务注解,表示该方法中的数据库操作应该在一个事务中执行
|
|
|
|
|
public R update(@RequestBody StoreupEntity storeup, HttpServletRequest request)//定义了一个方法,接收一个请求体中的 StoreupEntity 对象和 HttpServletRequest 对象
|
|
|
|
|
{
|
|
|
|
|
//ValidatorUtils.validateEntity(storeup);
|
|
|
|
|
storeupService.updateById(storeup);//调用服务层的方法根据 ID 更新 storeup 实体对象的所有字段
|
|
|
|
|
return R.ok();//返回一个包含成功信息的 R 对象
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 删除
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/delete")
|
|
|
|
|
public R delete(@RequestBody Long[] ids)// 定义一个方法,接收一个请求体中的 Long 数组,类型为 Long[]
|
|
|
|
|
{
|
|
|
|
|
storeupService.deleteBatchIds(Arrays.asList(ids));//调用服务层的方法,根据传入的 ID 数组批量删除数据
|
|
|
|
|
return R.ok();//返回一个包含成功信息的 R 对象 R.ok()函数是R工具类中的一个静态方法,用于创建一个包含成功信息的响应对象
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 提醒接口
|
|
|
|
|
*/
|
|
|
|
|
@RequestMapping("/remind/{columnName}/{type}") // 定义一个请求映射,当访问 /remind/{columnName}/{type} 路径时,会调用这个方法
|
|
|
|
|
public R remindCount(@PathVariable("columnName") String columnName, HttpServletRequest request,
|
|
|
|
|
@PathVariable("type") String type,@RequestParam Map<String, Object> map) { // 定义一个方法,接收一个路径变量 columnName 和 type,类型为 String,以及一个请求参数 map,类型为 Map<String, Object>
|
|
|
|
|
map.put("column", columnName); // 将 columnName 添加到 map 中,键为 "column"
|
|
|
|
|
map.put("type", type); // 将 type 添加到 map 中,键为 "type"
|
|
|
|
|
|
|
|
|
|
if(type.equals("2")) { // 如果 type 等于 "2"
|
|
|
|
|
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); // 创建一个日期格式化对象,格式为 "yyyy-MM-dd"
|
|
|
|
|
Calendar c = Calendar.getInstance(); // 创建一个日历对象,获取当前时间
|
|
|
|
|
Date remindStartDate = null; // 创建一个日期对象,用于存储提醒开始时间
|
|
|
|
|
Date remindEndDate = null; // 创建一个日期对象,用于存储提醒结束时间
|
|
|
|
|
if(map.get("remindstart")!=null) { // 如果 map 中存在 "remindstart" 键
|
|
|
|
|
Integer remindStart = Integer.parseInt(map.get("remindstart").toString()); // 将 "remindstart" 键对应的值转换为整数
|
|
|
|
|
c.setTime(new Date()); // 设置日历对象的时间为当前时间
|
|
|
|
|
c.add(Calendar.DAY_OF_MONTH,remindStart); // 将日历对象的时间增加 remindStart 天
|
|
|
|
|
remindStartDate = c.getTime(); // 获取增加后的时间,并赋值给 remindStartDate
|
|
|
|
|
map.put("remindstart", sdf.format(remindStartDate)); // 将 remindStartDate 格式化为 "yyyy-MM-dd" 格式,并添加到 map 中,键为 "remindstart"
|
|
|
|
|
}
|
|
|
|
|
if(map.get("remindend")!=null) { // 如果 map 中存在 "remindend" 键
|
|
|
|
|
Integer remindEnd = Integer.parseInt(map.get("remindend").toString()); // 将 "remindend" 键对应的值转换为整数
|
|
|
|
|
c.setTime(new Date()); // 设置日历对象的时间为当前时间
|
|
|
|
|
c.add(Calendar.DAY_OF_MONTH,remindEnd); // 将日历对象的时间增加 remindEnd 天
|
|
|
|
|
remindEndDate = c.getTime(); // 获取增加后的时间,并赋值给 remindEndDate
|
|
|
|
|
map.put("remindend", sdf.format(remindEndDate)); // 将 remindEndDate 格式化为 "yyyy-MM-dd" 格式,并添加到 map 中,键为 "remindend"
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
Wrapper<StoreupEntity> wrapper = new EntityWrapper<StoreupEntity>(); // 创建一个实体包装器对象,用于构建查询条件
|
|
|
|
|
if(map.get("remindstart")!=null) { // 如果 map 中存在 "remindstart" 键
|
|
|
|
|
wrapper.ge(columnName, map.get("remindstart")); // 设置查询条件,查询 columnName 字段大于等于 "remindstart" 键对应的值
|
|
|
|
|
}
|
|
|
|
|
if(map.get("remindend")!=null) { // 如果 map 中存在 "remindend" 键
|
|
|
|
|
wrapper.le(columnName, map.get("remindend")); // 设置查询条件,查询 columnName 字段小于等于 "remindend" 键对应的值
|
|
|
|
|
}
|
|
|
|
|
if(!request.getSession().getAttribute("role").toString().equals("管理员")) { // 如果当前用户的角色不是管理员
|
|
|
|
|
wrapper.eq("userid", (Long)request.getSession().getAttribute("userId")); // 设置查询条件,查询 userid 字段等于当前用户的 ID
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int count = storeupService.selectCount(wrapper); // 调用服务层的方法,根据查询条件查询符合条件的记录数,并赋值给 count
|
|
|
|
|
return R.ok().put("count", count); // 返回一个包含查询结果的响应对象,其中包含键 "count" 和对应的 count 值
|
|
|
|
|
}
|
|
|
|
|
}
|