用ASP编写购物车代码

网上购物已成为生活的潮流,在网上购物之后,想要随时查看自己已买的东西,想要随时删除或改动某件商品数量,要怎么做呢?以下我就来写代码及释义。先来做用户登陆页面(login.asp):

<html>

<head>

<title>购物车的实现</title>

</head>

<body>

<formmethod="post"action="check.asp">

<tablewidth="200"border="1">

<tr><tdwidth="107">username:</td>

<tdwidth="77"><inputtype="text"name="username"id="username"/></td></tr>

<tr><td>password:</td>

<td><inputtype="password"name="userpass"id="userpass"/></td></tr>

<tr><tdcolspan="2"><inputtype="submit"value="登录"></td>

</tr>

</table>

</form>

</body>

</html>

然后来写接收用户所填写的信息以检查是否存在该用户的页面(check.asp),假设存在该用户,那么就跳到购物的首页(index.asp):

<%

uname=request.Form("username")

upass=request.Form("userpass")

sql="select*fromuserswhereuname='"&uname&"'andupass='"&upass&"'"

setrs=server.CreateObject("adodb.recordset")

rs.opensql,conn,3,1

ifnotrs.eofthen

用户登陆成功之后,将username放入session里,并给用户分配一个订单,就像去超市购物推着一个购物车,此时这个购物车是属于你的,用username和系统时间作为购物车的名字,然后跳转到购物首页。

session("name")=uname

session("orderid")=time&uname

response.Redirect("index.asp")

else

%>

<script>

alert("username或password不对!");

history.back();

</script>

<%

endif

rs.close

setrs=nothing

conn.close

setconn=nothing

%>

那么,接下来就是购物的首页(index.asp)了

<!--#includefile="inc/conn.asp"-->

<html>

<head>

以下用css样式表将表格里的字体统一设置为14号字

<styletype="text/css">‘

<!--

table{

font-size:14px;

}

-->

</style>

</head>

<body>

<%

假设用户没登陆就直接打开购物首页,那么就跳转到登陆页面

ifsession("name")=""then

response.Redirect("login.asp")

endif

%>

做一个搜索的文本框,方便用户搜索商品。其原理是这种:用户填入要搜索的商品后,通过表单提交到本页面,从数据库中查找像用户填写的字符串的商品,再显示出来

<formmethod="post"action="index.asp">

<inputtype="text"size="15"name="search"id="search"/><inputtype="submit"value="搜索"/>

</form>

<%

searchname=request.Form("search")‘得到用户填写的字符串

sql="select*fromproductswherepnamelike'%"&searchname&"%'"‘写sql语句,查找出结果

setrs=server.CreateObject("adodb.recordset")‘设置一个结果集对象

rs.opensql,conn,3,1

whilenotrs.eof‘循环输出商品的相关信息

%>

每一个商品以下都有一个购买button,须要做一个表单

<formmethod="post"action="buy.asp">

<tablestyle="float:left">

<tr>

<tdwidth="103"rowspan="3"><ahref="product.asp?id=<%=rs(0)%>"><imgsrc="images/<%=rs(2)%>"width="100"height="100"border="0"></a><inputtype="hidden"name="id"value="<%=rs(0)%>"><inputtype="hidden"name="price"value="<%=rs(3)%>"/></td>

<tdwidth="107">名称:

<%=rs(1)%></td>

</tr>

<tr>

<td>价格:<%=rs(3)%></td>

</tr>

<tr>

<tdalign="center"><inputtype="submit"name="buy"value="购买"/></td>

</tr>

</table>

</form>

<%

rs.movenext‘指向下一个记录

wend

rs.close

setrs=nothing

conn.close

setconn=nothing

%>

</body>

</html>

假设用户想要查看商品更具体的信息,那么就应该将商品图片做成一个超链接,连接到product.asp,在该页面显示具体信息。在该页面也有一个购买button,点击之后相同跳到buy.asp:

<!--#includefile="inc/conn.asp"-->

<body>

<%

pid=request.QueryString("id")

response.Write(pid)

sql="select*fromproductswherepid="&pid

setrs=server.CreateObject("adodb.recordset")

rs.opensql,conn,3,1

ifnotrs.eofthen

%>

<tablewidth="387"height="119">

<tr>

<tdwidth="120"rowspan="4"><imgsrc="images/<%=rs(2)%>"width="100"height="100"></td>

<tdwidth="276">名称:<%=rs(1)%></td>

</tr>

<tr>

<td>价格:<%=rs(3)%></td>

</tr>

<tr>

<tdheight="30"><%=rs(4)%></td>

</tr>

<tr>

<tdalign="center"><inputtype="button"οnclick="javascript:location.href='buy.asp?id=<%=rs(0)%>&price=<%=rs(3)%>'"value="购买"></td>‘点击购买之后触发一个onclick事件,跳转到buy.asp

</tr>

</table>

<%

endif

rs.close

setrs=nothing

conn.close

setconn=nothing

%>

</body>

</html>

用户点击了购买以后,将该商品的id传到buy.asp,以下来写buy.asp的代码:

<!--#includefile="inc/conn.asp"-->‘将连接数据库的字符串包括进来

<%

pid=request("id")‘得到商品的id

price=request("price")‘得到商品的价格

sql="select*frommrcarwherepid="&pid&"andorderid='"&session("orderid")&"'"‘写sql语句来查询

setrs=server.CreateObject("adodb.recordset")

rs.opensql,conn,3,1

假设用户所要购买的商品已经买过,那么就直接在原来的基础上加1,否则的话,就插入记录

ifnotrs.eofthen

sql="updatemrcarsetpcount=pcount+1wherepid='"&pid&"'andorderid='"&session("orderid")&"'"

conn.executesql

response.Redirect("mycar.asp")

else

sql="insertintomrcar(orderid,pid,price,pcount)values('"&session("orderid")&"',"&pid&","&price&",1)"

conn.executesql

response.Redirect("mycar.asp")

endif

rs.close

setrs=nothing

conn.close

setconn=nothing

%>

运行完了sql语句之后将跳转到购物车页面(mycar.asp),显示出用户所购买的商品。而且有改动数量的button和删除的超链接

<!--#includefile="inc/conn.asp"-->

<%

sql="selecta.*,b.pnamefrommrcara,productsbwhereorderid='"&session("orderid")&"'anda.pid=b.pid"

setrs=server.CreateObject("adodb.recordset")

rs.opensql,conn,3,1

%>

<formmethod="post"action="update.asp"name="form1">

<tableborder="1">

<tr><td>orderid</td>

<td>商品名称</td>

<td>商品id</td>

<td>单位价格</td>

<td>数量</td>

<td>删除</td>

<td>改动</td>

</tr>

<%

sum=0

i=1‘这里的i值到后边有介绍

whilenotrs.eof‘将所购买的商品循环输出

%>

<tr><td><%=session("orderid")%></td>

<td><%=rs("pname")%></td>

<td><%=rs(1)%></td>

<td><%=rs(2)%></td>

<td><inputtype="text"size="10"value="<%=rs(3)%>"name="pcount"></td>

<td><ahref="delete.asp?id=<%=rs(1)%>">删除</a></td>

<td><inputtype="button"οnclick="javascript:document.form1.action='update.asp?rowcount=<%=i%>&pid=<%=rs(1)%>';document.form1.submit();"value="确认改动"></td>

</tr>

<%

i=i+1

sum=sum+cint(rs(2))*rs(3)‘计算总价格

rs.movenext

wend

rs.close

setrs=nothing

conn.close

setconn=nothing

%>

</table>

</form>

<ahref="index.asp">返回继续购物</a>

总金额为:<%=sum%>

点击改动数量的button之后,就跳到update.asp:

<!--#includefile="inc/conn.asp"-->

<%

这里须要注意在上个页面,有个i值,在这里就用到了,你要指明改动的是哪一行记录

i=request.querystring("rowcount")

pcount=request.form("pcount")(i)

pid=request.querystring("pid")(i)

sql="updatemrcarsetpcount="&pcount&"wherepid="&pid&"andorderid='"&session("orderid")&"'"

conn.executesql

conn.close

setconn=nothing

response.redirect("mycar.asp")‘运行完之后又一次跳转到mycar.asp

%>

相同点击删除之后,就跳到delete.asp,在该页面得到商品的id

<!--#includefile="inc/conn.asp"-->

<%

pid=request.QueryString("id")

response.write(pid)

sql="deletefrommrcarwherepid="&pid&"andorderid='"&session("orderid")&"'"

conn.executesql

conn.close

setconn=nothing

response.Redirect("mycar.asp")‘运行完之后又一次跳转到mycar.asp

%>一个简单的购物车做好了,它用到了连接数据库、数据库的增、删、改、查。

 

使用: 第1 '================================================= '建立购物车对象,该对象用于直接在程序中调用 '================================================= dim uCart set uCart= new UserCart 第二 建立一个购物车 uCart.CreateCart (可以重复建立,因为里面有IsArray判断。所以建议这句在建立购物车对象后必写) 第三 增加购物车里的商品,在客户端点了某产品后,服务器端处理的ASP文件中接受传过来的产品标志,并访问数据库。分别把AddItem(aID产品标 志如ID,aName产品名称,aPrice1产品价格一,如单价,aPrice2产品价格二如会员价,aPrice3产品价格三如金牌会员价,如果没这么多可以置空 或置0,aCount购买数量,一般是一个,多个的话后面可以用修改函数修改,aImage产品图片地址) 使用方法:aa=uCart.AddItem(aID产品标志如ID,aName产品名称,aPrice1产品价格一,如单价,aPrice2产品价格二如会员价,aPrice3产品价格 三如金牌会员价,如果没这么多可以置空或置0,aCount购买数量,一般是一个,多个的话后面可以用修改函数修改,aImage产品图片地址),返回 true表示成功,false表示失败 第四 增加了以后进如显示页面,就要用到查看购物车 mycart=uCart.ViewCart() For i =LBound(myCart,2) to UBound(myCart,2) if myCart(0,i)"" then myCart(0,i) '获取标号 myCart(1,i) '获取单价 。。。以此类推 end if next 第五 查看了,可以修改购物车,如更改数量等,或是删除其中的 call uCart.ModifItem(mID唯一标志号,mCount产品数量,mFlag-标志 0-添加 1-删除,2-修改 3-清空) '先用给后面参数赋值 修改其中的商品 可以用第四个显示,先接受session的值,然后循环修改 或清空购物车 uCart.RemoveAll() 然后结帐,很简单 myprice=uCart.TPrice() 然后myprice(0)是产品单价的总价格,myprice(1)是产品会员价的总价格,myprice(2)是高级会员的总价格,myprice(3)是产品总数量 将商品装入购物车,这时需要用cookie或session来做一个不同页面间传递的全局变量,也就是说关了浏览器(针对session)或清楚了cookie等原因,本次购物车会消失,就象你今天在商场买了一车的东西,最后没结帐,明天肯定没了,又归位了,当然要有特殊需要保存,可以写数据库!所以这里记录的只需要是该商品的相关信息就可以了,这里我们记录他的 物品ID, 物品单价, 物品名称, 物品数量
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值