package cn.liantao.lbook.controller;
import cn.liantao.lbook.entity.*;
import cn.liantao.lbook.service.OrderService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
import java.sql.Timestamp;
import java.text.SimpleDateFormat;
import java.util.Calendar;
import java.util.Date;
import java.util.LinkedList;
import java.util.List;
@RestController
@RequestMapping(value="/order")
public class OrderController {
// 创建连接数据库的接口实例
@Autowired
private OrderService orderService;
// 监听'/order/get' 返回相应用户的订单数据
@RequestMapping(value = "/get", method = RequestMethod.POST)
@ResponseBody
public List<List<Order>> getOrder(@RequestBody User user) {
String account = user.getAccount();
List<Order> orders_raw = orderService.getOrder(account);
List<List<Order>> orders = new LinkedList<>();
List<Order> list = new LinkedList<>();
if (orders_raw.size() > 0) {
int id = orders_raw.get(0).getId();
for (int i=0;i<orders_raw.size();i++){
if (orders_raw.get(i).getId() != id){
orders.add(list);
list = new LinkedList<>();
list.add(orders_raw.get(i));
id = orders_raw.get(i).getId();
} else {
list.add(orders_raw.get(i));
}
}
}
orders.add(list);
return orders;
}
// 监听'/order/getall' 返回所有用户的订单数据
@RequestMapping(value = "/getall", method = RequestMethod.GET)
@ResponseBody
public OrderList getAllOrders() {
List<Order> orders_raw = orderService.getAllOrders();
List<List<Order>> orders = new LinkedList<>();
List<Order> list = new LinkedList<>();
int id = orders_raw.get(0).getId().intValue();
for (int i=0;i<orders_raw.size();i++){
if (orders_raw.get(i).getId().intValue() != id){
orders.add(list);
list = new LinkedList<>();
list.add(orders_raw.get(i));
id = orders_raw.get(i).getId();
} else {
list.add(orders_raw.get(i));
}
}
orders.add(list);
OrderList result = new OrderList();
result.setOrders(orders);
return result;
}
// 监听'/order/add' 添加订单,写入数据库
@RequestMapping(value = "/add", method = RequestMethod.POST)
@ResponseBody
public List<Order> addOrder(@RequestBody Orders orders) {
int size = orders.getOrders().size();
for (int i=0;i<size;i++) {
Date date= new Date();
Timestamp timestamp = new Timestamp(date.getTime());
orders.getOrders().get(i).setDate(timestamp);
}
orderService.addOrder(orders.getOrders());
List<Order> result = orderService.getOrder(orders.getOrders().get(0).getAccount());
return result;
}
// 监听'/order/search' 接受一个参数 返回过滤后的订单数据
@RequestMapping(value = "/search", method = RequestMethod.GET)
@ResponseBody
public OrderList searchOrders(@RequestParam("filter") String filter) {
List<Order> orders_raw = orderService.searchOrder(filter);
List<List<Order>> orders = new LinkedList<>();
if (orders_raw.size() > 0) {
List<Order> list = new LinkedList<>();
int id = orders_raw.get(0).getId().intValue();
for (int i=0;i<orders_raw.size();i++){
if (orders_raw.get(i).getId().intValue() != id){
orders.add(list);
list = new LinkedList<>();
list.add(orders_raw.get(i));
id = orders_raw.get(i).getId();
} else {
list.add(orders_raw.get(i));
}
}
orders.add(list);
}
OrderList result = new OrderList();
result.setOrders(orders);
return result;
}
// 监听'/order/date' 返回日期筛选后的订单数据
@RequestMapping(value = "/date", method = RequestMethod.GET)
@ResponseBody
public List<DateOrder> dateFilter(@RequestParam("beginDate") String beginDate, @RequestParam("endDate") String endDate, @RequestParam("account") String account) {
// 将结束日期+1 便于sql操作
try {
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
Date date = format.parse(endDate);
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
calendar.add(Calendar.DAY_OF_MONTH, 1);
date = calendar.getTime();
endDate = format.format(date);
} catch (Exception e){
System.out.println(e);
}
return orderService.dateFilter(beginDate,endDate,account);
}
// 监听'/order/dateDetail' 返回日期筛选后的详细订单数据
@RequestMapping(value = "/dateDetail", method = RequestMethod.GET)
@ResponseBody
public List<DateOrder> dateDetailFilter(@RequestParam("beginDate") String beginDate, @RequestParam("endDate") String endDate, @RequestParam("account") String account) {
// 将结束日期+1 便于sql操作
try {
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
Date date = format.parse(endDate);
Calendar calendar = Calendar.getInstance();
calendar.setTime(date);
calendar.add(Calendar.DAY_OF_MONTH, 1);
date = calendar.getTime();
endDate = format.format(date);
} catch (Exception e){
System.out.println(e);
}
return orderService.dateDetailFilter(beginDate,endDate,account);
}
}
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
基于Vue+SpringBoot开发的网上书店系统源码+数据库+项目说明文档(课设项目毕设项目推荐).zip 【技术栈】 【后端】 Maven SpringBoot SpringActuator SpringSecurity MyBatis Jackson 【前端】 Vue ElementUI BootStrap Axios vuex vue-cli 数据库 MySQL mongoDB 【功能】 首页 登录,登出 书籍展示及详情 购物车 下单 个人订单 购买记录 【管理员功能】 书籍管理 用户权限 订单管理 搜索订单 订单统计 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用! 2、本项目适合计算机相关专业(如计科、人工智能、通信工程、自动化、电子信息等)的在校学生、老师或者企业员工下载使用,也适合小白学习进阶,当然也可作为毕设项目、课程设计、作业、项目初期立项演示等。 3、如果基础还行,也可在此代码基础上进行修改,以实现其他功能,也可直接用于毕设、课设、作业等。 欢迎下载,沟通交流,互相学习,共同进步!
资源推荐
资源详情
资源评论
收起资源包目录
基于Vue+SpringBoot开发的网上书店系统源码+数据库+项目说明文档(课设项目毕设项目推荐).zip (92个子文件)
sql
lbook.sql 3KB
项目说明.md 744B
L-book-server
mvnw.cmd 6KB
sql
create_table_users.sql 237B
create_database.sql 22B
create_table_orders.sql 560B
create_table_books.sql 320B
pom.xml 3KB
src
test
java
cn
liantao
lbook
service
UserServiceImplTest.java 75B
LBookApplicationTests.java 300B
main
resources
application-dev.yml 610B
mybatis
mapping
BookMapper.xml 3KB
UserMapper.xml 2KB
OrderMapper.xml 4KB
application.yml 175B
java
cn
liantao
lbook
mapper
OrderMapper.java 647B
UserMapper.java 567B
BookMapper.java 417B
security
MyUserDetailService.java 2KB
SecurityConfig.java 5KB
CustomAuthenticationFilter.java 2KB
controller
BookController.java 4KB
MailController.java 598B
UserController.java 4KB
OrderController.java 6KB
SrcController.java 3KB
service
OrderService.java 710B
UserService.java 884B
BookService.java 519B
UserServiceImpl.java 3KB
MailService.java 129B
BookServiceImpl.java 2KB
OrderServiceImpl.java 2KB
MailServiceImpl.java 1KB
LBookApplication.java 395B
entity
Book.java 391B
SecurityUser.java 1KB
DateOrder.java 482B
Orders.java 142B
Order.java 522B
LoginState.java 225B
OrderList.java 151B
UserState.java 170B
User.java 293B
util
Message.java 2KB
GetRequestJson.java 2KB
RandomNumber.java 323B
config
MongoConf.java 656B
META-INF
MANIFEST.MF 69B
.mvn
wrapper
maven-wrapper.properties 116B
maven-wrapper.jar 47KB
MavenWrapperDownloader.java 5KB
mvnw 9KB
.gitignore 277B
.idea
vcs.xml 367B
.gitignore 39B
readme_img
login.png 71KB
home.png 1.65MB
books.png 112KB
L-book-client
babel.config.js 53B
项目说明.md 437B
src
pages
About
About.vue 480B
Users
Users.vue 2KB
Login
Login.vue 15KB
Home
Home.vue 1KB
Search
Search.vue 2KB
Books
Books.vue 9KB
Statistics
Statistics.vue 9KB
Orders
Orders.vue 2KB
App.vue 2KB
store
modules
Orders.js 3KB
Books.js 656B
ShopCart.js 1KB
Person.js 708B
index.js 337B
main.js 475B
api
ajax.js 849B
index.js 3KB
components
Order
Order.vue 3KB
Book
Book.vue 15KB
ShopCart
ShopCart.vue 9KB
Navbar
Navbar.vue 5KB
router
index.js 2KB
package.json 1KB
public
book.png 6KB
css
bootstrap.min.css 141KB
index.html 672B
images
home.png 214KB
package-lock.json 378KB
index.html 612B
vue.config.js 425B
.gitignore 214B
共 92 条
- 1
资源评论
onnx
- 粉丝: 9492
- 资源: 5595
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功