jsp电子商务系统之六 订单篇1


常规一个商品一个订单

多个商品一个订单

订单只有提交才能结算


付款页面




代码实现,主要是Servlet代码和Service业务层的代码,此处业务层,对多个dao的操作更为明显,体现业务二字!!!

package com.cart.web;

import java.io.IOException;
import java.util.Date;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.cart.entity.Order;
import com.cart.entity.Userinfo;
import com.cart.service.OrderService;

public class OrderServlet extends HttpServlet {
	@Override
	protected void doGet(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
		//1.业务,将购物车中的数据删除,同时增加数据进订单表和订单详情表;
		String[]bids=req.getParameterValues("bid");
		StringBuilder sbbid=new StringBuilder();
		for(String bid:bids){
			sbbid.append(bid+",");
		}
		
		String sbid=sbbid.substring(0,sbbid.length()-1);
		
		//已经获取了你复选框的订单,到商品id数组中,此处是bids(大家可以是pids/gids等)
		OrderService orderService=new OrderService();
		
		Order order=new Order();
		Userinfo user=(Userinfo)req.getSession().getAttribute("userinfo");
		order.setUserid(user.getId());
		order.setContactphone(user.getPhone());
		order.setCreatetime(new Date());
		order.setTotal(Double.parseDouble(req.getParameter("total")));
		order.setShipaddress(user.getAddress());
		order.setStatus("未发货");
		
		//orderService.insertOrder(order); //保存订单;
		//让service继续去执行保存订单的操作;
		
		orderService.delCartAndSaveOrder(sbid,user,order);
	}
	
	@Override
	protected void doPost(HttpServletRequest req, HttpServletResponse resp)
			throws ServletException, IOException {
		this.doGet(req, resp);
	}
}

package com.cart.service;

import java.sql.*;
import com.cart.dao.*;
import com.cart.dao.impl.*;
import com.cart.entity.Order;
import com.cart.entity.Userinfo;
import com.cart.util.DaoFactory;

public class OrderService {
	//1.定义属性:对dao进行操作;
	OrderDao orderDao=new OrderDaoImpl();
	CartDao cartDao=new CartDaoImpl();
	//2.对订单,进行增删该查
	public void delCartAndSaveOrder(String sbid,Userinfo user,Order order){
		//使用事务操作,业务层可以这样操作,对不同的dao操作;
		Connection con=null;
		PreparedStatement pstmt=null;
		try{
			StringBuilder sbSql=new StringBuilder();
			sbSql.append("delete from cartitem where uid=? and bid in(");
			sbSql.append(sbid);
			sbSql.append(")");
			String sql=sbSql.toString();
			
			con=DaoFactory.getConnection();
			pstmt=con.prepareStatement(sql);
			con.setAutoCommit(false);//设置自动提交事务,为false
			orderDao.insertOrder(order);//调用插入订单方法;,同时删除原来的购物车数据方法;
			Object[] params={user.getId()};
			DaoFactory.setParams(pstmt, params);
			DaoFactory.executeUpdate(sql, params);
			
			//System.out.println(sbSql);
			
			con.commit();
			
		}catch(Exception e){
			e.printStackTrace();
		}finally{
			DaoFactory.closeAll(null, null, con);
		}
	}
	public int insertOrder(Order order){
		//ct.deletecartItem(uid, bid);
		return orderDao.insertOrder(order);
	}
	public int updateOrder(int id){
		return orderDao.updateOrder(id);
	}
	public int deleteOrder(int id){
		return orderDao.deleteOrder(id);
	}
	
	public Order findOrderById(int id){
		return orderDao.findOrderById(id);
	}
}



  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

teayear

读后有收获可以支付宝请作者喝咖

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

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

打赏作者

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

抵扣说明:

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

余额充值