asp.net基于session实现购物车的方法

本文实例讲述了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程序设计有所帮助。

(0)

相关推荐

  • ASP.NET中在一般处理程序中使用session的简单介绍

    复制代码 代码如下: <%@ WebHandler Language="C#" Class="ChangePwd" %> using System; using System.Web; using System.Web.SessionState; public class ChangePwd : IHttpHandler, IReadOnlySessionState { public void ProcessRequest (HttpContext co

  • Asp.Net程序目录下文件夹或文件操作导致Session失效的解决方案

    1.配置web.config <system.web> <sessionState mode="StateServer" stateConnectionString="tcpip=127.0.0.1:42424" sqlConnectionString="data source=127.0.0.1;Trusted_Connection=yes" cookieless="false" timeout="

  • ASP.NET 程序中删除文件夹导致session失效问题的解决办法分享

    在Global中  Application_Start 添加 如: 复制代码 代码如下: void Application_Start(object sender, EventArgs e)    {        //在应用程序启动时运行的代码        System.Reflection.PropertyInfo p = typeof(System.Web.HttpRuntime).GetProperty("FileChangesMonitor", System.Reflect

  • ASP.NET ASHX中获得Session的方法

    1-在 aspx和aspx.cs中,都是以Session["xxx"]="aaa"和aaa=Session["xxx"].ToString()进行读写. 而在ashx中,Session都要使用context.Session,读写方法是这样的: context.Session["xxx"]="aaa"和aaa=context.Session["xxx"].ToString() 2-在ash

  • asp.net 删除项目文件/文件夹IIS重启,Session丢失问题

    仔细一看,SSO返回的ticket也不相同,才发现原来IIS重启了,最后解决方案如下: 新建一个类继承IHttpModule 复制代码 代码如下: /// <summary> /// Stops the ASP.NET AppDomain being restarted (which clears /// Session state, Cache etc.) whenever a folder is deleted. /// </summary> public class Stop

  • 实现Asp与Asp.Net共享Session的方法

    <iframe align="top" marginwidth="0" marginheight="0" src="http://www.zealware.com/46860.html" frameborder="0" width="468" scrolling="no" height="60"></iframe> 在.ne

  • ASP.NET 使用application与session对象写的简单聊天室程序

    ASP.Net中有两个重要的对象,一个是application对象,一个是session对象. Application:记录应用程序参数的对象,该对象用于共享应用程序级信息. Session:记录浏览器端的变量对象,用来存储跨网页程序程序的变量或者对象. 说实话,写了快一年的asp.net,application对象还真没怎么用过.看了看书,根据这两个对象的特性写了一个简单的聊天室程序.真的是非常的简陋. 我的思路是,有两个页面Default页和ChatRoom页,页面布局如图: Default

  • asp.net基于session实现购物车的方法

    本文实例讲述了asp.net基于session实现购物车的方法.分享给大家供大家参考,具体如下: //加入购物车 protected void LinkButton2_Click(object sender, EventArgs e) { DataTable dt = null; //用户购买商品 如果 没有登录 则提示登录 if (Session["userName"] == null) { Common.MessageBox.ShowAndRedirectTo(this.Page,

  • asp.net基于HashTable实现购物车的方法

    本文实例讲述了asp.net基于HashTable实现购物车的方法.分享给大家供大家参考,具体如下: //用户购买商品时 if (e.CommandName.ToLower() == "buy") { //判断用户购物车是否为空 如果为空则分配一个 Hashtable table; if (Session["car"] == null) { table = new Hashtable(); } else { //用户购物车己存在 则取出数据 table = Sess

  • Java Web基于Session的登录实现方法

    本文实例讲述了Java Web基于Session的登录实现方法.分享给大家供大家参考,具体如下: package cn.com.login; import java.io.IOException; import java.io.PrintWriter; import java.util.ArrayList; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpSer

  • 基于Session的国际化实现方法

    如何将我们网站的其它内容(如菜单.标题等)做国际化处理呢?这就是本篇要将的内容->国际化. 在项目的spring.xml文件添加的内容如下 <mvc:interceptors> <span style="white-space:pre"> </span><!-- 国际化操作拦截器 如果采用基于(请求/Session/Cookie)则必需配置 --> <bean class="org.springframework.w

  • asp.net session丢失的解决方法小结

    现在我就把原因和解决办法写出来. ASP.NET Session丢失原因: 由于Asp.net程序是默认配置,所以Web.Config文件中关于Session的设定如下: < sessionState mode='InProc' stateConnectionString='tcpip=127.0.0.1:42424' sqlConnectionString='data source=127.0.0.1;Trusted_Connection=yes' cookieless='true' time

  • Java Web开发之基于Session的购物商店实现方法

    本文实例讲述了Java Web开发之基于Session的购物商店实现方法.分享给大家供大家参考,具体如下: package cn.com.shopping; import java.io.IOException; import java.util.ArrayList; import java.util.List; import javax.servlet.ServletException; import javax.servlet.http.HttpServlet; import javax.s

  • Asp.Net Core中基于Session的身份验证的实现

    在Asp.Net框架中提供了几种身份验证方式:Windows身份验证.Forms身份验证.passport身份验证(单点登录验证). 每种验证方式都有适合它的场景: 1.Windowss身份验证通常用于企业内部环境,Windows Active Directory就是基于windows平台的身份验证实现: 2.Forms身份验证是Asp.Net框架中提出的另一种验证方式: 3.passport身份验证是微软提供的基于自己的lives账号实现的单点认证服务. Asp.net Core验证码登录遇到

  • c#利用Session对象实现购物车的方法示例

    本文实现了c# Session对象实现购物车的方法,分享给大家,也给自己留个笔记: //shopcart.aspx.cs using System; using System.Data; using System.Configuration; using System.Collections; using System.Web; using System.Web.Security; using System.Web.UI; using System.Web.UI.WebControls; usi

  • jQuery基于json与cookie实现购物车的方法

    本文实例讲述了jQuery基于json与cookie实现购物车的方法.分享给大家供大家参考,具体如下: json 格式: [{'ProductID':ABC','Num':'1'},{'ProductID':DEF,'Num':'2'}] 这里使用到了 $.cookie这个插件.这个插件的代码在文章的最后 /* 添加商品及数量到购物车cookie中,返回当前商品在cookie中的总数 */ function AddToShoppingCar(id, num) { var _num = 1; if

  • asp.net基于Web Service实现远程上传图片的方法

    本文实例讲述了asp.net基于Web Service实现远程上传图片的方法.分享给大家供大家参考,具体如下: 页面调用代码: 前提添加Web 引用 HttpFileCollection files = HttpContext.Current.Request.Files; string filePath = files[0].FileName; string fileName = filePath.Substring(filePath.LastIndexOf("//") + 1); b

随机推荐