微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

php实现购物车功能下

接着上篇继续学习: 《php实现购物车的功能(上)》

一个管理界面

登录界面

代码实现: 7.1 admin.PHP

rush:PHP;"> PHP

/**

  • @author switch
  • @copyright 2015
  • 主管理菜单
    */
    //require_once语句和require语句完全相同,唯一区别是PHP会检查该文件是否已经被包含过,如果是则不会再次包含。
    require_once('book_sc_fns.PHP');

session_start();

if((@$_POST['username']) && (@$_POST['passwd'])) //尝试登陆
{
$username = $_POST['username'];
$passwd = $_POST['passwd'];

if(login($username,$passwd))
{
$_SESSION['admin_user'] = $username;
}
else
{
do_html_header("Problem:");
echo "

You Could not be logged in.

You must be logged in to view this page.

";
do_html_URL('login.PHP','Login');
do_html_footer();
exit;
}
}

do_html_header("Administration");

if(check_admin_user())
{
display_admin_menu();
}
else
{
echo "

You are not authorized to enter the administration area.

";
do_html_URL('login.PHP','Login');
}
do_html_footer();
?>

7.2 user_auth_fns.PHP文件中的函数login()

if(!$conn)
return 0;

//检查用户名唯一性
$query = "select * from admin where username='". $username ."'
and password = sha1('". $password ."')";
$result = $conn ->query($query);

if(!$result)
return 0;

if($result ->num_rows > 0)
return 1;
else
return 0;
}

7.3 user_auth_fns.PHP文件中的函数check_admin_user()

rush:PHP;"> function check_admin_user() //检查是否是管理员 { if(isset($_SESSION['admin_user'])) return true; else return false; }

管理主界面

代码实现:

PHP文件中的函数display_admin_menu()






PHP
}

function display_button($target,$image,$alt) //显示按钮
{
echo "<div align= \" center \"><a href=\"". $target ."\">
<img src=\"images/". $image .".gif\"
alt=\"". $alt ."\" border = \" 0 \" height = \" 50 \"
width = \" 135 \" />

";
}

目录添加

目录添加成功

目录页中可以看出多了Novel目录

代码实现: 7.5 insert_category_form.PHP

rush:PHP;"> PHP

/**

  • @author switch
  • @copyright 2015
  • 允许管理员数据库添加一个目录的表格
    */
    //require_once语句和require语句完全相同,如果是则不会再次包含
    require_once('book_sc_fns.PHP');
    session_start();

do_html_header();
if(check_admin_user())
{
display_category_form();
do_html_URL("admin.PHP","Back to administrtion menu");
}
else
{
echo "

You are not authorized to enter the administation area.

";
}
do_html_footer();
?>

PHP

rush:PHP;"> PHP

/**

  • @author switch
  • @copyright 2015
  • 数据库中插入新目录
    */
    //require_once语句和require语句完全相同,如果是则不会再次包含
    require_once('book_sc_fns.PHP');
    session_start();

do_html_header("Adding a category");
if(check_admin_user())
{
if(filled_out($_POST))
{
$catname =$_POST['catname'];
if(insert_category($catname))
{
echo "

Category \"". $catname ."\" was added to the database.

";
}
else
{
echo "

Category \"". $catname ."\" Could not be added to the database.

";
}
}
else
{
echo "

You have not filled out the form. Please try again.

";
}
do_html_URL("admin.PHP","Back to administration menu");
}
else
{
echo "

You are not authorised to view this page.

";
}
do_html_footer();
?>

管理员目录界面

目录编辑界面-可更新,删除

目录更新成功

目录主界面可以看到该目录更改成功

代码实现: 7.7 edit_category_form.PHP

rush:PHP;"> PHP

/**

  • @author switch
  • @copyright 2015
  • 管理员编辑目录的表单
    */
    //require_once语句和require语句完全相同,如果是则不会再次包含。
    require_once('book_sc_fns.PHP');
    session_start();

do_html_header("Edit category");
if(check_admin_user())
{
if($catname = get_category_name($_GET['catid']))
{
$catid = $_GET['catid'];
$cat = compact('catname','catid');
display_category_form($cat);
}
else
{
echo "

Could not retrieve category details.

";
}
do_html_URL("admin.PHP","Back to administration menu");
}
else
{
echo "

You are not authorized to enter the administration area.

";
}
do_html_footer();
?>

7.8 edit_category.PHP

rush:PHP;"> PHP

/**

  • @author switch
  • @copyright 2015
  • 更新数据库中的目录
    */
    //require_once语句和require语句完全相同,如果是则不会再次包含。
    require_once('book_sc_fns.PHP');
    session_start();

do_html_header("Updating category");
if(check_admin_user())
{
if(filled_out($_POST))
{
if(update_category($_POST['catid'],$_POST['catname']))
{
echo "

Category was updated.

";
}
else
{
echo "

Category Could not be updated.

";
}
}
else
{
echo "

you have not filled out the form. Please try again.

";
}
do_html_URL("admin.PHP","Back to administration menu");
}
else
{
echo "

You are not authorised to view this page.

";
}
do_html_footer();
?>

7.9 admin_fns.PHP

rush:PHP;"> /**

  • @author switch
  • @copyright 2015
  • 管理脚本使用的函数集合
    */
    function display_category_form($category = '') //显示目录表单
    {
    //如果传入存在目录,进入编辑模式
    $edit = is_array($category);
    ?>
    <form method="post" action="<?php echo $edit ? 'edit_category.php' :'insert_category.php'; ?>">
    <table border="0">
    <tr>
    <td>Category Name:</td>
    <td><input type="text" name="catname" size="40" maxlength="40" value="<?php echo $edit ? $category['catname'] : ''; ?>"/></td>
    </tr>
    <tr>
    <td <?php if(!$edit){echo "colspan=2";} ?> align="center">
    <?PHP
    if($edit)
    {
    echo "<input type=\"hidden\" name=\"catid\" value=\"". $category['catid'] ."\" />";
    }
    ?>
    <input type="submit" value="<?php echo $edit ? 'Update' : 'Add'; ?> Category"/>
    </td>
    <?PHP
    if($edit) //允许删除存在目录
    {
    echo "<td>
    <form method=\"post\" action=\"delete_category.PHP\">
    <input type=\"hidden\" name=\"catid\" value=\"". $category['catid'] ."\" />
    <input type=\"submit\" value=\"Delete category\" />

function display_book_form($book = '') //显示图书表单
{
//如果传入图书存在,进入编辑模式
$edit = is_array($book);
?>

<form method="post" action="<?php echo $edit ? 'edit_book.php' : 'insert_book.php'; ?>">
<table border="0">
<tr>
<td>ISBN:</td>
<td></td>
</tr>
<tr>
<td>Book Title:</td>
<td></td>
</tr>
<tr>
<td>Book Author:</td>
<td><input type="text" name="author" value="<?php echo $edit ? $book['author'] : ''; ?>"/></td>
</tr>
<tr>
<td>Category:</td>
<td>
<select name="catid">
<?PHP
$cat_array = get_categories();
foreach($cat_array as $thiscat)
{
echo "<option value=\"". $thiscat['catid'] ."\"";
if(($edit) && ($thiscat['catid'] == $book['catid']))
{
echo " selected";
}
echo ">". $thiscat['catname'] ."";
}
?>

align="center"> PHP if ($edit) echo "";?> PHP if ($edit) { echo "PHP\"> }
?>
</td>
</tr>
</table>

function display_password_form() //显示更改密码表单
{
?>


<form action="change_password.PHP" method="post">
<table width="250" cellpadding="2" cellspacing="0" bgcolor="#cccccc">
<tr>
<td>Old password:</td>
<td><input type="password" name="old_passwd" size="16" maxlength="16"/></td>
</tr>
<tr>
<td>New password:</td>
<td><input type="password" name="new_passwd" size="16" maxlength="16"/></td>
</tr>
<tr>
<td>Repeat new password:</td>
<td><input type="password" name="new_passwd2" size="16" maxlength="16"/></td>
</tr>
<tr>
<td colspan="2" align="center"><input type="submit" value="Change password"/></td>
</tr>
</table>


function insert_category($catname) //目录插入
{
$conn = db_connect(); //数据库连接

$query = "select *
from categories
where catname='". $catname ."'";
$result = $conn ->query($query);
if((!$result) || ($result ->num_rows != 0))
return false;

$query = "insert into categories values
('','". $catname ."')";
$result = $conn ->query($query);
if(!$result)
return false;
else
return true;
}

function insert_book($isbn,$title,$author,$catid,$price,$description) //图书插入
{
$conn = db_connect(); //连接数据库

$query = "select * from books
where isbn='". $isbn ."'";
$result = $conn ->query($query);
if((!$result) || ($result ->num_rows != 0))
return false;

$query = "insert into books values
('". $isbn ."','". $author ."','". $title ."','". $catid ."','". $price ."','". $description ."')";

$result = $conn ->query($query);
if(!$result)
return false;
else
return true;
}

function update_category($catid,$catname) //更改目录名称
{
$conn = db_connect(); //连接数据库

$query = "update categories
set catname='". $catname ."'
where catid='". $catid ."'";
$result = @$conn ->query($query);
if(!$result)
return false;
else
return true;
}

function update_book($oldisbn,$isbn,$description)
{
$conn = db_connect(); //连接数据库

$query = "update books
set isbn='". $isbn ."',title='". $title ."',author='". $author ."',catid='". $catid ."',price ='". $price ."',description='". $description ."'
where isbn='". $oldisbn ."'";
$result = @$conn ->query($query);
if(!$result)
return false;
else
return true;
}

function delete_category($catid) //删除目录
{
$conn = db_connect(); //连接数据库

$query = "select *
from books
where catid='". $catid ."'";
$result = @$conn ->query($query);
if((!$result) || (@$result ->num_rows > 0)) //如果该目录有图书,无法删除该目录
return false;

$query = "delete from categories
where catid='". $catid ."'";
$result = @$conn ->query($query);
if(!$result)
return false;
else
return true;
}

function delete_book($isbn) //删除图书
{
$conn = db_connect(); //连接数据库

$query = "delete from books
where isbn='". $isbn ."'";
$result = @$conn ->query($query);
if(!$result)
return false;
else
return true;
}
?>

7.10 目录删除操作,图书添加,更新,删除操作基本与上述操作差不多,这里就不在演示,可以下载代码查看

8、扩展 本项目创建了一个相当简单的PHP购物车系统。我们还可以对它进行许多改进和提高:

  • 在真正的在线商店,可能必须建立一些订单记录和实施系统——在这个系统中,用户无法看到已经预定了的订单。
  • 顾客希望在不必与我们联系的前提下就能检查到他们的订单处理情况。用户应当可以通过一种身份验证方式使之能够查看自己以前的订单,并且也可以将操作与个人情况紧密地结合起来。也更方便我们收集一些用户习惯信息。
  • 图书的图片可以通过FTP之类的服务传输到该网站的图像目录并给它们取一个合适的名字。可以把文件上载到图片插入页,以使该操作方便一些。
  • 可以添加用户登录、个性化设置以及书目推荐、在线评论、会员制度、库存级别检查等。可以添加功能是非常多的。

以上就是PHP实现购物车功能的全部代码,希望对大家的学习有所帮助。

源码下载:购物车

原文地址:https://www.jb51.cc/php/20578.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐