步骤 2 : 模仿和排错 步骤 3 : 我的订单页 步骤 4 : OrderDAO 步骤 5 : OrderService 步骤 6 : bought.html 步骤 7 : boughtPage.html 步骤 8 : modal4deleteConfirm.html 步骤 9 : ForeRESTController.bought()
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
package com.how2java.tmall.dao;
import java.util.List;
import org.springframework.data.jpa.repository.JpaRepository;
import com.how2java.tmall.pojo.Order;
import com.how2java.tmall.pojo.User;
public interface OrderDAO extends JpaRepository<Order,Integer>{
public List<Order> findByUserAndStatusNotOrderByIdDesc(User user, String status);
}
package com.how2java.tmall.dao; import java.util.List; import org.springframework.data.jpa.repository.JpaRepository; import com.how2java.tmall.pojo.Order; import com.how2java.tmall.pojo.User; public interface OrderDAO extends JpaRepository<Order,Integer>{ public List<Order> findByUserAndStatusNotOrderByIdDesc(User user, String status); }
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
package com.how2java.tmall.service;
import com.how2java.tmall.dao.OrderDAO;
import com.how2java.tmall.pojo.Order;
import com.how2java.tmall.pojo.OrderItem;
import com.how2java.tmall.pojo.User;
import com.how2java.tmall.util.Page4Navigator;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;
import org.springframework.data.domain.Pageable;
import org.springframework.data.domain.Sort;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Propagation;
import org.springframework.transaction.annotation.Transactional;
import java.util.List;
@Service
public class OrderService {
public static final String waitPay = "waitPay";
public static final String waitDelivery = "waitDelivery";
public static final String waitConfirm = "waitConfirm";
public static final String waitReview = "waitReview";
public static final String finish = "finish";
public static final String delete = "delete";
@Autowired OrderDAO orderDAO;
@Autowired OrderItemService orderItemService;
public Page4Navigator<Order> list(int start, int size, int navigatePages) {
Sort sort = new Sort(Sort.Direction.DESC, "id");
Pageable pageable = new PageRequest(start, size,sort);
Page pageFromJPA =orderDAO.findAll(pageable);
return new Page4Navigator<>(pageFromJPA,navigatePages);
}
public void removeOrderFromOrderItem(List<Order> orders) {
for (Order order : orders) {
removeOrderFromOrderItem(order);
}
}
private void removeOrderFromOrderItem(Order order) {
List<OrderItem> orderItems= order.getOrderItems();
for (OrderItem orderItem : orderItems) {
orderItem.setOrder(null);
}
}
public Order get(int oid) {
return orderDAO.findOne(oid);
}
public void update(Order bean) {
orderDAO.save(bean);
}
@Transactional(propagation= Propagation.REQUIRED,rollbackForClassName="Exception")
public float add(Order order, List<OrderItem> ois) {
float total = 0;
add(order);
if(false)
throw new RuntimeException();
for (OrderItem oi: ois) {
oi.setOrder(order);
orderItemService.update(oi);
total+=oi.getProduct().getPromotePrice()*oi.getNumber();
}
return total;
}
public void add(Order order) {
orderDAO.save(order);
}
public List<Order> listByUserWithoutDelete(User user) {
List<Order> orders = listByUserAndNotDeleted(user);
orderItemService.fill(orders);
return orders;
}
public List<Order> listByUserAndNotDeleted(User user) {
return orderDAO.findByUserAndStatusNotOrderByIdDesc(user, OrderService.delete);
}
}
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org">
<head th:include="include/fore/header::html" ></head>
<body>
<div id="workingArea">
<div th:replace="include/fore/top::html" ></div>
<div th:replace="include/fore/simpleSearch::html" ></div>
<div th:replace="include/fore/cart/boughtPage::html" ></div>
<div th:replace="include/fore/modal4deleteConfirm::html" ></div>
<div th:replace="include/fore/footer::html" ></div>
</div>
</body>
</html>
<!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head th:include="include/fore/header::html" ></head> <body> <div id="workingArea"> <div th:replace="include/fore/top::html" ></div> <div th:replace="include/fore/simpleSearch::html" ></div> <div th:replace="include/fore/cart/boughtPage::html" ></div> <div th:replace="include/fore/modal4deleteConfirm::html" ></div> <div th:replace="include/fore/footer::html" ></div> </div> </body> </html>
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
<div th:fragment="html">
<script>
$(function(){
var data4Vue = {
uri:'forebought',
orders:[]
};
//ViewModel
var vue = new Vue({
el: '#workingArea',
data: data4Vue,
mounted:function(){ //mounted 表示这个 Vue 对象加载成功了
this.load();
},
methods: {
load:function(){
var url = this.uri;
axios.get(url).then(function(response) {
vue.orders = response.data;
vue.$nextTick(function(){
linkDefaultActions();
orderPageRegisterListeners();
})
});
}
}
});
})
var deleteOrder = false;
var deleteOrderid = 0;
function orderPageRegisterListeners(){
$("a[orderStatus]").click(function(){
var orderStatus = $(this).attr("orderStatus");
if('all'==orderStatus){
$("table[orderStatus]").show();
}
else{
$("table[orderStatus]").hide();
$("table[orderStatus="+orderStatus+"]").show();
}
$("div.orderType div").removeClass("selectedOrderType");
$(this).parent("div").addClass("selectedOrderType");
});
$("a.deleteOrderLink").click(function(){
deleteOrderid = $(this).attr("oid");
deleteOrder = false;
$("#deleteConfirmModal").modal("show");
});
$("button.deleteConfirmButton").click(function(){
deleteOrder = true;
$("#deleteConfirmModal").modal('hide');
});
$('#deleteConfirmModal').on('hidden.bs.modal', function (e) {
if(deleteOrder){
var uri = "foredeleteOrder?oid="+deleteOrderid;
axios.put(uri).then(function(response){
if(0==response.data.code){
$("table.orderListItemTable[oid="+deleteOrderid+"]").hide();
}
else{
location.href="login";
}
});
}
})
}
</script>
<div class="boughtDiv">
<div class="orderType">
<div class="selectedOrderType"><a orderStatus="all" href="#nowhere">所有订单</a></div>
<div><a orderStatus="waitPay" href="#nowhere">待付款</a></div>
<div><a orderStatus="waitDelivery" href="#nowhere">待发货</a></div>
<div><a orderStatus="waitConfirm" href="#nowhere">待收货</a></div>
<div><a orderStatus="waitReview" href="#nowhere" class="noRightborder">待评价</a></div>
<div class="orderTypeLastOne"><a class="noRightborder"> </a></div>
</div>
<div style="clear:both"></div>
<div class="orderListTitle">
<table class="orderListTitleTable">
<tr>
<td>宝贝</td>
<td width="100px">单价</td>
<td width="100px">数量</td>
<td width="120px">实付款</td>
<td width="100px">交易操作</td>
</tr>
</table>
</div>
<div class="orderListItem">
<table v-for="o in orders" class="orderListItemTable" :orderStatus="o.status" :oid="o.id">
<tr class="orderListItemFirstTR">
<td colspan="2">
<b>{{o.createDate | formatDateFilter('YYYY-MM-DD') }}</b>
<span>订单号: {{o.orderCode}}
</span>
</td>
<td colspan="2"><img width="13px" src="img/site/orderItemTmall.png">天猫商场</td>
<td colspan="1">
<a class="wangwanglink" href="#nowhere">
<div class="orderItemWangWangGif"></div>
</a>
</td>
<td class="orderItemDeleteTD">
<a class="deleteOrderLink" :oid="o.id" href="#nowhere">
<span class="orderListItemDelete glyphicon glyphicon-trash"></span>
</a>
</td>
</tr>
<tr class="orderItemProductInfoPartTR" v-for="oi,index in o.orderItems" >
<td class="orderItemProductInfoPartTD"><img width="80" height="80" :src="'img/productSingle_middle/'+oi.product.firstProductImage.id+'.jpg'"></td>
<td class="orderItemProductInfoPartTD">
<div class="orderListItemProductLinkOutDiv">
<a :href="'product?pid='+oi.product.id">{{oi.product.name}}</a>
<div class="orderListItemProductLinkInnerDiv">
<img src="img/site/creditcard.png" title="支持信用卡支付">
<img src="img/site/7day.png" title="消费者保障服务,承诺7天退货">
<img src="img/site/promise.png" title="消费者保障服务,承诺如实描述">
</div>
</div>
</td>
<td class="orderItemProductInfoPartTD" width="100px">
<div class="orderListItemProductOriginalPrice">¥{{oi.product.originalPrice|formatMoneyFilter}}</div>
<div class="orderListItemProductPrice">¥{{oi.product.promotePrice|formatMoneyFilter}}</div>
</td>
<template v-if="index==0">
<td valign="top" :rowspan="o.orderItems.length" class="orderListItemNumberTD orderItemOrderInfoPartTD" width="100px">
<span class="orderListItemNumber">{{o.totalNumber}}</span>
</td>
<td valign="top" :rowspan="o.orderItems.length" width="120px" class="orderListItemProductRealPriceTD orderItemOrderInfoPartTD">
<div class="orderListItemProductRealPrice">¥ {{o.total|formatMoneyFilter}}</div>
<div class="orderListItemPriceWithTransport">(含运费:¥0.00)</div>
</td>
<td valign="top" :rowspan="o.orderItems.length" class="orderListItemButtonTD orderItemOrderInfoPartTD" width="100px">
<a v-if="o.status=='waitConfirm'" :href="'confirmPay?oid='+o.id">
<button class="orderListItemConfirm">确认收货</button>
</a>
<a v-if="o.status=='waitPay'" :href="'alipay?oid='+o.id+'&total='+o.total">
<button class="orderListItemConfirm">付款</button>
</a>
<div v-if="o.status=='waitDelivery'">
<span>待发货</span>
</div>
<a v-if="o.status=='waitReview'" :href="'review?oid='+o.id">
<button class="orderListItemReview">评价</button>
</a>
</td>
</template>
</tr>
</table>
</div>
</div>
</div>
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
<div th:fragment="html" >
<div class="modal" id="deleteConfirmModal" tabindex="-1" role="dialog" >
<div class="modal-dialog deleteConfirmModalDiv">
<div class="modal-content">
<div class="modal-header">
<button data-dismiss="modal" class="close" type="button"><span aria-hidden="true">×</span><span class="sr-only">Close</span></button>
<h4 class="modal-title">确认删除?</h4>
</div>
<div class="modal-footer">
<button data-dismiss="modal" class="btn btn-default" type="button">关闭</button>
<button class="btn btn-primary deleteConfirmButton" id="submit" type="button">确认</button>
</div>
</div>
</div>
</div>
</div>
<div th:fragment="html" > <div class="modal" id="deleteConfirmModal" tabindex="-1" role="dialog" > <div class="modal-dialog deleteConfirmModalDiv"> <div class="modal-content"> <div class="modal-header"> <button data-dismiss="modal" class="close" type="button"><span aria-hidden="true">×</span><span class="sr-only">Close</span></button> <h4 class="modal-title">确认删除?</h4> </div> <div class="modal-footer"> <button data-dismiss="modal" class="btn btn-default" type="button">关闭</button> <button class="btn btn-primary deleteConfirmButton" id="submit" type="button">确认</button> </div> </div> </div> </div> </div>
增值内容,请先登录
完整的 Springboot 模仿天猫项目,使用 Springboot 、Vue.js、shiro、redis、elasticsearch 等一整套技术栈, 从无到有涵盖全部129个知识点,565个开发步骤, 充实 Springboot 项目经验,为简历加上一个有吸引力的砝码.
增值内容,点击购买
使用爬虫已经被系统记录,请勿使用爬虫,增大封号风险。 如果是误封 ,请联系站长,谢谢
@GetMapping("forebought")
public Object bought(HttpSession session) {
User user =(User) session.getAttribute("user");
if(null==user)
return Result.fail("未登录");
List<Order> os= orderService.listByUserWithoutDelete(user);
orderService.removeOrderFromOrderItem(os);
return os;
}
package com.how2java.tmall.web;
import com.how2java.tmall.comparator.*;
import com.how2java.tmall.pojo.*;
import com.how2java.tmall.service.*;
import com.how2java.tmall.util.Result;
import org.apache.commons.lang.math.RandomUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.*;
import org.springframework.web.util.HtmlUtils;
import javax.servlet.http.HttpSession;
import java.text.SimpleDateFormat;
import java.util.*;
@RestController
public class ForeRESTController {
@Autowired
CategoryService categoryService;
@Autowired
ProductService productService;
@Autowired
UserService userService;
@Autowired
ProductImageService productImageService;
@Autowired
PropertyValueService propertyValueService;
@Autowired
OrderItemService orderItemService;
@Autowired
ReviewService reviewService;
@Autowired
OrderService orderService;
@GetMapping("/forehome")
public Object home() {
List<Category> cs= categoryService.list();
productService.fill(cs);
productService.fillByRow(cs);
categoryService.removeCategoryFromProduct(cs);
return cs;
}
@PostMapping("/foreregister")
public Object register(@RequestBody User user) {
String name = user.getName();
String password = user.getPassword();
name = HtmlUtils.htmlEscape(name);
user.setName(name);
boolean exist = userService.isExist(name);
if(exist){
String message ="用户名已经被使用,不能使用";
return Result.fail(message);
}
user.setPassword(password);
userService.add(user);
return Result.success();
}
@PostMapping("/forelogin")
public Object login(@RequestBody User userParam, HttpSession session) {
String name = userParam.getName();
name = HtmlUtils.htmlEscape(name);
User user =userService.get(name,userParam.getPassword());
if(null==user){
String message ="账号密码错误";
return Result.fail(message);
}
else{
session.setAttribute("user", user);
return Result.success();
}
}
@GetMapping("/foreproduct/{pid}")
public Object product(@PathVariable("pid") int pid) {
Product product = productService.get(pid);
List<ProductImage> productSingleImages = productImageService.listSingleProductImages(product);
List<ProductImage> productDetailImages = productImageService.listDetailProductImages(product);
product.setProductSingleImages(productSingleImages);
product.setProductDetailImages(productDetailImages);
List<PropertyValue> pvs = propertyValueService.list(product);
List<Review> reviews = reviewService.list(product);
productService.setSaleAndReviewNumber(product);
productImageService.setFirstProdutImage(product);
Map<String,Object> map= new HashMap<>();
map.put("product", product);
map.put("pvs", pvs);
map.put("reviews", reviews);
return Result.success(map);
}
@GetMapping("forecheckLogin")
public Object checkLogin( HttpSession session) {
User user =(User) session.getAttribute("user");
if(null!=user)
return Result.success();
return Result.fail("未登录");
}
@GetMapping("forecategory/{cid}")
public Object category(@PathVariable int cid,String sort) {
Category c = categoryService.get(cid);
productService.fill(c);
productService.setSaleAndReviewNumber(c.getProducts());
categoryService.removeCategoryFromProduct(c);
if(null!=sort){
switch(sort){
case "review":
Collections.sort(c.getProducts(),new ProductReviewComparator());
break;
case "date" :
Collections.sort(c.getProducts(),new ProductDateComparator());
break;
case "saleCount" :
Collections.sort(c.getProducts(),new ProductSaleCountComparator());
break;
case "price":
Collections.sort(c.getProducts(),new ProductPriceComparator());
break;
case "all":
Collections.sort(c.getProducts(),new ProductAllComparator());
break;
}
}
return c;
}
@PostMapping("foresearch")
public Object search( String keyword){
if(null==keyword)
keyword = "";
List<Product> ps= productService.search(keyword,0,20);
productImageService.setFirstProdutImages(ps);
productService.setSaleAndReviewNumber(ps);
return ps;
}
@GetMapping("forebuyone")
public Object buyone(int pid, int num, HttpSession session) {
return buyoneAndAddCart(pid,num,session);
}
private int buyoneAndAddCart(int pid, int num, HttpSession session) {
Product product = productService.get(pid);
int oiid = 0;
User user =(User) session.getAttribute("user");
boolean found = false;
List<OrderItem> ois = orderItemService.listByUser(user);
for (OrderItem oi : ois) {
if(oi.getProduct().getId()==product.getId()){
oi.setNumber(oi.getNumber()+num);
orderItemService.update(oi);
found = true;
oiid = oi.getId();
break;
}
}
if(!found){
OrderItem oi = new OrderItem();
oi.setUser(user);
oi.setProduct(product);
oi.setNumber(num);
orderItemService.add(oi);
oiid = oi.getId();
}
return oiid;
}
@GetMapping("forebuy")
public Object buy(String[] oiid,HttpSession session){
List<OrderItem> orderItems = new ArrayList<>();
float total = 0;
for (String strid : oiid) {
int id = Integer.parseInt(strid);
OrderItem oi= orderItemService.get(id);
total +=oi.getProduct().getPromotePrice()*oi.getNumber();
orderItems.add(oi);
}
productImageService.setFirstProdutImagesOnOrderItems(orderItems);
session.setAttribute("ois", orderItems);
Map<String,Object> map = new HashMap<>();
map.put("orderItems", orderItems);
map.put("total", total);
return Result.success(map);
}
@GetMapping("foreaddCart")
public Object addCart(int pid, int num, HttpSession session) {
buyoneAndAddCart(pid,num,session);
return Result.success();
}
@GetMapping("forecart")
public Object cart(HttpSession session) {
User user =(User) session.getAttribute("user");
List<OrderItem> ois = orderItemService.listByUser(user);
productImageService.setFirstProdutImagesOnOrderItems(ois);
return ois;
}
@GetMapping("forechangeOrderItem")
public Object changeOrderItem( HttpSession session, int pid, int num) {
User user =(User) session.getAttribute("user");
if(null==user)
return Result.fail("未登录");
List<OrderItem> ois = orderItemService.listByUser(user);
for (OrderItem oi : ois) {
if(oi.getProduct().getId()==pid){
oi.setNumber(num);
orderItemService.update(oi);
break;
}
}
return Result.success();
}
@GetMapping("foredeleteOrderItem")
public Object deleteOrderItem(HttpSession session,int oiid){
User user =(User) session.getAttribute("user");
if(null==user)
return Result.fail("未登录");
orderItemService.delete(oiid);
return Result.success();
}
@PostMapping("forecreateOrder")
public Object createOrder(@RequestBody Order order,HttpSession session){
User user =(User) session.getAttribute("user");
if(null==user)
return Result.fail("未登录");
String orderCode = new SimpleDateFormat("yyyyMMddHHmmssSSS").format(new Date()) + RandomUtils.nextInt(10000);
order.setOrderCode(orderCode);
order.setCreateDate(new Date());
order.setUser(user);
order.setStatus(OrderService.waitPay);
List<OrderItem> ois= (List<OrderItem>) session.getAttribute("ois");
float total =orderService.add(order,ois);
Map<String,Object> map = new HashMap<>();
map.put("oid", order.getId());
map.put("total", total);
return Result.success(map);
}
@GetMapping("forepayed")
public Object payed(int oid) {
Order order = orderService.get(oid);
order.setStatus(OrderService.waitDelivery);
order.setPayDate(new Date());
orderService.update(order);
return order;
}
@GetMapping("forebought")
public Object bought(HttpSession session) {
User user =(User) session.getAttribute("user");
if(null==user)
return Result.fail("未登录");
List<Order> os= orderService.listByUserWithoutDelete(user);
orderService.removeOrderFromOrderItem(os);
return os;
}
}
HOW2J公众号,关注后实时获知最新的教程和优惠活动,谢谢。
问答区域
2020-10-04
bought.html没有任何订单展示出来啊
2 个答案
小笼包233 跳转到问题位置 答案时间:2020-11-13 这基本上是因为id没有查询到数据
how2j 跳转到问题位置 答案时间:2020-10-07 我这里显示正常呀,推荐使用步骤1,2 来定位下,看看是否是你哪里写漏了导致的呢
回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
2020-05-08
为什么要用模态窗体的事件呢
回答已经提交成功,正在审核。 请于 我的回答 处查看回答记录,谢谢
2020-02-10
我的订单页前端样式问题
2019-11-16
orderService获取方式问题
2019-06-04
少写代码,导致订单项不显示
提问太多,页面渲染太慢,为了加快渲染速度,本页最多只显示几条提问。还有 3 条以前的提问,请 点击查看
提问之前请登陆
提问已经提交成功,正在审核。 请于 我的提问 处查看提问记录,谢谢
|