基于javaweb+mysql的springboot校园二手书交易管理系统(java+springboot+vue+elementui+layui+mysql)

基于javaweb+mysql的springboot校园二手书交易管理系统(java+springboot+vue+elementui+layui+mysql)

私信源码获取及调试交流

运行环境

Java≥8、MySQL≥5.7、Node.js≥10

开发工具

后端:eclipse/idea/myeclipse/sts等均可配置运行

前端:WebStorm/VSCode/HBuilderX等均可

适用

课程设计,大作业,毕业设计,项目练习,学习演示等

功能说明

基于javaweb的SpringBoot校园二手书交易管理系统(java+springboot+vue+elementui+layui+mysql)

项目介绍

基于SpringBoot Vue的校园二手书交易管理系统

角色:管理员、卖家、用户

管理员:管理员登录系统后,可以对首页、个人中心、用户管理、卖家用户管理、图书分类管理、二手图书管理、求购图书管理、求购回复管理、留言反馈、系统管理、订单管理等功能模块

卖家:卖家用户登录系统后,可以对首页、个人中心、二手图书管理、求购图书管理、求购回复管理、订单管理等

用户:用户登录系统后,可以对首页、个人中心、二手图书管理、求购图书管理、求购回复管理、订单管理

环境需要

1.运行环境:最好是java jdk 1.8,我们在这个平台上运行的。其他版本理论上也可以。 2.IDE环境:IDEA,Eclipse,Myeclipse都可以。推荐IDEA; 3.硬件环境:windows 7/8/10 1G内存以上;或者 Mac OS; 4.数据库:MySql 5.7/8.0版本均可; 5.是否Maven项目:是;

技术栈

后端:SpringBoot+Mybaits

前端:Vue+ElementUI+Layui+HTML+CSS+JS

使用说明

项目运行: 1. 使用Navicat或者其它工具,在mysql中创建对应sql文件名称的数据库,并导入项目的sql文件; 2. 使用IDEA/Eclipse/MyEclipse导入项目,导入成功后请执行maven clean;maven install命令,然后运行; 3. 将项目中application.yml配置文件中的数据库配置改为自己的配置; 4. 运行项目,控制台提示运行成功后再去运行前端项目; 5. 管理员用户名密码:admin/admin 普通用户名密码:user/123456


public String getSellerInfo(ModelMap model,

@RequestParam(value = "orderId", required = false) Integer orderId,

HttpSession session) {

User sessionUser = (User) session.getAttribute("user");

if (sessionUser == null) {

return "redirect:/";

Order orderInfo = orderService.getOrderById(orderId);

List<Order> orders = orderService.getOtherOrderBySellerId(

sessionUser.getId(), orderId);

model.addAttribute("orderInfo", orderInfo);

model.addAttribute("orders", orders);


User sessionUser = (User) session.getAttribute("user");

if (sessionUser == null) {

return "redirect:/";

Order orderInfo = orderService.getOrderById(orderId);

List<Order> orders = orderService.getOtherOrderByCustomerId(

sessionUser.getId(), orderId);

model.addAttribute("orderInfo", orderInfo);

model.addAttribute("orders", orders);

return "user/orderInfo";

@RequestMapping(value = "/user/sellerInfo", method = RequestMethod.GET)

public String getSellerInfo(ModelMap model,

@RequestParam(value = "orderId", required = false) Integer orderId,


.getId() + " " + user.getId());

status = "此手机号码已使用!";

} else if (userService.getUserByEmail(user.getEmail()).getId() != user

.getId()) {

status = "此邮箱已使用!";

} else {

if (!photo.isEmpty()) {

RandomString randomString = new RandomString();

FileCheck fileCheck = new FileCheck();

String filePath = "/statics/image/photos/" + user.getId();

String pathRoot = fileCheck.checkGoodFolderExist(filePath);

public String adminLogout(@RequestParam(required = false, defaultValue = "false" )String adminLogout, HttpSession session){

if (adminLogout.equals("true")){

session.removeAttribute("admin");

//        adminLogout = "false";

return "redirect:/";

@RequestMapping(value = "/adminPage", method = RequestMethod.GET)

public String getAdminPage(ModelMap model,

HttpSession session){

User admin = (User) session.getAttribute("admin");

if (admin == null){

return "redirect:/admin/adminLogin";

List<Good> goodList = goodService.getAllGoodList();

//            }

if (!password .equals(admin.getPassword())){

message = "用户密码错误!";

} else if (admin.getRoleId() != 101){

message = "用户没有权限访问!";

} else {

session.setAttribute("admin",admin);

return "redirect:/admin/adminPage";

} else {

message = "用户不存在!";

model.addAttribute("message", message);

return "admin/adminLogin";

@RequestMapping(value = "/adminLogout", method = RequestMethod.GET)


if (success) {

Order order = orderService.getOrderById(orderId);

return ResponseEntity.ok(order);

return ResponseEntity.ok(success);

@RequestMapping(value = "/user/order/create", method = RequestMethod.POST)

public ResponseEntity createOrder(@RequestBody Order order) {

Boolean success = orderService.insertOrder(order) > 0;

if (success) {

success = goodService.updateGoodStatusId(0, order.getGoodId()) > 0;

if (success) {

return ResponseEntity.ok(order.getId());

} else {

orderService.deleteOrderById(order.getId());


private final GoodService goodService;

private final OrderService orderService;

@Autowired

public OrderController(GoodService goodService, OrderService orderService) {

this.goodService = goodService;

this.orderService = orderService;

@RequestMapping(value = "/user/orderInfo", method = RequestMethod.GET)

public String getOrderInfo(ModelMap model,

@RequestParam(value = "orderId", required = false) Integer orderId,

HttpSession session) {


List<Order> orderList = orderService.getOrderList();

model.addAttribute("goodList", goodList);

model.addAttribute("userList", userList);

model.addAttribute("firstTypeList", firstTypeList);

model.addAttribute("orderList", orderList);

return "admin/adminPage";

@RequestMapping(value = "/user/update/status/{statusId}&{userId}", method = RequestMethod.GET)

public ResponseEntity updateUserStatus(@PathVariable Integer statusId,

@PathVariable Integer userId){

Boolean success = userService.updateUserStatus(statusId, userId);


if (sessionUser == null) {

return "redirect:/";

Order orderInfo = orderService.getOrderById(orderId);

List<Order> orders = orderService.getOtherOrderByCustomerId(

sessionUser.getId(), orderId);

model.addAttribute("orderInfo", orderInfo);

model.addAttribute("orders", orders);

return "user/orderInfo";

@RequestMapping(value = "/user/sellerInfo", method = RequestMethod.GET)

public String getSellerInfo(ModelMap model,

@RequestParam(value = "orderId", required = false) Integer orderId,

HttpSession session) {


.getNewPassword() + code).getBytes());

Boolean success = userService.updatePassword(md5Pass, code,

password.getUserId());

if (success) {

return ResponseEntity.ok(true);

} else {

return ResponseEntity.ok("密码修改失败!");

} else {

return ResponseEntity.ok("原密码输入不正确!");

 管理员控制层:

@Controller

@RequestMapping(value = "admin")

model.addAttribute("replies", replies);

return "user/userEdit";

@RequestMapping(value = "/userEdit", method = RequestMethod.POST)

public String postUserEdit(ModelMap model, @Valid User user,

HttpSession session,

@RequestParam(value = "photo", required = false) MultipartFile photo)

throws IOException {

String status;

Boolean insertSuccess;

User sessionUser = (User) session.getAttribute("user");


return "redirect:/user/userProfile";

@RequestMapping(value = "/userEdit", method = RequestMethod.GET)

public String getUserEdit(ModelMap model,

@RequestParam(value = "userId", required = false) Integer userId,

HttpSession session) {

User sessionUser = (User) session.getAttribute("user");

if (sessionUser == null) {

return "redirect:/";

User user = userService.getUserById(userId);

List<Order> sellGoods = orderService.getOrderBySellerId(user.getId());

List<Review> reviews = reviewService.gerReviewByToUserId(user.getId());

List<Reply> replies = reviewService.gerReplyByToUserId(user.getId());


List<Reply> replies = reviewService.gerReplyByToUserId(user.getId());

List<Order> sellGoods = orderService.getOrderBySellerId(user.getId());

model.addAttribute("collects", collects);

model.addAttribute("goods", goods);

model.addAttribute("orders", orders);

model.addAttribute("reviews", reviews);

model.addAttribute("replies", replies);

model.addAttribute("sellGoods", sellGoods);

return "user/userProfile";

@RequestMapping(value = "/review", method = RequestMethod.GET)

public String getReviewInfo(@RequestParam(required = false) Integer goodId,

@RequestParam(required = false) Integer reviewId) {

System.out.println("reviewId" + reviewId);

model.addAttribute("replies", replies);

model.addAttribute("sellGoods", sellGoods);

return "user/userProfile";

@RequestMapping(value = "/review", method = RequestMethod.GET)

public String getReviewInfo(@RequestParam(required = false) Integer goodId,

@RequestParam(required = false) Integer reviewId) {

System.out.println("reviewId" + reviewId);

if (reviewId != null) {

System.out.println("reviewId" + reviewId);

if (reviewService.updateReviewStatus(1, reviewId) == 1) {

return "redirect:/goods/goodInfo?goodId=" + goodId;

return "redirect:/user/userProfile";

@RequestParam(value = "password", required = false) String password,

HttpSession session) {

User admin = userService.getUserByEmail(email);

String message;

if (admin != null){

String mdsPass = DigestUtils.md5DigestAsHex((password + admin.getCode()).getBytes());

//            if (!mdsPass .equals(admin.getPassword())){

//                message = "用户密码错误!";

//            }

if (!password .equals(admin.getPassword())){

message = "用户密码错误!";


model.addAttribute("sellGoods", sellGoods);

model.addAttribute("reviews", reviews);

model.addAttribute("replies", replies);

return "user/userEdit";

@RequestMapping(value = "/userEdit", method = RequestMethod.POST)

public String postUserEdit(ModelMap model, @Valid User user,

HttpSession session,

@RequestParam(value = "photo", required = false) MultipartFile photo)

throws IOException {

String status;

Boolean insertSuccess;

User sessionUser = (User) session.getAttribute("user");


@RequestMapping(value = "/adminPage", method = RequestMethod.GET)

public String getAdminPage(ModelMap model,

HttpSession session){

User admin = (User) session.getAttribute("admin");

if (admin == null){

return "redirect:/admin/adminLogin";

List<Good> goodList = goodService.getAllGoodList();

for (Good good : goodList) {

good.setGoodUser(userService.getUserById(good.getUserId()));

good.setGoodSecondType(typeService.getSecondTypeById(good.getSecondTypeId()));

List<User> userList = userService.getAllUser();

model.addAttribute("goodList", goodList);

model.addAttribute("userList", userList);

model.addAttribute("firstTypeList", firstTypeList);

model.addAttribute("orderList", orderList);

return "admin/adminPage";

@RequestMapping(value = "/user/update/status/{statusId}&{userId}", method = RequestMethod.GET)

public ResponseEntity updateUserStatus(@PathVariable Integer statusId,

@PathVariable Integer userId){

Boolean success = userService.updateUserStatus(statusId, userId);

if (success){

请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述
请添加图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java毕业

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值