上面我已经介绍过了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> 的配置与登录控件的一些操作。使用登录控件就可以轻松的解决了上诉的问题了