一,解决上期乱码问题
分析乱码问题:
传递到后台的值,乱码的原因可能有两种
1、前台-->浏览器那一端就已经产生了乱码
2、后端-->在子控制器接受前端传递到后台的过程中出现乱码
上期乱码的根本原因:
就是前台正常的字符串传递到后台,出现了乱码
意味着中间做了编码的转换(编码解码)
因此猜想是过滤器(EncodingFiter)的问题:
修改util包中的EncodingFiter,注掉不需要部分就可以了
/**
* 中文乱码处理
*
*/
@WebFilter(filterName = "encodingFiter",urlPatterns = "/*")
public class EncodingFiter implements Filter {
private String encoding = "UTF-8";// 默认字符集
public EncodingFiter() {
super();
}
public void destroy() {
}
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain) throws IOException, ServletException {
HttpServletRequest req = (HttpServletRequest) request;
HttpServletResponse res = (HttpServletResponse) response;
// 中文处理必须放到 chain.doFilter(request, response)方法前面
res.setContentType("text/html;charset=" + this.encoding);
if (req.getMethod().equalsIgnoreCase("post")) {
req.setCharacterEncoding(this.encoding);
}
// 这一串不需要
/*else {
Map map = req.getParameterMap();// 保存所有参数名=参数值(数组)的Map集合
Set set = map.keySet();// 取出所有参数名
Iterator it = set.iterator();
while (it.hasNext()) {
String name = (String) it.next();
String[] values = (String[]) map.get(name);// 取出参数值[注:参数值为一个数组]
for (int i = 0; i < values.length; i++) {
values[i] = new String(values[i].getBytes("ISO-8859-1"),
this.encoding);
}
}
}*/
chain.doFilter(request, response);
}
public void init(FilterConfig filterConfig) throws ServletException {
String s = filterConfig.getInitParameter("encoding");// 读取web.xml文件中配置的字符集
if (null != s && !s.trim().equals("")) {
this.encoding = s.trim();
}
}
}
结果:
二,结算
1、购物车结算思路分析
操作两张表的数据:订单表、订单项表
功能:
①、点击去结算的按钮,对应弹出模态框
②、点击模态框确定的按钮,将购物车中的数据(订单表的数据以及订单项表的数据)一并提交到后台
2、增加订单类和订单项类
订单实体类
public class Order {
private long id;
private long uid;
private Date orderTime;
private String consignee;
private String phone;
private String postalcode;
private String address;
private int sendType;
private Date sendTime;
private float orderPrice;
private int orderState;
订单项实体类
public class OrderItem {
private long id;
private long oid;
private String bid;
private int quantity;
3、购物车结算生成订单和生成订单项方法
3.1,增加订单、按照订单时间倒序查询
按照订单时间倒序查询:需要设置当前订单项是属于哪个订单的,思路是查询出最新订单的id
按照订单时间进行倒序查询,取第一条数据即可
orderDao:
public class OrderDao extends BaseDao<Order>{
/**
* 购物车结算生成订单
* @param order
* @throws Exception
*/
public void add(Order order) throws Exception {
String sql="insert into t_easyui_order(uid,orderTime,consignee,phone,postalcode,address,sendType,sendTime,orderPrice,orderState) values(?,now(),?,?,?,?,?,?,?,?)";
super.executeUpdate(sql, order, new String[] {"uid","consignee","phone","postalcode","address","sendType","sendTime","orderPrice","orderState"});
}
/**
* 按照订单时间倒序查询
* @param order
* @param pageBean
* @return
* @throws Exception
*/
public List<Order> list( Order order, PageBean pageBean) throws Exception {
String sql="select * from t_easyui_order order by orderTime desc";
return super.executeQuery(sql, Order.class, pageBean);
}
3.2,生成订单项方法OrderItemDao
public class OrderItemDao extends BaseDao<OrderItem>{
/**
* 购物车结算生成订单项
* @param OrderItem
* @throws Exception
*/
public void add(OrderItem orderItem) throws Exception {
String sql="insert into t_easyui_orderitem(oid,bid,quantity) values(?,?,?)";
super.executeUpdate(sql, orderItem, new String[] {"oid","bid","quantity"});
}
}
4、BookDao写修改销量方法
当购买书籍后,对应书籍销量增加
/**
* 根据书籍的名称(唯一)修改销量的方法
* @param book
* @throws Exception
*/
public void editSales(Book book) throws Exception {
String sql="update t_easyui_book set sales=sales+? where name=?";
super.executeUpdate(sql, book, new String[] {"sales","name"});
}
子控制器
// 当前书籍被购买,那么这本书的销量就应该+被卖的书Quantity
Book b=new Book();
b.setName(itemEle[0]);
b.setSales(Integer.valueOf(itemEle[2]));
bd.editSales(b);
5、ShoppingAction (订单入库以及订单项入库)
public class ShoppingAction extends ActionSupport implements ModelDriver<ShoppingVo>{
ShoppingVo sv=new ShoppingVo();
private OrderDao od=new OrderDao();
private OrderItemDao oid=new OrderItemDao();
@Override
public ShoppingVo getModel() {
// TODO Auto-generated method stub
return sv;
}
public void createOrder(HttpServletRequest req, HttpServletResponse resp) {
// 获取uid
User cuser=(User) req.getSession().getAttribute("cuser");
// 必须登录,不登录就结束
if(cuser==null) {
return;
}
// 组装数据
Order order=new Order();
order.setAddress(sv.getAddress());
order.setConsignee(sv.getConsignee());
// 订单价格总计
float orderPrice=0f;
String pageStr=sv.getPageStr();
if(StringUtils.isNotBlank(pageStr)&& pageStr.length()>1) {
for(String item:pageStr.substring(1).split(",")) {
String[] itemEle = item.split("-");
orderPrice+=Float.valueOf(itemEle[3]);
}
}
order.setOrderPrice(orderPrice);
order.setOrderState(1);
order.setPhone(sv.getPhone());
order.setPostalcode(sv.getPostalcode());
order.setSendType(sv.getSendType());
order.setUid(cuser.getId());
try {
// 订单数据入库
od.add(order);
// 订单项数据入库
Order newest = od.list(null, null).get(0);
if(StringUtils.isNotBlank(pageStr)&& pageStr.length()>1) {
for(String item:pageStr.substring(1).split(",")) {
OrderItem oi=new OrderItem();
String[] itemEle = item.split("-");
oi.setBid(itemEle[0]);
// 需要设置当前订单项是属于哪个订单的
// 思路:查询出最新订单的id,按照订单时间进行倒序查询,取第一条数据即可
oi.setOid(newest.getId());
oi.setQuantity(Integer.valueOf(itemEle[2]));
oid.add(oi);
}
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
效果展示:
最后一格销量发生改变