Profile实现购物车(应用Profile)(转)

上面我已经介绍过了 Profile的配置和简单应用了,如果大家上面没有学会的话下面我在来做一下高级一点的应用,我会从一开始创建数据库与配置一步一步地在说一遍:

 

这们要完成一个这样的功能:一个购物车,能添加商品和删除商品的操作

 要一个描述商品的类 (ShopInfo.cs),一个购物车类 (ShopCart.cs),和一个页面显示商品信息 (default.aspx)

 

 

1.       这次我们先来创建数据库

在这个路径下: C:"WINDOWS"Microsoft.NET"Framework"v2.0.50727

v2.0.50727是跟据你的版本号解定的文件夹

这个下面有一个 aspnet_regsql.exe进行运行 -à 配置指定的数据库

Aspnet_regsql.exe- à 下一步 - à 下一步 ------ à 你的服务器的名字,用什么身份进行登录,可以在这里选择指定的数据库

这样就可以在指定的数据库中自动生成 profile与登录控件要用的表了

 

2.       项目中在 web.config中配置文件中配置 配置节

 2.1 数据连接字符串

< connectionStrings >

     < add name = "KuConnectionString " connectionString = "Data Source=localhost;Initial Catalog=ku;Integrated Security=True " providerName = "System.Data.SqlClient "/>

</ connectionStrings >

2.2 配置 profile 配置节

         < profile defaultProvider = "MySqlProfileProvider ">

              < providers >

                   < add name = "MySqlProfileProvider " connectionStringName = "KuConnectionString " applicationName = "/ " type = "System.Web.Profile.SqlProfileProvider, System.Web, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50a3a "/>

      </ providers >

      < properties >

        < add name = "userName " type = "system.string " serializeAs = "Binary "/>

        < add name = "cartShop " type = "ShopInfo " serializeAs = "Binary "/>

      </ properties >

         </ profile >

   </ system.web >

解释:

第一个 <properties> 配置节

defaultProvider = "MySqlProfileProvider "  为当前默认的<Profile>中的配置这里用的

是我们自己配置的MySqlProfileProvider

connectionStringName = "KuConnectionString " 为2.1中的name(是数据库连接字符串的name)

下一个< properties >

< add name = "userName " type = "system.string " serializeAs = "Binary "/>//type 为指定的类型 serializeAs="Binary" 以什么类型存储(这里用的是以二进制存储)

< add name = "cartShop " type = "ShopCart " serializeAs = "Binary "/>

这个type是我们要用到的购物车类名为这个类的类型,以二进制进行存储

 

3.       上面的是准备工作已经做好了那就开始做我们要实现的功能吧

3.1一个描述商品的一个类: ShopInfo.cs 这个类中只有一些商品的属性与它的 get,set方法

代码:

using System;

using System.Data;

using System.Configuration;

using System.Linq;

using System.Web;

using System.Web.Security;

using System.Web.UI;

using System.Web.UI.HtmlControls;

using System.Web.UI.WebControls;

using System.Web.UI.WebControls.WebParts;

using System.Xml.Linq;

[Serializable ]

/// <summary>

/// ShopInfo 的摘要说明

/// </summary>

public class ShopInfo

{

    private int _ID;//ID 商品的

    public int ID

    {

        get { return _ID; }

        set { _ID = value ; }

    }

    private string _Name;//Name 商品的名字

    public string Name

    {

        get { return _Name; }

        set { _Name = value ; }

    }

    private decimal _Price;//Price 商品的价格

    public decimal Price

    {

        get { return _Price; }

        set { _Price = value ; }

    }

    private int _Count = 1;//Count 商品的数量

 

    public int Count

    {

        get { return _Count; }

        set { _Count = value ; }

    }

// 构造方法

    public ShopInfo(int id,string name,decimal price) {

        _ID = id;

        _Name = name;

        _Price = price;

    }

}

3.2一个描述购物车类: ShopCart.cs 这个类中是用来操作买商品与删除商品一系列的操作,这里我们用的是 hashTable进行存储商品数据的

代码:

using System;

using System.Data;

using System.Configuration;

using System.Web.Security;

using System.Collections;

[Serializable ]

/// <summary>

/// ShopCart 的摘要说明

/// </summary>

public class ShopCart

{

     private Hashtable _HashShopCart = new Hashtable ();

     public ICollection HashShopCart

     {

        get

        {

            return _HashShopCart.Values;

        }

     }

     // 获取总价钱的属性

     public decimal Total

     {

         get

         {

             decimal sum = 0;

             foreach (ShopInfo shop in this .HashShopCart){

                 sum += shop.Count * shop.Price;

             }

             return sum;  

         }

     }

     // 添加方法

     public void ADDShop(int id,string name,decimal price)

     {  

        ShopInfo shopItem = (ShopInfo )_HashShopCart[id];//_HashShopCart[id];

        //1. 购物车中是否有这个数据有就Count++

        if (shopItem != null ){

           shopItem.Count++;

           _HashShopCart[id] = shopItem;

        }

        else //2. 没有就添加

        {

           _HashShopCart.Add(id,new ShopInfo (id,name,price));

        }

    }

 

    // 删除一个商品的方法

    public void Remove(int id)

    {

         ShopInfo shopItem =(ShopInfo ) _HashShopCart[id];

         //1. 判断有这件商品

         if (shopItem == null )

         {

            return ;

         }

         shopItem.Count--;

         //2. 减完看看数量是否为0 如果为0就删除这个

         if (shopItem.Count <= 0)

         {

              _HashShopCart.Remove(id);

         }

    }  

}   

4.       所有的都写好了现在就差显示页面了

一个显示商品的页面 default.aspx

   这里的数据我就不写了大致是:商品 id,商品名,商品价格

   之后呢,我用的是 GridView控件显示的 ,要在显示控件上加一个选择按钮,把这个文本改成‘购买‘ 要用这个选择按钮的选择事件: SelectedIndexChanged 在这个事件中写上:

获取选中行的数据;

int id = int .Parse(gvGoodsInfo.SelectedDataKey.Value.ToString());

        string name = gvGoodsInfo.SelectedRow.Cells[1].Text;

        string prices = gvGoodsInfo.SelectedRow.Cells[2].Text;

        decimal price = decimal .Parse(prices);

        // 开始放到Profile中(如果上面没有问题的话那你的数据库中就有选择的这些数据了)

        Profile.shopCart.ADDShop(id, name, price);

        BindShopCart();

非常简单吧:

还可以取出邦定到其它的控件就行显示如:

    private void BindShopCart()

    {

        if (Profile.shopCart == null )

        {

            Profile.shopCart = new ShopCart ();

        }

        gvShopCart.DataSource = Profile.shopCart.HashShopCart;

        gvShopCart.DataBind();       

}

在这个GridView控件上也加一个选择按钮进行删除商品的操作:

 protected void gvShopCart_SelectedIndexChanged(object sender, EventArgs e)

    {

        //gvShopCart 的选择事件(删除商品)

        string id = this .gvShopCart.SelectedDataKey.Value.ToString();

        Profile.shopCart.Remove(int .Parse(id));

        this .BindShopCart();

}

 

这样一个简单的购物车就完成了,上面的还有很多功能不完善,希望你们自己去完善一下。

虽然购物车已经实现了,但只能是一个匿名用户的购物车,如果是一个登录用户那用的时候只能是购买一件商品了,这样肯定是不行的,那要怎样解决它呢,下次介绍一下 < membership> 的配置与登录控件的一些操作。使用登录控件就可以轻松的解决了上诉的问题了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值