现如今,农产品在线销售平台是商业贸易中的一条非常重要的道路,可以把其从传统的实体模式中解放中来,网上购物可以为消费者提供巨大的便利。通过农产品在线销售平台这个平台,可以使用户足不出户就可以了解现今的流行趋势和丰富的农产品信息,为用户提供了极大的方便,农产品在线销售平台的主要功能包含:商品的类别管理、商品的信息管理、订单管理、用户的管理等
前台子系统为用户提供注册、登陆的功能,以及浏览商品,购买商品,提交订单后采用模拟的金额支付,实现商品的购买流程。后台子系统供网站内部管理人员使用,可以添加新的商品、商品修改和调整,商品种类维护,可以对用户进行管理。对用户的订单进行管理发货等等。
1.前台模块设计:
① 注册功能。用户首先要进行注册成为网站的用户,注册时需填写用户名、邮箱号、密码3项信息,然后点击“注册”按钮。如果注册成功,则提示注册成功并转到用户登录界面,同时用户信息会被写进数据库中的用户表中。如果注册失败,则会提示失败原因。用户注册成功后就可以登陆了。
② 登陆功能。如果用户是网站的已注册用户,在购买商品前需要填写邮箱号和密码,之后点击“登陆”按钮,之后系统会将用户填入的信息与数据库中用户注册时填写的信息进行比对,如果一致的话网站将会跳转到首页用户即可享受到网站的购买商品。如果用户填写的信息有误,网站将会提示用户输入的信息有误。
③ 商品展示功能。网站将所有商品信息从数据库中提取出来显示在网站中,用户可以浏览网站,将自己心怡的商品放入购物车中,这是系统会提取该商品的信息并将信息加入购物车表中。
④ 购物车功能。当用户选择完商品后可以进入购物车页面,系统会从购物车表中提取用户的购物车信息并显示出来,用户可以在这里查看自己要购买的商品,也可以取消购买某商品,这时该商品的信息会从购物车表中删除。
⑤ 订单生成功能。在购物车模块,当用户确定所买的商品后,单击“订单生成”的功能,进入订单的界面。在结账界面,系统会将购物车表中的商品信息显示在订单中并根据用户购买的数量和商品的单价计算出用户购买的商品的总价,接下来只需要用户填写收货信息选择付款和发货方式并点击“确认提交订单”按钮。确认后产生将订单,系统会将订单信息插入数据库中的订单表和订单商品表中,并进入支付页面。
2.后台模块设计:
① 用户管理功能。管理员在后台首页点击用户管理就会进入用户列表页面,系统会将数据库中的用户信息以列表的形式显示出来,管理员可以在这个页面进行用户的更新和删除操作,系统可以将最新更新的信息重新写入用户表中并替换原信息,也可以将用户的信息从数据表中删除。
② 商品类别管理功能。管理员在后台点击商品分类按钮会进入商品分类界面,系统会将数据库中的商品分类信息以列表的形式展现出来,管理员可以对商品的分类进行排序,也可以在该页面点击添加新分类、编辑和删除按钮,同时系统会在数据库中对商品分类表中的数据进行相应的新增,更新和删除。
③ 商品管理功能。管理员在后台点击商品管理就会进入商品管理界面,系统会将数据库中的商品信息以列表的形式显示出来,管理员可以在该界面对商品进行添加、更新和删除的操作。在新增时,如果添加成功系统会提示新增成功同时将新商品信息添加进数据库中的商品表,如果添加失败,系统会提示失败的原因。当管理员对商品信息进行更新时,数据表中的商品信息也会随之更新。管理员删除商品,数据表中相应的商品信息也会随之删除。
④ 订单管理功能。管理员在后台点击订单管理就会进入订单管理界面,系统会从数据库中将订单信息提取出来,依列表的形式展现出来。管理员可以在该界面对订单的发货状态进行更改也可以删除订单,同时数据库中订单表中的订单状态也会更新,或者删除订单数据。
⑤ 新闻管理功能。网站会不定时的更新一些有关于时尚潮流趋势的新闻,用户也可以浏览这些新闻从中了解近期的时尚资讯。管理员在后台点击编辑新闻就会进入编辑新闻界面,系统会将新闻数据表中的数据提取出来显示在页面上,管理员可以在这里修改新闻,然后点击“保存修改”按钮进行保存,然后系统会同步更新新闻表中的内容并提示更新成功。
<?php
error_reporting(E_ALL ^ E_NOTICE);
$conn=("localhost","root","root") or die("数据库链接失败".mysql_error());
mysql_select_db("daizu",$conn) or die("数据库链接失败".mysql_error());
mysql_query('set names utf8');
//设置时区
date_default_timezone_set('asia/shanghai');
define('SYS_ROOT', str_replace("\\", '/', dirname(__FILE__)));
define('File_ROOT', SYS_ROOT."/upload/");
define('IMG_ROOT', SYS_ROOT . "/upload/");
($_POST);
($_GET);
function getfirst($sql)
{
$res=mysql_query($sql);
$rows=mysql_fetch_array($res);
return $rows;
}
//
function getcount($sql){
$res=mysql_query($sql);
return mysql_num_rows($res);
}
function get_name($id,$table)
{
$sql="select * from $table where id='$id'";
$rows=getfirst($sql);
return $rows[name];
}
//遍历创建目录
function Remkdir($path) {
if (!file_exists($path)) {
Remkdir(dirname($path));
($path, 0777);
}
}
//上传图片
function upload_image($inputname, $image=null, $type='upimages', $width=440) {
$n = time().rand(1000,9999).'.jpg';
$z = $_FILES[$inputname];
if ($z && strpos($z['type'], 'image')===0 && $z['error']==0) {
if (!$image) {
Remkdir( IMG_ROOT . '/' . "{$type}/" );
$image = "{$type}/{$n}";
$path = IMG_ROOT . '/' . $image;
} else {
Remkdir( dirname(IMG_ROOT .'/' .$image) );
$image = "{$type}/{$n}";
$path = IMG_ROOT . '/' .$image;
}
//echo $path ;
move_uploaded_file($z['tmp_name'], $path);
//echo $image;exit;
return $image;
}
return $image;
}
//获取文件后缀名
function get_extend($file_name)
{
$extend = pathinfo($file_name);
$extend = strtolower($extend["extension"]);
return $extend;
}
//文件上传实现
function upload_file($inputname, $file=null)
{
$year = date('Y'); $day = date('md');
$z = $_FILES[$inputname];
$file_ext=get_extend($z['name']);
$n = time().rand(1000,9999).".".$file_ext;
if ($z && $z['error']==0) {
if (!$file) {
Remkdir( File_ROOT . '/' . "{$day}" );
$file = "{$day}/{$n}";
$path = File_ROOT . '/' . $file;
} else {
Remkdir( File_ROOT . '/' . "{$day}" );
$file = "{$day}/{$n}";
$path = File_ROOT . '/' .$file;
}
//echo $path ;
move_uploaded_file($z['tmp_name'], $path);
//echo $file;exit;
return $file;
}
return $file;
}
//分页函数.
function get_pager($url, $param, $count, $page = 1, $size = 10)
{
$size = intval($size);
if($size < 1)$size = 10;
$page = intval($page);
if($page < 1)$page = 1;
$count = intval($count);
$page_count = $count > 0 ? intval(ceil($count / $size)) : 1;
if ($page > $page_count)$page = $page_count;
$page_prev = ($page > 1) ? $page - 1 : 1;
$page_next = ($page < $page_count) ? $page + 1 : $page_count;
$param_url = '?';
foreach ($param as $key => $value)$param_url .= $key . '=' . $value . '&';
$pager['url'] = $url;
$pager['start'] = ($page-1) * $size;
$pager['page'] = $page;
$pager['size'] = $size;
$pager['count'] = $count;
$pager['page_count'] = $page_count;
if($page_count <= '1')
{
$pager['first'] = $pager['prev'] = $pager['next'] = $pager['last'] = '';
}
else
{
if($page == $page_count)
{
$pager['first'] = $url . $param_url . 'page=1';
$pager['prev'] = $url . $param_url . 'page=' . $page_prev;
$pager['next'] = '';
$pager['last'] = '';
}
elseif($page_prev == '1' && $page == '1')
{
$pager['first'] = '';
$pager['prev'] = '';
$pager['next'] = $url . $param_url . 'page=' . $page_next;
$pager['last'] = $url . $param_url . 'page=' . $page_count;
}
else
{
$pager['first'] = $url . $param_url . 'page=1';
$pager['prev'] = $url . $param_url . 'page=' . $page_prev;
$pager['next'] = $url . $param_url . 'page=' . $page_next;
$pager['last'] = $url . $param_url . 'page=' . $page_count;
}
}
return $pager;
}
?>
目录
1 绪论 1
1.1课题背景 1
1.2课题研究现状 1
1.3初步设计方法与实施方案 2
1.4本文研究内容 2
2 系统开发环境 4
2.1 使用工具简介 4
2.2 环境配置 4
2.3 B/S结构简介 4
2.4 MySQL数据库 5
2.5 框架介绍 5
3 系统分析 6
3.1系统可行性分析 6
3.1.1经济可行性 6
3.1.2技术可行性 6
3.1.3运行可行性 6
3.2系统现状分析 6
3.3功能需求分析 7
3.4系统设计规则与运行环境 8
3.5系统流程分析 8
3.5.1操作流程 8
3.5.2添加信息流程 9
3.5.3删除信息流程 10
4 系统设计 11
4.1系统设计主要功能 11
4.2数据库设计 11
4.2.1数据库设计规范 11
4.2.2 E/R图 11
4.2.3数据表 12
5 系统实现 25
5.1系统功能模块 25
5.2后台模块 27
5.2.1管理员功能模块 27
5.2.2用户功能模块 30
6 系统测试 33
6.1功能测试 33
6.2可用性测试 33
6.3性能测试 34
6.4测试结果分析 34
7结 论 35
参考文献 36
致 谢 37