php实现一个简单的购物网站
实现一个简单的购物网站
一、考试时间:8小时
二、开发工具:DW
三、数据库:见附件
四、需要实现的页面:
Index:浏览商品页面,显示商品列表,用户可以点击“购买“。
ViewCart:查看购物车页面,显示已购买的商品信息,可以点击“删除“已买的商品
ViewAccount:查看个人账户余额
Login:登录页面
建议使用的技术:Ajax,Session,数组。
五、实现功能:
1、 显示商品列表
2、 实现购买功能,购买的时候动态显示购物车中的商品数量和商品总价格
3、 点击查看购物车后,显示已购买的商品。注意“购买数量”列,如果对一种商品点击购买多次,其“购买数量”不断增加。
4、 删除购物车中已购买的商品。
如果某商品的“购买数量”为1时,则点击“删除”时,直接从购物车中删除该商品;
如果商品的“购买数量”大于1时,点击一次“删除”时,把其购买数量减1。直到该商品购买数量为1时,再点击删除时,删除该商品
5、 在查看完购物车后还可以点击“浏览商品”继续购买。并在上面显示已购买的商品数量和总价格。
6、 在“查看购物车“后,可以提交订单
但在提交订单时,须完成以下功能:
a) 检查用户是否已登录,未登录则转到Login页面
b) 检查用户账户余额是否能够满足本次够买
c) 检查库存数量是否满足本次够买
d) 如果以上条件都满足则
- 从用户账户中扣除本次购买的总价格
- 从商品库存中扣除本次每种商品的购买数量
- 向订单表和订单内容表中加入本次购买的商品信息
7、 点击查看账户,可以查看该用户的账户余额。
开始做,首先先做一个登录页面:login.php
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head> <body>
<h1>登录页面</h1>
<div>
<form action="logincl.php" method="post">
账号:
<input type="text" name="uid" />
</div>
<div>
密码:
<input type="password" name="pwd" />
</div>
<input type="submit" value="登录" />
</form>
</body>
</html>
效果如图:

在做一个登录的处理页面:logincl.php
<?php
session_start();
include("../fengzhuang/DBDA.class.php");
$db = new DBDA(); $uid =$_POST["uid"];
$pwd = $_POST["pwd"]; $sql = "select password from login where username = '{$uid}'";
$arr = $db->Query($sql); if($arr[0][0]==$pwd && !empty($pwd))
{
$_SESSION["uid"] =$uid;
header("location:main.php");
}
else
{
echo"登录失败";
}
这样就可以和数据库联系了,这个是数据库的登录帐号和密码,验证帐号,密码,然后跳到主页:main.php

现在做主页的页面:main.php
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head> <body>
<h1>大苹果购物网</h1> <?php
session_start();
include("../fengzhuang/DBDA.class.php");
$db = new DBDA();
date_default_timezone_set("PRC"); //1.找出购物车中多少种商品和总价
$uid = $_SESSION["uid"];
$attr = array();
//如果购物车有商品,取出值
if(!empty($_SESSION["gwc"]))
{
$attr = $_SESSION["gwc"];
} $gs = count($attr);//$gs 商品数量
$sum = 0;//$sum 总价格,默认总价格为0
foreach($attr as $v)
{
$v[0];//水果代号
$v[1]; //水果数量
$sql = "select price from fruit where ids ='{$v[0]}'";//查询单价 $ajg = $db->Query($sql);
$dj = $ajg[0][0];//单价 $sum += $dj * $v[1];//总价=单价*数量
}
echo"<div>购物车中有:{$gs}种商品,商品总价为:{$sum}元</div>";
?> <table width="100%" border="1" cellpadding="0" cellspacing="0">
<tr>
<td>代号</td>
<td>水果名称</td>
<td>水果价格</td>
<td>原产地</td>
<td>货架</td>
<td>库存量</td>
<td> </td>
</tr>
<?php //2.从数据库中找出数据 $sql = "select * from fruit";
$arr = $db->Query($sql); foreach($arr as $v)
{
echo"<tr>
<td>$v[0]</td>
<td>$v[1]</td>
<td>$v[2]</td>
<td>$v[3]</td>
<td>$v[4]</td>
<td>$v[5]</td>
<td><a href='add.php?ids={$v[0]}'>购买</a></td>
</tr> "; } ?> </table>
<a href="gouwuche.php?ids={$v[0]}">查看购物车</a> </body>
</html>
然后做主页的处理页面:add.php
<?php
session_start();
//找出点击"购买"的ids
$ids = $_GET["ids"]; //1.第一次点击添加购物车
//2.如果购物车中没有该商品
//3.如果购物车中有该商品 //第一步,判断购物车为空,则第一次点击把商品添加到购物车
if(empty($_SESSION["gwc"]))
{
$arr = array(array($ids,1));
$_SESSION["gwc"] = $arr;
}
//如果不为空,则有2种判断,1:该商品为空,则需添加进去,2:该商品有,则需数量上+1;
else
{
//不是第一次点击
//判断购物车中是否存在该商品
$arr = $_SESSION["gwc"]; $chuxian = false;
foreach($arr as $v)
{
if($v[0]==$ids)
{
$chuxian =true;
}
} if($chuxian)
{
//如果购物车中有该商品
for($i=0;$i<count($arr);$i++)
{
$arr[$i][1]+=1;
} $_SESSION["gwc"] =$arr;
} else
{
//如果购物车中没有该商品
$asg = array($ids,1);
$arr[] =$asg;
$_SESSION["gwc"] = $arr;
}
} header("location:main.php");
登录效果如图:

然后再做查看购物车页面,能看到购物车中的商品和单价和总价:gouwuche.php
首先购买3中商品:

然后代码:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
</head> <body> <h1>大苹果购物网</h1> <h2>购物车中有以下商品:</h2> <table width="100%" border="1" cellpadding="0" cellspacing="0">
<tr>
<td>商品名称</td>
<td>商品单价</td>
<td>购买数量</td>
<td> </td>
</tr> <?php
session_start(); include("../fengzhuang/DBDA.class.php");
$db = new DBDA(); $uid = $_SESSION["uid"];
$arr = array();
if(!empty($_SESSION["gwc"]))
{
$arr = $_SESSION["gwc"];
} foreach($arr as $k=>$v)
{
$sql = "select * from fruit where ids ='{$v[0]}' ";
$attr =$db->Query($sql); echo"<tr>
<td>{$attr[0][1]}</td>
<td>{$attr[0][2]}</td>
<td>{$v[1]}</td>
<td><a href='shanchu.php?sy={$k}'>删除</a></td>
</tr>
";
}
?>
</table>
<div>
<a href="tijiao.php?ids='{$v[0]}'">提交订单</a>
</div> </body>
</html>
效果如图所示:

然后做提交页面 :tijiao.php
<?php session_start();
include("../fengzhuang/DBDA.class.php");
$db = new DBDA();
date_default_timezone_set('PRC') ;
$uid=$_SESSION["uid"];
$sye="select account from login where username ='{$uid}' ";
$aye=$db->Query($sye);
$aye[0][0];//余额 $attr =array();
if(!empty($_SESSION["gwc"]))
{
$attr =$_SESSION["gwc"];
} $sum = 0;//总价
foreach($attr as $v)
{
$v[0];//水果代号
$v[1];//数量
$sql = "select price from fruit where ids='{$v[0]}'";
$ajg = $db->Query($sql);
$dj = $ajg[0][0];//单价
$sum +=$dj*$v[1]; } //判断余额是否满足购买
if($aye[0][0]>=$sum)
{
//余额满足,判断库存
foreach($attr as $v)
{
$skc = "select name,number from fruit where ids='{$v[0]}'";
$akc = $db->Query($skc);
$akc[0][1];//库存 //判库存是否满足
if($akc[0][1]<$v[1])
{
echo"{$akc[0][0]}库存不足";
exit;
} } //提交订单
//账户扣除余额
$skcye = "update login set account=account-{$sum} where username ='{$uid}'";
$db->Query($skcye,0); //扣除库存
foreach($attr as $v)
{
$skckc = "update fruit set number = number-{$v[1]} where ids ='{$v[0]}'";
$db->Query($skckc,0);
} //添加订单
$ddh = date("YmdHis");
$time = time();
$sdd = "insert into orders values('{$ddh}','{$uid}','{$time}')";
$db->Query($sdd,0); //添加订单详情
foreach($attr as $v)
{
$sddxq ="insert into orderdetails values('','{$ddh}','{$v[0]}','$v[1]')";
$db->Query($sddxq,0); }
}
else
{
echo"余额不足";
exit;
}
header("location:main.php");
然后看看数据库有没有改变:

李四的账户余额已经减少了
php实现一个简单的购物网站的更多相关文章
- 用 Vue 做一个简单的购物app
前言 最近在学习Vue的使用.看了官方文档之后,感觉挺有意思的.于是着手做了一个简单的购物app.h5 与原生 app 交互的原理这是我第一次在这个网站上写分享,如有不当之处,请多多指教. 一整个项目 ...
- PHP操作实现一个多功能购物网站
PHP操作实现一个多功能购物网站 一.需要实现的页面: Index.aspx:浏览商品页面,显示商品列表,用户可以点击“加入购物车“. ViewCart.aspx:查看购物车页面,显示已购买的商品信息 ...
- [.NET] 一步步打造一个简单的 MVC 网站 - BooksStore(一)
一步步打造一个简单的 MVC 网站 - BooksStore(一) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore 简介 主 ...
- Ruby学习笔记2 : 一个简单的Ruby网站,搭建ruby环境
Ruby on Rails website 的基础是 请求-返回 循环. 首先是浏览器请求服务器, 第二步,Second, in our Rails application, the route ta ...
- 一个简单的购物金额结算(JAVA)
我编写的代码: import java.util.Scanner; public class ZuoYe01 { public static void main(String[] args) { // ...
- 基于SpringCloud的微服务架构实战案例项目,以一个简单的购物流程为示例
QuickStart 基于SpringCloud体系实现,简单购物流程实现,满足基本功能:注册.登录.商品列表展示.商品详情展示.订单创建.详情查看.订单支付.库存更新等等. 每个业务服务采用独立的M ...
- Java初学者作业——使用switch结构实现一个简单的购物计划
返回本章节 返回作业目录 需求说明: 使用switch结构实现一个购物计划,计划为:星期一.星期三.星期五购买伊利牛奶和面包,星期二.星期四购买苹果和香蕉,星期六.星期日购买啤酒和周黑鸭. 实现思路: ...
- 【lucene】一个简单的招聘网站的建立
1.建立索引库: 核心代码如下 package com.tabchanj.job.index; import java.util.ArrayList; import java.util.HashMap ...
- Redis 实战 —— 11. 实现简单的社交网站
简介 前面介绍了广告定向的实现,它是一个查询密集型 (query-intensive) 程序,所以每个发给它的请求都会引起大量计算.本文将实现一个简单的社交网站,则会尽可能地减少用户在查看页面时系统所 ...
随机推荐
- 【C#】List<T>对象的深复制
一.List对象中的T是值类型的情况(int 类型等) 对于值类型的List直接用以下方法就可以复制: List<T> oldList = new List<T>(); old ...
- inux内存映射和共享内存理解和区别
可以看到内存映射中需要的一个参数是int fd(文件的标识符),可见函数是通过fd将文件内容映射到一个内存空间, 我需要创建另一个映射来得到文件内容并统计或修改,这时我创建这另一个映射用的仍是mmap ...
- BusyBox rcS&fstab配置
rcS为系统初始化脚本,完成最开始的一些配置工作,可开启应用程序. #!/bin/shmount -a ;mount文件,要mount的文件有fstab指定. . /etc/profile ...
- JVM 详谈
JVM 详谈 本来这次应该讲讲ORM 的几个框架,但是笔者还没有完全总结出来,所以这里先插入一次学习JVM的心得.作为一个Java程序员,如果不了解JVM的工作原理,就很难从底层去把 握Java语言和 ...
- LINQ操作符四:排序操作符
Linq中的排序操作符包括OrderBy.OrderByDescending.ThenBy.ThenByDescending和Reverse,提供了升序或者降序排序. 一.OrderBy操作符 Ord ...
- php 抽象 继承 多态
1.继承和重载 !!!php中使用extends单一继承的方法 被继承的类 父类(基类) 继承者 子类(派生类) 如果说我们需要将父类方法重载(方法覆盖),在派生类里使用与基类方法重名的方法名称 ...
- 在Ubuntu中安装PHP,MySQL,Nginx和phpMyAdmin
apt install php apt-get install php7.0 apt-get -y install php7.0-fpm 缺少 mysqli 扩展.请检查 PHP 配置. apt in ...
- style="display:none"隐藏html的标签
隐藏html的标签 <div class="span11 alignment"> <h1>我的虚拟网络</h1> </div> &l ...
- UC浏览器调试移动端网站
准备工作: UC浏览器开发版网址 UC浏览器开发者版下载地址 下载adb_tool 步骤: 1.将adb_tool解压,把里面的文件复制到 C:\Windows\SysWOW64 文件夹下面. 2.运 ...
- javascript实现记录文本框内文字个数
最近在做一个项目中遇到这样一个问题,要对文本框中用户输入的文字进行记数,在下面显示出来,因为我们做的是一个短信发送平台,现在我们国家的短信服务,如果你的信息超过了70个字符,短信就会按二条给你下发.所 ...