大家好,今天给大家分享一套基于SSM的高校二手交易平台系统
开发语言:Java
数据库:MySQL
技术:Spring+SpringMvc+MyBatis+Jsp
工具:IDEA/Ecilpse、Navicat、Maven
博主介绍: 一名Java全栈工程师,专注于Java全栈技术!
主要技术: SpringCloud Alibaba、SpringBoot、SSM、Html、Css、Vue、小程序、uni-app等设计与开发。
获取源码: @
基于SSM的高校二手交易平台系统
一、演示效果
二、前言
本系统将严格按照软件开发流程进行各个阶段的工作,采用B/S架构,面向对象编程思想进行项目开发。在引言中,作者将论述高校二手交易平台的当前背景以及系统开发的目的,后续章节将严格按照软件开发流程,对系统进行各个阶段分析设计。
高校二手交易平台的主要使用者分为管理员和用户,实现功能包括管理员:个人中心、用户管理、商品上架管理、订单信息管理、商品信息管理、联系商家管理、论坛管理、管理员管理、系统管理,用户:个人中心、商品上架管理、订单信息管理、商品信息管理、联系商家管理、我的收藏管理,前台首页;首页、商品信息、论坛信息、新闻资讯、我的、跳转到后台、客服等功能。由于本网站的功能模块设计比较全面,所以使得整个高校二手交易平台信息管理的过程得以实现。
本系统的使用可以实现本高校二手交易平台管理的信息化,可以方便管理员进行更加方便快捷的管理。
关键词:高校二手交易平台;JSP技术;MYSQL数据库;
三、系统关键技术
JSP技术、JAVA、MYSQL、B/S结构、SSM等等
四、系统设计
系统结构设计
五、系统功能设计
5.1前台首页功能模块
高校二手交易平台,在系统首页可以查看首页、商品信息、论坛信息、新闻资讯、我的、跳转到后台、客服等内容,如图5-1所示。
用户登录、用户注册,在注册页面可以填写账号、密码、姓名、手机、身份证等信息进行注册、登录,如图5-2所示。
个人中心,在个人中心页面通过填写账号、密码、姓名、性别、手机、身份证等信息进行更新信息、退出登录,如图5-3所示。在商品信息页面通过查看商品编号、商品名称、商品类型、数量、期望交易地点、图片、发布日期、商品介绍、账号、姓名等信息进行购物车、联系商家、点我收藏操作,如图5-4所示。
![在这里插入图片描述](https://img-blog.csdnimg.cn/direct/daa5d7d885de4f3f8ceb166e7e4c454d.png)
5.2管理员功能模块
管理员登录,通过填写用户名、密码进行登录,如图5-5所示。
管理员登录进入高校二手交易平台可以查看个人中心、用户管理、商品上架管理、订单信息管理、商品信息管理、联系商家管理、论坛管理、管理员管理、系统管理等信息。
商品上架管理,在商品上架管理页面中可以通过查看商品编号、商品名称、商品类型、数量、价格、期望交易地点、图片、上架日期、商品介绍、账号、姓名、是否审核、审核回复等内容进行修改、删除,如图5-6所示。还可以根据需要对商品信息管理进行详情,修改或删除等详细操作,如图5-7所示。
客服聊天表管理,在客服聊天表管理页面中可以查看新消息、状态等信息,并可根据需要对已有客服聊天表管理进行修改或删除等操作,如图5-8所示。
5.3用户功能模块
用户登录进入高校二手交易平台可以查看个人中心、商品上架管理、订单信息管理、商品信息管理、联系商家管理、我的收藏管理等内容。
商品上架管理,在商品上架管理页面中通过查看商品编号、商品名称、商品类型、数量、价格、期望交易地点、图片、上架日期、商品介绍、账号、姓名、是否审核、审核回复等信息,还可以根据需要对商品上架管理进行修改、删除如图5-9所示。
联系商家管理,在联系商家管理页面中通过查看标题、商品名称、商品类型、内容、账号、姓名、日期等信息,还可以根据需要对联系商家管理进行修改、删除如图5-10所示。
商品信息管理,在商品信息管理页面中通过查看商品编号、商品名称、商品类型、数量、期望交易地点、图片、发布日期、商品介绍、账号、姓名、是否审核、审核回复等信息,还可以根据需要对商品信息管理进行修改、删除如图5-11所示。
订单信息管理,在订单信息管理页面中通过查看订单编号、商品名称、商品类型、数量、期望交易地点、日期、商品介绍、账号、姓名、是否审核、审核回复、是否支付、地址等信息,还可以根据需要对订单信息管理进行修改、删除如图5-12所示。
六、部分代码
package com.controller;
import java.util.Arrays;
import java.util.Calendar;
import java.util.Date;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.PostMapping;
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.ResponseBody;
import org.springframework.web.bind.annotation.RestController;
import com.annotation.IgnoreAuth;
import com.baomidou.mybatisplus.mapper.EntityWrapper;
import com.entity.TokenEntity;
import com.entity.UserEntity;
import com.service.TokenService;
import com.service.UserService;
import com.utils.CommonUtil;
import com.utils.MPUtil;
import com.utils.PageUtils;
import com.utils.R;
import com.utils.ValidatorUtils;
/**
* 登录相关
*/
@RequestMapping("users")
@RestController
public class UserController{
@Autowired
private UserService userService;
@Autowired
private TokenService tokenService;
/**
* 登录
*/
@IgnoreAuth
@PostMapping(value = "/login")
public R login(String username, String password, String captcha, HttpServletRequest request) {
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
if(user==null || !user.getPassword().equals(password)) {
return R.error("账号或密码不正确");
}
String token = tokenService.generateToken(user.getId(),username, "users", user.getRole());
return R.ok().put("token", token);
}
/**
* 注册
*/
@IgnoreAuth
@PostMapping(value = "/register")
public R register(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}
/**
* 退出
*/
@GetMapping(value = "logout")
public R logout(HttpServletRequest request) {
request.getSession().invalidate();
return R.ok("退出成功");
}
/**
* 密码重置
*/
@IgnoreAuth
@RequestMapping(value = "/resetPass")
public R resetPass(String username, HttpServletRequest request){
UserEntity user = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", username));
if(user==null) {
return R.error("账号不存在");
}
user.setPassword("123456");
userService.update(user,null);
return R.ok("密码已重置为:123456");
}
/**
* 列表
*/
@RequestMapping("/page")
public R page(@RequestParam Map<String, Object> params,UserEntity user){
EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
PageUtils page = userService.queryPage(params, MPUtil.sort(MPUtil.between(MPUtil.allLike(ew, user), params), params));
return R.ok().put("data", page);
}
/**
* 列表
*/
@RequestMapping("/list")
public R list( UserEntity user){
EntityWrapper<UserEntity> ew = new EntityWrapper<UserEntity>();
ew.allEq(MPUtil.allEQMapPre( user, "user"));
return R.ok().put("data", userService.selectListView(ew));
}
/**
* 信息
*/
@RequestMapping("/info/{id}")
public R info(@PathVariable("id") String id){
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 获取用户的session用户信息
*/
@RequestMapping("/session")
public R getCurrUser(HttpServletRequest request){
Long id = (Long)request.getSession().getAttribute("userId");
UserEntity user = userService.selectById(id);
return R.ok().put("data", user);
}
/**
* 保存
*/
@PostMapping("/save")
public R save(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
if(userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername())) !=null) {
return R.error("用户已存在");
}
userService.insert(user);
return R.ok();
}
/**
* 修改
*/
@RequestMapping("/update")
public R update(@RequestBody UserEntity user){
// ValidatorUtils.validateEntity(user);
UserEntity u = userService.selectOne(new EntityWrapper<UserEntity>().eq("username", user.getUsername()));
if(u!=null && u.getId()!=user.getId() && u.getUsername().equals(user.getUsername())) {
return R.error("用户名已存在。");
}
userService.updateById(user);//全部更新
return R.ok();
}
/**
* 删除
*/
@RequestMapping("/delete")
public R delete(@RequestBody Long[] ids){
userService.deleteBatchIds(Arrays.asList(ids));
return R.ok();
}
}