末获取源码
开发语言:Java
开发工具:IDEA /Eclipse
数据库:MYSQL5.7
应用服务:Tomcat7/Tomcat8
使用框架ssm+vue
JDK版本:jdk1.8
校园短期闲置资源置换平台是校园短期闲置资源置换必不可少的一个部分。在校园短期闲置资源置换的整个过程中,校园短期闲置资源置换平台担负着最重要的角色。为满足如今日益复杂的管理需求,各类校园短期闲置资源置换管理程序也在不断改进。本课题所设计的校园短期闲置资源置换平台,使用java技术进行开发,它的优点代码不能从浏览器查看,保密性非常好,比其他的系统更具安全性。java还容易修改和调试,毕竟商家是在不断发展过程中,难免有更多需求,这点很重要。而且,本系统对校园短期闲置资源置换的管理,是为了满足更深层次的需求。除了上述优势外,本系统还具有查询迅速,搜索资料方便,可靠性强等特点。
考虑到实际生活中校园短期闲置资源置换管理方面的需要以及对该平台认真地分析,将系统权限按管理员,置换账户和用户这三类涉及用户划分。
(1)管理员;管理员使用本系统涉到的功能主要有:首页,个人中心,用户管理,置换账户管理,商品分类管理,置换商品管理,置换订单管理,交流论坛,系统管理等功能。管理员用例图如图
(2)置换账户;进入系统可以实现首页,个人中心,置换商品管理,置换订单管理等功能。置换账户用例图如图
(3)用户;进入系统可以实现首页,个人中心,置换订单管理等功能。用户用例图如图
校园短期闲置资源转换平台,在平台首页可以查看首页,置换商品,交流论坛,公告信息,个人中心,后台管理,在线客服等内容,并进行详细操作;如图
在用户注册页面通过填写用户账号,密码,再次输入密码, 用户姓名,联系方式等信息进行注册操作,如图
在置换商品页面可以查看商品名称,商品分类,成色,品牌,置换账号,置换姓名,联系电话,点击次数等内容,并进行申请置换,评论和收藏操作,如图
在交流论坛页面可以查看帖子标题,发布人,发布时间,帖子内容等信息并进行评论操作,如图
在个人中心页面通过填写用户账号,密码,用户姓名,上传图片,性别,联系方式等内容进行更新信息,还可以根据需要对我的发布,我的收藏进行相对应操作,如图
管理员进行登录,进入系统前在登录页面根据要求填写用户名和密码,选择角色等信息,点击登录进行登录操作,如图
管理员登录系统后,可以对首页,个人中心,用户管理,置换账户管理,商品分类管理,置换商品管理,置换订单管理,交流论坛,系统管理等功能进行相应的操作管理,如图
在用户管理页面可以对索引,用户账号,用户姓名,照片,性别,联系方式等内容进行详情,修改和删除等操作,如图
在置换账户管理页面可以对索引,置换账号,置换姓名,照片,性别,联系电话等内容进行详情,修改和删除等操作,如图
在商品分类管理页面可以对索引, 商品分类等内容进行详情,修改和删除等操作,如图
在置换商品管理页面可以对索引,商品名称,图片,商品分类,成色,品牌,置换账号,置换姓名,联系电话等内容进行详情,修改,查看评论和删除等操作,如图
在置换订单管理页面可以对索引,置换编号,商品名称,品牌,置换账号,联系电话,置换物品,物品图片,物品品牌,物品成色,交换地址,用户账号,用户姓名,联系方式,审核回复,审核状态等内容进行详情,修改和删除操作,如图
在交流论坛页面可以对索引,帖子标题,用户名,状态等内容进行详情,修改,查看评论和删除等操作,如图
在公告信息页面可以对索引,标题,图片等内容进行详情,修改和删除操作,还可以对在线客服,轮播图管理进行详细操作,如图
用户登录进入校园短期闲置资源转换平台可以对首页,个人中心,置换订单管理等功能进行相应操作,如图
在置换订单管理页面可以对索引,置换编号,商品名称,品牌,置换账号,联系电话,置换物品,物品图片,物品品牌,物品成色,交换地址,用户账号,用户姓名,联系方式,审核回复,审核状态等内容进行详情和删除操作,如图
置换账户登录进入校园短期闲置资源转换平台可以对首页,个人中心,置换商品管理,置换订单管理等功能进行相应操作,如图
在置换商品管理页面可以对索引,商品名称,图片,商品分类,成色,品牌,置换账号,置换姓名,联系电话等内容进行详情,修改,查看评论和删除等操作,如图
在置换订单管理页面可以对索引,置换编号,商品名称,品牌,置换账号,联系电话,置换物品,物品图片,物品品牌,物品成色,交换地址,用户账号,用户姓名,联系方式,审核回复,审核状态,审核等内容进行详情和删除操作,如图
/**
* 置换账户
* 后端接口
* @author
* @email
* @date 2022-04-25 17:05:25
*/
@RestController
@RequestMapping("/zhihuanzhanghu")
public class ZhihuanzhanghuController {
@Autowired
private ZhihuanzhanghuService zhihuanzhanghuService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@RequestMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
ZhihuanzhanghuEntity user = zhihuanzhanghuService.selectOne(new EntityWrapper().eq("zhihuanzhanghao", username));
if(user==null || !user.getMima().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(), username,"zhihuanzhanghu", "置换账户" );
return R.ok().put("token", token);
}
/**
* 注册
*/
@IgnoreAuth
@RequestMapping("/register")
public R register(@RequestBody ZhihuanzhanghuEntity zhihuanzhanghu){
//ValidatorUtils.validateEntity(zhihuanzhanghu);
ZhihuanzhanghuEntity user = zhihuanzhanghuService.selectOne(new EntityWrapper().eq("zhihuanzhanghao", zhihuanzhanghu.getZhihuanzhanghao()));
if(user!=null) {
return R.error("注册用户已存在");
}
Long uId = new Date().getTime();
zhihuanzhanghu.setId(uId);
zhihuanzhanghuService.insert(zhihuanzhanghu);
return R.ok();
}
/**
* 退出
*/
@RequestMapping("/logout")
public R logout(HttpServletRequest request) {
request.getSession().invalidate();
return R.ok("退出成功");
}
/**
* 获取用户的session用户信息
*/
@RequestMapping("/session")
public R getCurrUser(HttpServletRequest request){
Long id = (Long)request.getSession().getAttribute("userId");
ZhihuanzhanghuEntity user = zhihuanzhanghuService.selectById(id);
return R.ok().put("data", user);
}
/**
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
ZhihuanzhanghuEntity user = zhihuanzhanghuService.selectOne(new EntityWrapper().eq("zhihuanzhanghao", username));
if(user==null) {
return R.error("账号不存在");
}
user.setMima("123456");
zhihuanzhanghuService.updateById(user);
return R.ok("密码已重置为:123456");
}
/**
* 后端列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map params,ZhihuanzhanghuEntity zhihuanzhanghu,
HttpServletRequest request){
EntityWrapper ew = new EntityWrapper();
PageUtils page = zhihuanzhanghuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zhihuanzhanghu), params), params));
return R.ok().put("data", page);
}
/**
* 前端列表
*/
@IgnoreAuth
@RequestMapping("/list")
public R list(@RequestParam Map params,ZhihuanzhanghuEntity zhihuanzhanghu,
HttpServletRequest request){
EntityWrapper ew = new EntityWrapper();
PageUtils page = zhihuanzhanghuService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.likeOrEq(ew, zhihuanzhanghu), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/lists")
public R list( ZhihuanzhanghuEntity zhihuanzhanghu){
EntityWrapper ew = new EntityWrapper();
ew.allEq(MPUtil.allEQMapPre( zhihuanzhanghu, "zhihuanzhanghu"));
return R.ok().put("data", zhihuanzhanghuService.selectListView(ew));
}
/**
* 查询
*/
@RequestMapping("/query")
public R query(ZhihuanzhanghuEntity zhihuanzhanghu){
EntityWrapper< ZhihuanzhanghuEntity> ew = new EntityWrapper< ZhihuanzhanghuEntity>();
ew.allEq(MPUtil.allEQMapPre( zhihuanzhanghu, "zhihuanzhanghu"));
ZhihuanzhanghuView zhihuanzhanghuView = zhihuanzhanghuService.selectView(ew);
return R.ok("查询置换账户成功").put("data", zhihuanzhanghuView);
}
/**
* 后端详情
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") Long id){
ZhihuanzhanghuEntity zhihuanzhanghu = zhihuanzhanghuService.selectById(id);
return R.ok().put("data", zhihuanzhanghu);
}
/**
* 前端详情
*/
@IgnoreAuth
@RequestMapping("/detail/{id}")
public R detail(@PathVariable("id") Long id){
ZhihuanzhanghuEntity zhihuanzhanghu = zhihuanzhanghuService.selectById(id);
return R.ok().put("data", zhihuanzhanghu);
}
/**
* 后端保存
*/
@RequestMapping("/save")
public R save(@RequestBody ZhihuanzhanghuEntity zhihuanzhanghu, HttpServletRequest request){
zhihuanzhanghu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(zhihuanzhanghu);
ZhihuanzhanghuEntity user = zhihuanzhanghuService.selectOne(new EntityWrapper().eq("zhihuanzhanghao", zhihuanzhanghu.getZhihuanzhanghao()));
if(user!=null) {
return R.error("用户已存在");
}
zhihuanzhanghu.setId(new Date().getTime());
zhihuanzhanghuService.insert(zhihuanzhanghu);
return R.ok();
}
/**
* 前端保存
*/
@RequestMapping("/add")
public R add(@RequestBody ZhihuanzhanghuEntity zhihuanzhanghu, HttpServletRequest request){
zhihuanzhanghu.setId(new Date().getTime()+new Double(Math.floor(Math.random()*1000)).longValue());
//ValidatorUtils.validateEntity(zhihuanzhanghu);
ZhihuanzhanghuEntity user = zhihuanzhanghuService.selectOne(new EntityWrapper().eq("zhihuanzhanghao", zhihuanzhanghu.getZhihuanzhanghao()));
if(user!=null) {
return R.error("用户已存在");
}
zhihuanzhanghu.setId(new Date().getTime());
zhihuanzhanghuService.insert(zhihuanzhanghu);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
@Transactional
public R update(@RequestBody ZhihuanzhanghuEntity zhihuanzhanghu, HttpServletRequest request){
//ValidatorUtils.validateEntity(zhihuanzhanghu);
zhihuanzhanghuService.updateById(zhihuanzhanghu);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
zhihuanzhanghuService.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 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 wrapper = new EntityWrapper();
if(map.get("remindstart")!=null) {
wrapper.ge(columnName, map.get("remindstart"));
}
if(map.get("remindend")!=null) {
wrapper.le(columnName, map.get("remindend"));
}
int count = zhihuanzhanghuService.selectCount(wrapper);
return R.ok().put("count", count);
}
}