基于javaweb+mysql的springboot+mybatis网上书店管理系统在线购书系统(前台、后台)(javaweb+springboot+thymeleaf+html+mysql+maven)
私信源码获取及调试交流
运行环境
Java≥8、MySQL≥5.7
开发工具
eclipse/idea/myeclipse/sts等均可配置运行
适用
课程设计,大作业,毕业设计,项目练习,学习演示等
功能说明
前台:购书
后台:管理书、用户、订单发货等
前台
后台
技术框架
JavaWeb SpringBoot MyBatis Thymeleaf html layui JavaScript SpringMVC MySQL
基于javaweb的SpringBoot+MyBatis网上书店管理系统在线购书系统(前台、后台)(javaweb+springboot+thymeleaf+html+mysql+maven)
HttpSession session = request.getSession();
if (session.getAttribute("user")==null) {
//用户未登录,抛出异常
throw new CustomizeException(ResultCode.USER_NOT_LOGGED_IN);
}
//已登录,放行请求
return true;
}
}
/**
* @Description: 管理员访问拦截器
*/
public class AdminInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
HttpSession session = request.getSession();
if (session.getAttribute("admin")==null) {
//用户未登录,抛出异常
throw new CustomizeException(ResultCode.USER_NOT_LOGGED_IN);
}
Admin admin = (Admin) session.getAttribute("admin");
//已登录,放行请求
return true;
}
}
/**
* @Description: 登录注册模块业务接口
*/
public interface LoginRegisterService {
/**
* 用户登录
* @param record
* @param session
* 处理前台获取所有分类的请求
* @return
*/
@GetMapping("/category")
@ResponseBody
public ResultVO getCategories() {
List<Category> categories = bookDisplayService.getAllCategories();
return new ResultVO(ResultCode.SUCCESS,categories);
}
/**
* 根据前台传来的categoryCode,响应对应的分类的书籍
* 需要进行分页响应
* 如果categoryCode为null,则响应所有书籍
* @param categoryCode 分类代码
* @param page 页码
* @param limit 每页的数量
* @return
*/
@GetMapping("/books")
@ResponseBody
public ResultVO getBooksByCategoryCode(@RequestParam(required = false) String categoryCode, @RequestParam(required = false) Integer page, @RequestParam(required = false) Integer limit) {
List<Book> books = bookDisplayService.getBooksByCategoryCode(page==null?1:page, limit==null?10:limit, categoryCode);
PageInfo pageInfo = new PageInfo(books); //获得分页信息
return new ResultVO(ResultCode.SUCCESS, (int) pageInfo.getTotal(),books);
}
/**
* 根据请求的bookId,返回该Id的书籍信息,响应Html视图
* @param bookId
* @return
*/
@GetMapping("/books/details/{bookId}")
public String bookDetailsView(@PathVariable("bookId") Integer bookId, Model model) {
Book book = bookDisplayService.getBookDetailsByBookId(bookId);
model.addAttribute("book", book);
return "details";
}
/**
* 首页根据书名搜索书籍
* @param bookName
* @return
*/
@GetMapping("/books/search")
@ResponseBody
}
@PostMapping("/delete")
public ResultVO bookDelete(Integer bookId) {
int books = bookService.bookDeleteSearchById(bookId);
return new ResultVO(ResultCode.SUCCESS, null);
}
//添加验证注解
@PostMapping("/insert")
public ResultVO bookInsert(@Valid Book record) {
int books = bookService.bookInsert(record);
return new ResultVO(ResultCode.SUCCESS, null);
}
@GetMapping("/searchcode")
public ResultVO bookSerchByCategoryCode(String catrgoryCode,Integer page,Integer limit) {
List<Book> books = bookService.bookSearchByCode(catrgoryCode,page,limit);
PageInfo pageInfo = new PageInfo(books);
if(books.size()!=0)
{
return new ResultVO(ResultCode.SUCCESS,(int)pageInfo.getTotal(), books);
}
else
return new ResultVO(ResultCode.RECORD_NOT_FOUND, null);
}
//添加验证注解
@PostMapping("/update")
public ResultVO bookUpdate(@Valid Book record) {
int books = bookService.bookUpdate(record);
return new ResultVO(ResultCode.SUCCESS, null);
}
/**
* 多条件搜索 ----by guozongchao
* @param book
* @param page
* @param limit
* @return
*/
bindingResult = ex.getBindingResult();
}else {
BindException ex=(BindException)e;
bindingResult = ex.getBindingResult();
}
ObjectError error = bindingResult.getAllErrors().get(0);
return new ResultVO(ResultCode.ARGUMENT_NOT_VALID,error.getDefaultMessage(),null);
}
/**
* 其他异常处理
* @param e
* @return
*/
@ExceptionHandler(Exception.class)
public ResultVO ExceptionHandler(Exception e){
log.error(e.getMessage());
return new ResultVO(ResultCode.UNKNOWN_ERROR,e.getMessage());
}
}
/**
* @Description: 客户端路由控制器
*/
@Controller
public class ClientRouterController {
//跳转首页
@GetMapping({"/","/index"})
public String toHomePage(){
return "index";
}
//跳转登录页面
@GetMapping("/login")
public String toLogin(HttpSession session){
if(session.getAttribute("user")!=null){
return new ResultVO(ResultCode.SUCCESS, carts);
}
/**
* 更新购物车的商品数量
* @param cartId 购物车Id
* @param quantity 商品购买数量
* @return
*/
@PutMapping("/list/{cartId}")
public ResultVO updateCartItem(@PathVariable("cartId") Integer cartId,Integer quantity) {
if(quantity<=0){
throw new CustomizeException(ResultCode.FAILED,"购物数量必须大于0");
}
if(quantity>10){
throw new CustomizeException(ResultCode.FAILED,"每件商品限购10件");
}
ShoppingCart cart = new ShoppingCart();
cart.setCartId(cartId);
cart.setQuantity(quantity);
shoppingCartService.updateShoppingCart(cart);
return new ResultVO(ResultCode.SUCCESS);
}
/**
* 添加到购物车请求处理
*
* @param cart 接收前台传来的参数
* @return
*/
@PostMapping("/list")
public ResultVO addToShoppingCart(@Valid ShoppingCart cart, HttpSession session) {
User user = (User) session.getAttribute("user");
cart.setUserId(user.getUserId());
shoppingCartService.addToShoppingCart(cart);
return new ResultVO(ResultCode.SUCCESS);
}
/**
* 删除前台传来的cartId的购物车项
* @param cartId
* @return
*/
@DeleteMapping("/list/{cartId}")
public ResultVO deleteCartItem(@PathVariable("cartId") Integer cartId) {
shoppingCartService.deleteShoppingCartByCartId(cartId);
return new ResultVO(ResultCode.SUCCESS);
}
//添加验证注解
@PostMapping("/insert")
public ResultVO bookInsert(@Valid Book record) {
int books = bookService.bookInsert(record);
return new ResultVO(ResultCode.SUCCESS, null);
}
@GetMapping("/searchcode")
public ResultVO bookSerchByCategoryCode(String catrgoryCode,Integer page,Integer limit) {
List<Book> books = bookService.bookSearchByCode(catrgoryCode,page,limit);
PageInfo pageInfo = new PageInfo(books);
if(books.size()!=0)
{
return new ResultVO(ResultCode.SUCCESS,(int)pageInfo.getTotal(), books);
}
else
return new ResultVO(ResultCode.RECORD_NOT_FOUND, null);
}
//添加验证注解
@PostMapping("/update")
public ResultVO bookUpdate(@Valid Book record) {
int books = bookService.bookUpdate(record);
return new ResultVO(ResultCode.SUCCESS, null);
}
/**
* 多条件搜索 ----by guozongchao
* @param book
* @param page
* @param limit
* @return
*/
@GetMapping("/search")
public ResultVO searchBooks(Book book,Integer page, Integer limit) {
if(book.getBookName().isEmpty()){
book.setBookName(null);
}
if(book.getIsbn().isEmpty()){
book.setIsbn(null);
}
List<Book> books = bookService.searchBooks(book, page, limit);
return new ResultVO(ResultCode.SUCCESS,null);
}
else
return new ResultVO(ResultCode.RECORD_NOT_FOUND,null);
}
/**
* 删除指定orderId的订单
* @param orderId
* @return
*/
@DeleteMapping("/list/{orderId}")
public ResultVO deleteOrder(@PathVariable("orderId") Integer orderId) {
int orders = orderService.deleteByOrderId(orderId);
return new ResultVO(ResultCode.SUCCESS,null);
}
/* @GetMapping("/list/user_order/{userId}")
public ResultVO getOrderByUserId(@PathVariable("userId") Integer userId) {
List<Order> orders = orderService.selectByUserId(userId);
if(orders.size()!=0)
{
return new ResultVO(ResultCode.SUCCESS,orders);
}
else
return new ResultVO(ResultCode.RECORD_NOT_FOUND,null);
}*/
@GetMapping("/list/{orderId}")
public ResultVO getOrderByOrderId(@PathVariable("orderId") Integer orderId) {
Order orders = orderService.selectByOrderId(orderId);
if(orders!=null)
return new ResultVO(ResultCode.SUCCESS,orders);
else
return new ResultVO(ResultCode.RECORD_NOT_FOUND,null);
}
/**
* 多条件搜索订单 ---- by guozongchao
* @param order
* @param page
* @param limit
* @return
}
/**
* 根据前台传来的categoryCode,响应对应的分类的书籍
* 需要进行分页响应
* 如果categoryCode为null,则响应所有书籍
* @param categoryCode 分类代码
* @param page 页码
* @param limit 每页的数量
* @return
*/
@GetMapping("/books")
@ResponseBody
public ResultVO getBooksByCategoryCode(@RequestParam(required = false) String categoryCode, @RequestParam(required = false) Integer page, @RequestParam(required = false) Integer limit) {
List<Book> books = bookDisplayService.getBooksByCategoryCode(page==null?1:page, limit==null?10:limit, categoryCode);
PageInfo pageInfo = new PageInfo(books); //获得分页信息
return new ResultVO(ResultCode.SUCCESS, (int) pageInfo.getTotal(),books);
}
/**
* 根据请求的bookId,返回该Id的书籍信息,响应Html视图
* @param bookId
* @return
*/
@GetMapping("/books/details/{bookId}")
public String bookDetailsView(@PathVariable("bookId") Integer bookId, Model model) {
Book book = bookDisplayService.getBookDetailsByBookId(bookId);
model.addAttribute("book", book);
return "details";
}
/**
* 首页根据书名搜索书籍
* @param bookName
* @return
*/
@GetMapping("/books/search")
@ResponseBody
public ResultVO searchBook(@RequestParam(required = true) String bookName) {
List<Book> books = bookDisplayService.searchBooksByBookName(1, 10, bookName);
PageInfo pageInfo = new PageInfo(books);
return new ResultVO(ResultCode.SUCCESS, (int) pageInfo.getTotal(), books);
}
}
}
*/
/* @GetMapping("/search")
public ResultVO searchUserById(Integer userId) {
User users =userService.selectByUserId(userId);
if(users!=null)
return new ResultVO(ResultCode.SUCCESS,users);
else
return new ResultVO(ResultCode.USER_NOT_FOUND,null);
}*/
/* 原来
@PostMapping("/update1")
public ResultVO updateUser( User record) {
int users =userService.updateByUserId(record);
return new ResultVO(ResultCode.SUCCESS,null);
}*/
/**
* 修改 添加验证注解和RequestBody注解 --By guozongchao
* @param record
* @return
*/
@PostMapping("/update")
public ResultVO updateUser(@RequestBody @Valid User record) {
int users =userService.updateByUserId(record);
return new ResultVO(ResultCode.SUCCESS,null);
}
@GetMapping("/search")
public ResultVO searchUsers(User user, Integer page, Integer limit) {
if (user.getUserName().isEmpty()) {
user.setUserName(null);
}
if (user.getEmail().isEmpty()) {
user.setEmail(null);
}
List<User> users = userService.searchUsers(user, page, limit);
PageInfo pageInfo = new PageInfo(users);
return new ResultVO(ResultCode.SUCCESS, (int) pageInfo.getTotal(), users);
}
}
return new ResultVO(ResultCode.SUCCESS,users);
else
return new ResultVO(ResultCode.USER_NOT_FOUND,null);
}*/
/* 原来
@PostMapping("/update1")
public ResultVO updateUser( User record) {
int users =userService.updateByUserId(record);
return new ResultVO(ResultCode.SUCCESS,null);
}*/
/**
* 修改 添加验证注解和RequestBody注解 --By guozongchao
* @param record
* @return
*/
@PostMapping("/update")
public ResultVO updateUser(@RequestBody @Valid User record) {
int users =userService.updateByUserId(record);
return new ResultVO(ResultCode.SUCCESS,null);
}
@GetMapping("/search")
public ResultVO searchUsers(User user, Integer page, Integer limit) {
if (user.getUserName().isEmpty()) {
user.setUserName(null);
}
if (user.getEmail().isEmpty()) {
user.setEmail(null);
}
List<User> users = userService.searchUsers(user, page, limit);
PageInfo pageInfo = new PageInfo(users);
return new ResultVO(ResultCode.SUCCESS, (int) pageInfo.getTotal(), users);
}
}
public ResultVO methodArgumentNotValidExceptionHandler(Exception e) {
BindingResult bindingResult;
if(e instanceof MethodArgumentNotValidException){
MethodArgumentNotValidException ex= (MethodArgumentNotValidException)e;
bindingResult = ex.getBindingResult();
}else {
BindException ex=(BindException)e;
bindingResult = ex.getBindingResult();
}
ObjectError error = bindingResult.getAllErrors().get(0);
return new ResultVO(ResultCode.ARGUMENT_NOT_VALID,error.getDefaultMessage(),null);
}
/**
* 其他异常处理
* @param e
* @return
*/
@ExceptionHandler(Exception.class)
public ResultVO ExceptionHandler(Exception e){
log.error(e.getMessage());
return new ResultVO(ResultCode.UNKNOWN_ERROR,e.getMessage());
}
}
/**
* @Description: 客户端路由控制器
*/
@Controller
public class ClientRouterController {
//跳转首页
@GetMapping({"/","/index"})
public String toHomePage(){
return "index";
}
/**
* @Description: 首页商品展示模块控制器
*/
@Controller
@RequestMapping("/index")
public class BookDisplayController {
@Autowired
private BookDisplayService bookDisplayService;
/**
* 处理前台获取所有分类的请求
* @return
*/
@GetMapping("/category")
@ResponseBody
public ResultVO getCategories() {
List<Category> categories = bookDisplayService.getAllCategories();
return new ResultVO(ResultCode.SUCCESS,categories);
}
/**
* 根据前台传来的categoryCode,响应对应的分类的书籍
* 需要进行分页响应
* 如果categoryCode为null,则响应所有书籍
* @param categoryCode 分类代码
* @param page 页码
* @param limit 每页的数量
/**
* @Description: 用户中心模块
*/
@Controller
@RequestMapping("/user_center")
public class UserCenterController {
@Autowired
private OrderHandleService orderHandleService;
/**
* 根据用户ID,获取用户订单
* @return
*/
@GetMapping("/orders")
@ResponseBody
public ResultVO getUserOrders(Integer page, Integer limit, HttpSession session) {
User user = (User) session.getAttribute("user");
List<Order> orders = orderHandleService.getOrdersByUserId(user.getUserId(), page, limit);
PageInfo pageInfo = new PageInfo(orders);
return new ResultVO(ResultCode.SUCCESS, (int)pageInfo.getTotal(),orders);
}
/**
* 删除指定orderId的订单
* @param orderId
* @return
*/
@DeleteMapping("/orders/{orderId}")
@ResponseBody
private OrderHandleService orderHandleService;
/**
* 分页获取订单列表,如果都为空,则获取所有
* @param page 页码
* @param limit 每页的条数
* @return
*/
@GetMapping("/list")
public ResultVO getOrderList(@RequestParam(required = false) Integer page, @RequestParam(required = false) Integer limit) {
List<Order> orders = orderHandleService.getAllOrdersByPage(page, limit);
PageInfo pageInfo = new PageInfo(orders);
return new ResultVO(ResultCode.SUCCESS,(int)pageInfo.getTotal(),orders);
}
/**
* 用户提交订单处理
* @param order
* @param session
* @return
*/
@PostMapping("/submit")
public ResultVO orderSubmit(@RequestBody @Valid Order order, HttpSession session) {
User user = (User) session.getAttribute("user");
order.setUserId(user.getUserId());
orderHandleService.createOrder(order);
return new ResultVO(ResultCode.SUCCESS,"/"+user.getUserName()+"/orders");
}
/**
* 更新订单信息,比如审核通过
* @param order
* @return
*/
@PutMapping("/list/{orderId}")
public ResultVO updateOrder(@PathVariable("orderId") Integer orderId,@RequestBody Order order) {
Order orders1 = orderService.selectByOrderId(orderId);
if(orders1!=null)
{
order.setOrderId(orderId);
int orders = orderService.updateByOrderId(order);
return new ResultVO(ResultCode.SUCCESS,null);
}
else
return new ResultVO(ResultCode.RECORD_NOT_FOUND,null);
//跳转登录页面
@GetMapping("/login")
public String toLogin(HttpSession session){
if(session.getAttribute("user")!=null){
return "redirect:/";
}
return "login";
}
//跳转注册页面
@GetMapping("/register")
public String toRegister(){
return "register";
}
//跳转个人订单页面
@GetMapping("/{userName}/orders")
public String toOrderCenter(@PathVariable("userName") String userName,HttpSession session){
User user= (User) session.getAttribute("user");
if(user!=null && user.getUserName().equals(userName)){
return "user_orders";
}
return "redirect:/login";
}
//跳转购物车页面
@GetMapping("/{userName}/shopping_cart")
public String toUserShoppingCart(@PathVariable("userName") String userName,HttpSession session){
User user= (User) session.getAttribute("user");
if(user!=null && user.getUserName().equals(userName)){
return "shopping_cart";
}
return "redirect:/login";
}
}
*/
@GetMapping("/category")
@ResponseBody
public ResultVO getCategories() {
List<Category> categories = bookDisplayService.getAllCategories();
return new ResultVO(ResultCode.SUCCESS,categories);
}
/**
* 根据前台传来的categoryCode,响应对应的分类的书籍
* 需要进行分页响应
* 如果categoryCode为null,则响应所有书籍
* @param categoryCode 分类代码
* @param page 页码
* @param limit 每页的数量
* @return
*/
@GetMapping("/books")
@ResponseBody
public ResultVO getBooksByCategoryCode(@RequestParam(required = false) String categoryCode, @RequestParam(required = false) Integer page, @RequestParam(required = false) Integer limit) {
List<Book> books = bookDisplayService.getBooksByCategoryCode(page==null?1:page, limit==null?10:limit, categoryCode);
PageInfo pageInfo = new PageInfo(books); //获得分页信息
return new ResultVO(ResultCode.SUCCESS, (int) pageInfo.getTotal(),books);
}
/**
* 根据请求的bookId,返回该Id的书籍信息,响应Html视图
* @param bookId
* @return
*/
@GetMapping("/books/details/{bookId}")
public String bookDetailsView(@PathVariable("bookId") Integer bookId, Model model) {
Book book = bookDisplayService.getBookDetailsByBookId(bookId);
model.addAttribute("book", book);
return "details";
}
/**
* 首页根据书名搜索书籍
* @param bookName
* @return
*/
@GetMapping("/books/search")
return new ResultVO(ResultCode.SUCCESS, null);
}
//添加验证注解
@PostMapping("/insert")
public ResultVO bookInsert(@Valid Book record) {
int books = bookService.bookInsert(record);
return new ResultVO(ResultCode.SUCCESS, null);
}
@GetMapping("/searchcode")
public ResultVO bookSerchByCategoryCode(String catrgoryCode,Integer page,Integer limit) {
List<Book> books = bookService.bookSearchByCode(catrgoryCode,page,limit);
PageInfo pageInfo = new PageInfo(books);
if(books.size()!=0)
{
return new ResultVO(ResultCode.SUCCESS,(int)pageInfo.getTotal(), books);
}
else
return new ResultVO(ResultCode.RECORD_NOT_FOUND, null);
}
//添加验证注解
@PostMapping("/update")
public ResultVO bookUpdate(@Valid Book record) {
int books = bookService.bookUpdate(record);
return new ResultVO(ResultCode.SUCCESS, null);
}
/**
* 多条件搜索 ----by guozongchao
* @param book
* @param page
* @param limit
* @return
*/
@GetMapping("/search")
public ResultVO searchBooks(Book book,Integer page, Integer limit) {
if(book.getBookName().isEmpty()){
book.setBookName(null);
}
if(book.getIsbn().isEmpty()){
book.setIsbn(null);
}
List<Book> books = bookService.searchBooks(book, page, limit);
PageInfo pageInfo = new PageInfo(books);
return new ResultVO(ResultCode.SUCCESS, (int) pageInfo.getTotal(), books);
}
}
/**
* @Description: 首页商品展示模块控制器
*/
@Controller
@RequestMapping("/index")
public class BookDisplayController {
@Autowired
private BookDisplayService bookDisplayService;
/**
* 处理前台获取所有分类的请求
* @return
*/
@GetMapping("/category")
@ResponseBody
public ResultVO getCategories() {
List<Category> categories = bookDisplayService.getAllCategories();
return new ResultVO(ResultCode.SUCCESS,categories);
}
/**
* 根据前台传来的categoryCode,响应对应的分类的书籍
* 需要进行分页响应
* 如果categoryCode为null,则响应所有书籍
* @param categoryCode 分类代码
* @param page 页码
* @param limit 每页的数量
* @return
*/
@GetMapping("/books")
@ResponseBody
public ResultVO getBooksByCategoryCode(@RequestParam(required = false) String categoryCode, @RequestParam(required = false) Integer page, @RequestParam(required = false) Integer limit) {
List<Book> books = bookDisplayService.getBooksByCategoryCode(page==null?1:page, limit==null?10:limit, categoryCode);
PageInfo pageInfo = new PageInfo(books); //获得分页信息