asp.net基于session实现购物车的方法
程序员文章站
2023-12-18 17:47:34
本文实例讲述了asp.net基于session实现购物车的方法。分享给大家供大家参考,具体如下:
//加入购物车
protected void linkbutt...
本文实例讲述了asp.net基于session实现购物车的方法。分享给大家供大家参考,具体如下:
//加入购物车 protected void linkbutton2_click(object sender, eventargs e) { datatable dt = null; //用户购买商品 如果 没有登录 则提示登录 if (session["username"] == null) { common.messagebox.showandredirectto(this.page, "请先登录 再购买商品!", "login.aspx"); } else { //如果己经登录 则根据接收过来的商品编号 根据该商品编号来获取该商品的详细信息(返回实体类) //返回信息有 商品编号 商品名称 商品市场价 商品的大小(siz) 图片(image) 重量 总价 购买数量 总共要支付的钱 商品总重量 model.product model = new model.product(); //根据商品编号 获取该商品详细信息 model.id =(int) request.querystring.getvalues("uid")[0]; system.data.sqlclient.sqldatareader sdr=dal.product.drpr(model); if (session["shopcar"] == null) { dt = new datatable(); //商品编号 dt.columns.add("id", typeof(int32)); //商品价格(本站价格) dt.columns.add("localprice", typeof(double)); //商品发布价格 dt.columns.add("posttime", typeof(string)); //购买数量 dt.columns.add("buycount", typeof(int32)); //商品总价 dt.columns.add("sumprice", typeof(int32)); //颜色 dt.columns.add("color", typeof(string)); //商品大小 dt.columns.add("size", typeof(string)); //商品名称 dt.columns.add("title", typeof(string)); //商品类型 dt.columns.add("cate", typeof(string)); //商品图片 dt.columns.add("image", typeof(string)); //商品时间 dt.columns.add("only", typeof(string)); //商品重量 dt.columns.add("weight", typeof(string)); //商品总重量 dt.columns.add("sumweight", typeof(string)); } else { //如果购物车不为空时 刚判断 该商品的信息是否存在购物车中 如果 存在则 把该商品的数量加上1 dt = session["shopcar"] as datatable; for (int j = 0; j < dt.rows.count; j++) { //如果读到该商品的编号 则该商品己经存在 则将该商品的数量加1 if (dt.rows[j]["id"].tostring() = model.id.tostring() && convert.tostring(dt.rows[i]["color"]) == d_color.text) { //如果商品 己经存在 则购买数量加上1 dt.rows[j]["buycount"] = convert.toint32(dt.rows[j]["buycount"]) + 1; //session保存购物车 session["shopcar"] = dt; response.redirect("shoppingcar.aspx"); return; } } } //如果该商品信息不存在 购物车中 则添加一个新的商品信息 datarow row = dt.newrow(); if (dr.read()) { //商品的重量 row["weight"] = sdr["_weight"].tostring(); //商品的总重量 row["sumweight"] = sdr["_weight"].tostring(); //商品购买 时间 row["only"] = datetime.now.tostring("yyyymmddhhmmssfff"); //商品型号 row["size"] = _size.text; //商品图片 row["image"] = image_1.imageurl; //商品类型名称 row["cate"] = cate_name.text; //商品名称 row["title"] = title_l.text; //商品颜色 row["color"] = d_color.text; //商品编号 row["id"] = convert.toint32(dr["_id"].tostring()); //商品本站价格 row["localprice"] = convert.todouble(sdr["_localprice"].tostring()); //商品发布时间 row["posttime"] = convert.tostring(sdr["_posttime"].tostring()); //购买数量 默认为1 row["buycount"] = 1; //商品总价 row["sumprice"] = convert.todouble(sdr["_localprice"].tostring()); dt.rows.add(row); } dr.close(); //保存商品信息 session["dt"] = dt; response.redirect("shoplist.aspx"); } } //获取商品信息 (商品总重量 总价格) private void getcountinfo() { datatable dt = null; if (session["shopcar"] != null) { //显示提示信息 label1.visible = true; } else { dt = session["shopcar"] as datatable; for (int j = 0; j < dt.rows.count; j++) { //获取单个商品的总价(计算公式:商品的数量 乘以商品的价格) dt.rows[j]["sumprice"] = convert.toint32(dt.rows[j]["localprice"]*convert.toint32(dt.rows[j]["buycount"])); //获取单个商品的总重量 (计算公式:购买的商品数量 乘以商品的单个重量) dt.rows[j]["sumweight"] = convert.toint32(dt.rows[j]["weight"] * convert.toint32(dt.rows[j]["buycount"])); //保存信息 session["shopcar"] = dt; //显示用户购物车的所有商品信息 showshoppingcarinfo(); } } } /// <summary> /// 显示购买的商品信息 /// </summary> private void showshoppingcarinfo() { datatable dt = null; //定义获取商品总价格 变量 double wholeprice = 0; //定义获取商品的总重量 变量 double wholeweight = 0; //用户己经购买 if (session["shopcar"] != null) { dt = session["shopcar"] as datatable; for (int j = 0; j < dt.rows.count; j++) { //获取所有商品 总价格 wholeprice += convert.todouble(dt.rows[j]["sumprice"]); //获取商品的 总重量 wholeweight += convert.todouble(dt.rows[j]["sumweight"]); } //总价格 wprice.text = wholeprice.tostring(); //总重量 wweight.text = wholeweight.tostring(); //保存商品总价格 session["wholeprice"] = wholeprice; //保存商品 总重量 session["wholeweight"] = wholeweight; //商品总项数 wholeprocount.text = convert.tostring(dt.rows.count); //保存商品的总项 session["wholeprocount"] = wholeprocount.text; //如果项数为空时 if (dt.rows.count == 0) { //显示用户未购买商品 label1.visible = true; } } else { //如果没有购买商品 则显示提示信息 label1.visible = true; gridview1.datasource = null; gridview1.databind(); } }
从购物车移除一件商品:row_command
if(e.commandname=="del") { datatable dt=session["shopcar"] as datatable; for(int j=0;j<dt.rows.count;j++){ if(dt.rows[j]["only"]==e.commandargument) { dt.rows.remove(j); } } }
希望本文所述对大家asp.net程序设计有所帮助。