电子商城项目开发(后台功能模块开发)

前端之家收集整理的这篇文章主要介绍了电子商城项目开发(后台功能模块开发)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

后台登陆页login.PHP

    <?PHP
    //1.连接数据库 (创建一个数据库,创建数据表 test_admin)
    //id,adminuser,adminpass,created_at,login_at,login_ip
    require '../db.func.PHP';
    require '../tools.func.PHP';
    // POST提交
    if (!empty($_POST['adminuser'])) {
      //2.查询用户名和密码是否正确 adminuser adminpass
        $prefix = getDBPrefix();
        $adminuser = htmlentities($_POST['adminuser']);
        $adminpass = md5(htmlentities($_POST['adminpass']));
        $sql = "SELECT id,adminuser FROM {$prefix}admin 
                        WHERE adminuser = '$adminuser' 
                        AND adminpass = '$adminpass'";

        $res = queryOne($sql);
        if ($res) {
        //3.写入session
            setSession('admin',['adminuser' => $adminuser,'id' => $res['id']]
            );
            $login_at = date('Y-m-d H:i:s');
            $ip = $_SERVER['REMOTE_ADDR'] == '::1' ? '127.0.0.1' : $_SERVER['REMOTE_ADDR'];
            $login_ip = ip2long($ip);
            $sql = "UPDATE {$prefix}admin 
                            SET login_at = '$login_at',login_ip = '$login_ip' 
                            WHERE id = '{$res['id']}'";
            execute($sql);
        //4.跳转到index.PHP
            header('location: index.PHP');
        } else {
            setInfo('用户名或者密码错误');
        }
    }

    ?>
    <!doctype html>
    <html>

    head>
      title>商城</<!-- required Meta tags -->
      Meta charset="utf-8"content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=0" name="viewport" />
      http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"      Fonts and icons     link rel="stylesheet" type="text/css" href="assets/css/googlefonts.css?family=Roboto:300,400,500,700|Roboto+Slab:400,700|Material+Icons" ="https://maxcdn.bootstrapcdn.com/font-awesome/latest/css/font-awesome.min.css" Material Kit CSS href="assets/css/material-dashboard.css?v=2.1.1" rel="stylesheet" />
    bodydiv class="wrapper ">
        div>
          >
            ="container" style="width: 50%;margin-top: 250px;">
              ="row">
                ="col-md-12">
                  >
                    ="card">

                      ="card-header card-header-primary">
                        h4 ="card-title">登录h4p ="card-category">管理员身份登录后台p>
                      ="card-body">
                          >PHP if (hasInfo()) echo getInfo(); ?>form action="login.PHP" method="post">
                            >
                              ="form-group">
                                label ="bmd-label-floating">用户名labelinput type="text"="adminuser" class="form-control">密码="password"="adminpass"button ="submit"="btn btn-primary pull-right"button="clearfix"></formscript src="assets/js/core/jquery.min.js"script="assets/js/core/popper.min.js"="assets/js/core/bootstrap-material-design.min.js">

数据库结构shop.sql

    /*
     Navicat Premium Data Transfer

     Source Server         : 127.0.0.1
     Source Server Type    : MysqL
     Source Server Version : 80012
     Source Host           : localhost:3306
     Source Schema         : shop

     Target Server Type    : MysqL
     Target Server Version : 80012
     File Encoding         : 65001

     Date: 26/01/2019 10:13:57
    */

    SET NAMES utf8mb4;
    SET FOREIGN_KEY_CHECKS = 0;

    -- ----------------------------
     Table structure for test_admin
    DROP TABLE IF EXISTS `test_admin`;
    CREATE TABLE `test_admin` (
      `id` int(10) unsigned NOT NULL AUTO_INCREMENT,`adminuser` varchar(50) NULL DEFAULT '',`adminpass` char(32) 255) bigint(20) '0'PRIMARY KEY (`id`)
    ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;

     Records of test_admin
    BEGIN;
    INSERT INTO `test_admin` VALUES (1,admin',1)">0192023a7bbd73250516f069df18b5002019-01-23 20:21:032019-01-24 12:56:482130706433);
    COMMIT Table structure for test_cart
     `test_cart`;
     `test_cart` (
      `id` decimal(10,1); font-weight: bold">2) unsigned 0.00text3  Records of test_cart
    INTO `test_cart` 2,1); font-weight: bold">21700.00,1); font-weight: bold">3,1)">{\"3\":{\"quantity\":2,\"product\":{\"id\":\"3\",\"name\":\"Macbook Pro\",\"price\":\"8800.00\",\"code\":\"88888888\",\"description\":\"Macbook Pro\"}},\"4\":{\"quantity\":1,\"product\":{\"id\":\"4\",\"name\":\"\\u534e\\u4e3a\\u624b\\u673a\",\"price\":\"4100.00\",\"code\":\"929868123123123\",\"description\":\"\\u5546\\u54c1\\u63cf\\u8ff0\\uff1a\\r\\n\\r\\n\\u8fd9\\u662f\\u534e\\u4e3a\\u624b\\u673a\"}}}@H_299_404@5,1)">2019-01-24 10:53:24 Table structure for test_order
     `test_order`;
     `test_order` (
      `id`  Records of test_order
    INTO `test_order` 17600.00,\"description\":\"Macbook Pro\"}}}2019-01-24 12:46:33 Table structure for test_product
     `test_product`;
     `test_product` (
      `id` 200) 100) 5  Records of test_product
    INTO `test_product` Macbook Pro88888888@H_299_404@99,1); font-weight: bold">8800.00,1)">2019-01-24 00:19:28@H_299_404@4,1)">华为手机929868123123123商品描述:\r\n\r\n这是华为手机@H_299_404@4100.00,1)">2019-01-24 00:31:28 Table structure for test_user
     `test_user`;
     `test_user` (
      `id` tinyint(3) unsigned 6  Records of test_user
    INTO `test_user` zhangsan4297f44b13955235245b2497399d7a93张三@H_299_404@28,1)">965794175@qq.com132000000002019-01-23 23:54:34wangwu'',1); font-weight: bold">0,1)">wangwu@test.com2019-01-24 09:21:45zhaoliuzhaoliu@test.com2019-01-24 09:35:05@H_299_404@1;

配置数据库文件config.PHP

    <?PHP
    *
     * Created by PHPStorm.
     * Date: 2019/1/23
     * Time: 20:22
     */
    date_default_timezone_set('PRC'return [
        'DB_HOST' => '127.0.0.1','DB_PORT' => '3306','DB_USER' => 'root','DB_PASS' => '123456','DB_NAME' => 'test_shop','DB_PREFIX' => 'test_','DB_CHARSET' => 'utf8',
    ];

操作数据库函数db.func.PHP

    <?PHP

    function connect()
    {
        $config = require dirname(__FILE__) . '/config.PHP';
        $MysqLi = @MysqLi_connect(
            $config['DB_HOST'] . ':' . $config['DB_PORT'],1)">$config['DB_USER'],1)">$config['DB_PASS'],1)">$config['DB_NAME']
        ) or die('Connect Error: ' . MysqLi_connect_errno() . '-' . MysqLi_connect_error());
        MysqLi_set_charset($MysqLi,1)">$config['DB_CHARSET']);
        return $MysqLi;
    }

    function queryOne($sql)
    {
        $MysqLi = connect();
        $result = MysqLi_query();
        $data = [];
        if ($result && MysqLi_num_rows($result) > 0) {
            $data = MysqLi_fetch_assoc($result);
        }
        $datafunction query() {
            while ($res = )) {
                $data[] = $res;
            }
        }
         getDBPrefix()
    {
        ;
        $config['DB_PREFIX'];
    }

    function execute( connect();
        );
        return MysqLi_affected_rows($MysqLi) > 0;
    }

公共函数文件tools.func.PHP

    <?*
     * Created by PHPStorm.
     * Date: 2019/1/23
     * Time: 20:31
     function setSession($key,1)">$data,1)">$prefix = '')
    {
        session_id() || @session_start();
        if (!empty($prefix)) {
            $_SESSION[$prefix][$key] = ;
        } else {
            ;
        }
    }

    function getSession()) {
            isset($key]) ? $key] : [];
        }  {
             [];
        }
    }

    function deleteSession($key] = nullfunction setInfo($info)
    {
        setSession('info',1)">$info,'system');
    }

     getInfo()
    {
       $info = getSession('info',1)">);
       deleteSession('info',1)">);
        hasInfo()
    {
       return !empty(getSession('info',1)">));
    }

判断是否有登陆权限auth.PHP

    <?*
     * Created by PHPStorm.
     * Date: 2019/1/23
     * Time: 22:07
     if (empty(getSession('adminuser','admin'))) {
        header('location: login.PHP'exit;
    }

登陆成功后进入后台首页index.PHP

    PHP
    require '../db.func.PHP';
    require '../tools.func.PHP';
    require 'auth.PHP';
    //1.查询数据库 test_admin
    //2.写sql语句
    $prefix = getDBPrefix();
    $sql = "SELECT id,login_ip 
                    FROM {$prefix}admin ORDER BY created_at DESC";
    $data = query($sql);
    //3.遍历数据

    require 'header.PHP';
    ="card-title ">所有管理员> 控制台所有管理员列表="table-responsive"table ="table table-hover"thead =" text-primary"th
                                ID
                            
                                用户名
                            
                                创建时间
                            
                                最后登录时间
                            
                                最后登录IP
                            theadtbodyPHP foreach ($data as $admin): ?>
                            trtd>
                                    PHP echo $admin['id']; ?>
                                PHP echo $admin['adminuser']; PHP echo $admin['created_at']; PHP echo $admin['login_at']; PHP echo long2ip($admin['login_ip']); PHP endforeach; tablePHP
    require 'footer.PHP';
    ?>

header.PHP

    PHP
    $script = basename($_SERVER['SCRIPT_FILENAME']);
    // 控制台 index.PHP admin_edit.PHP
    // 用户管理 users.PHP user_add.PHP user_edit.PHP
    // 商品管理 products.PHP product_add.PHP product_edit.PHP
    -->
        ="viewport"/>
        
              href="stylesheet"="sidebar" data-color="purple" data-background-color="white"="logo"a ="index.PHP"="simple-text logo-normal"
                    商城
                a="sidebar-wrapper"ul ="nav"li ="nav-item <?PHP echo substr($script,5) == 'index' || substr($script,5) == 'admin' ? 'active' : ''; ?>"="nav-link"="index.PHP"i ="material-icons">dashboardi>控制台li="users.PHP">person>用户管理="products.PHP">library_books>商品管理="carts.PHP">shopping_cart>购物车管理="orders.PHP">list>订单管理 your sidebar here -->
                ul="main-panel" Navbar -->
            nav ="navbar navbar-expand-lg navbar-transparent navbar-absolute fixed-top "="container-fluid"="navbar-wrapper"="navbar-brand"="collapse navbar-collapse justify-content-end"="navbar-nav"="nav-item dropdown"="#" id="navbarDropdownProfile" data-toggle="dropdown" aria-haspopup="true"
                                   aria-expanded="false"="d-lg-none d-md-block"
                                        管理员
                                    ="dropdown-menu dropdown-menu-right" aria-labelledby="navbarDropdownProfile"="dropdown-item"="admin_edit.PHP">编辑="dropdown-divider"="logout.PHP">退出 your navbar here -->
                        nav End Navbar ="content">

footer.PHP

    >

管理员账号密码修改admin_edit.PHP

    PHP
    require '../tools.func.PHP';
    require 'auth.PHP';
    require '../db.func.PHP';
    $current_user = getSession('admin');

    //1.判断是否为post提交
    if (!empty($_POST['adminpass'])) {
      //2.验证新密码和确认密码是否一致
        $adminpass = md5(htmlentities($_POST['adminpass']));
        $newpass = htmlentities($_POST['newpass']);
        $confirmpass = htmlentities($_POST['confirmpass']);
        if ($newpass != $confirmpass) {
            setInfo('两次密码输入不一致');
        } else {
        //3.验证旧密码是否正确 (查询数据库 用id,adminpass)
        $prefix = getDBPrefix();
        $sql = "SELECT id FROM {$prefix}admin 
                    WHERE id = '{$current_user['id']}' 
                    AND adminpass = '$adminpass'
                    ";
        $res = queryOne($sql);
        //4.更新数据表 imooc_admin adminpass
        if ($res) {
          $pass = md5($newpass);
          $sql = "UPDATE {$prefix}admin 
                    SET adminpass = '$pass'
                    WHERE id = '{$current_user['id']}'";
          if (execute($sql)) {
              setInfo('修改密码成功');
          } else {
              setInfo('修改密码失败');
          }
        } else {
            setInfo('旧密码不正确!');
        }
        }

        //5.显示结果到页面
    }



    require 'header.PHP';
    >修改密码>修改当前管理员密码?>
                    ="admin_edit.PHP" disabled name value="<?PHP echo $current_user['adminuser']; ?>">

                        >旧密码>新密码="newpass">确认密码="confirmpass">修改?>

管理员后台登出logout.PHP

    <?*
     * Created by PHPStorm.
     * Date: 2019/1/23
     * Time: 22:06
     // 1. 删除当前登录用户的session
    require '../tools.func.PHP';

    deleteSession('admin');

    header('location: login.PHP');

用户列表显示users.PHP

    PHP
    require '../db.func.PHP';
    require '../tools.func.PHP';
    require 'auth.PHP';
    // 1. 写SQL查询
    $prefix = getDBPrefix();
    $sql = "SELECT id,username,age,name,email,phone,created_at
                    FROM {$prefix}user ORDER BY created_at DESC";
    // 2. 执行查询
    $res = query($sql);
    // 3. 遍历结果

    require 'header.PHP';
    ="col-10">所有用户> 用户列表="col-2"="user_add.PHP"="btn btn-round btn-info"="margin-left: 20px;">添加用户
                                姓名
                            
                                年龄
                            
                                邮箱
                            
                                联系电话
                            
                                注册时间
                            
                                操作
                            PHP foreach ($res as $user): PHP echo $user['id']; PHP echo $user['username']; PHP echo $user['name']; PHP echo $user['age']; PHP echo $user['email']; PHP echo $user['phone']; PHP echo $user['created_at']; ="user_edit.PHP?id=<?PHP echo $user['id']; ?>"
                                    |
                                    ="user_del.PHP?id=<?PHP echo $user['id']; ?>">删除?>

添加用户user_add.PHP

    PHP
    require '../tools.func.PHP';
    require '../db.func.PHP';
    require 'auth.PHP';
    if (!empty($_POST['username'])) {
        // 1. 接收post数据
        $username = htmlentities($_POST['username']);
        $password = htmlentities($_POST['password']);
        $confirmpass = htmlentities($_POST['confirmpass']);
        $name = htmlentities($_POST['name']);
        $age = htmlentities($_POST['age']);
        $email = htmlentities($_POST['email']);
        $phone = htmlentities($_POST['phone']);
        $created_at = date('Y-m-d H:i:s');
        $prefix = getDBPrefix();
        // 2. 验证密码输入是否一致
        if ($password != $confirmpass) {
            setInfo('两次密码输入不一致');
        } else {
            $password = md5($password);
        // 3. 写sql语句
            $sql = "INSERT INTO {$prefix}user(username,password,created_at)
                            VALUES('$username','$password','$age','$name','$email','$phone','$created_at')";
        // 4. 执行添加,如果成功,显示成功信息
            if (execute($sql)) {
                setInfo('添加成功');
            } else {
          setInfo('添加失败');
            }
        }

    }


    require 'header.PHP';
    >添加一个用户="col-md-4"="username"="col-md-6">姓名="name">年龄="number"="age">联系电话="phone">电子邮箱="email"?>

修改用户信息user_edit.PHP

    PHP
    require '../db.func.PHP';
    require '../tools.func.PHP';
    require 'auth.PHP';
    // 1. 接收id
    $id = intval($_GET['id']);
    if (empty($id)) {
        header('location: users.PHP');
    }
    // 2. 根据id查询用户
    $prefix = getDBPrefix();
    $sql = "SELECT id,name 
                    FROM {$prefix}user WHERE id = '$id'";
    $current_user = queryOne($sql);
    if (empty($current_user)) {
      header('location: users.PHP');
    }
    // 3. 将查询出的用户的数据放入到表单当中
    // 4. 判断是否为post提交
    if (!empty($_POST['name'])) {
      // 5. 接收post数据
        $name = htmlentities($_POST['name']);
        $age = htmlentities($_POST['age']);
        $email = htmlentities($_POST['email']);
        $phone = htmlentities($_POST['phone']);
        // 6. 更新数据记录
        $sql = "UPDATE {$prefix}user 
                        SET name = '$name',age = '$age',email = '$email',phone = '$phone'
                        WHERE id = '$id'";
        if (execute($sql)) {
        $current_user = array_merge($current_user,$_POST);
            setInfo('更新成功');
        } else {
            setInfo('更新失败');
        }
        // 7. 显示结果
    }


    require 'header.PHP';
    >修改用户>修改一个用户="user_edit.PHP?id=<?PHP echo $id; ?>"="<?PHP echo $current_user['username']; ?>" disabled class="<?PHP echo $current_user['name']; ?>"="<?PHP echo $current_user['age']; ?>"="<?PHP echo $current_user['phone']; ?>"="<?PHP echo $current_user['email']; ?>">更新信息?>

删除用户user_del.PHP

    <?*
     * Created by PHPStorm.
     * Date: 2019/1/24
     * Time: 10:49
     */
    require '../db.func.PHP'require 'auth.PHP' 1. 接收id
    $id = intval($_GET['id']);
     2. 从数据库当中删除对应的数据
    $prefix = getDBPrefix();
    $sql = "DELETE FROM {$prefix}user WHERE id = '$id'"if (execute()) {
        setInfo('删除成功');
    }  {
        setInfo('删除失败');
    }
     3. 跳回到列表页
    header('location: users.PHP');

商品列表products.PHP

    PHP
    require '../tools.func.PHP';
    require 'auth.PHP';
    require '../db.func.PHP';
    $prefix = getDBPrefix();
    $sql = "SELECT * FROM {$prefix}product ORDER BY created_at DESC ";
    $data = query($sql);
    require 'header.PHP';
    >所有商品> 所有商品列表="product_add.PHP">添加商品>

                ="table table-hover"="table-layout:fixed; "th width="5%"
                                商品编号
                            
                                商品名称
                            
                                商品描述
                            
                                商品库存
                            
                                商品单价
                            
                                商品上架时间
                            
                                编辑
                            PHP foreach ($data as $pro): PHP echo $pro['id']; ?>
                                    PHP echo $pro['code']; PHP echo $pro['name']; PHP echo mb_substr($pro['description'],8,'utf-8') . '...'; PHP echo $pro['stock']; PHP echo $pro['price']; PHP echo $pro['created_at']; >
                                        ="#"
                                        |
                                        ?>

添加商品product_add.PHP

    PHP
    require '../tools.func.PHP';
    require 'auth.PHP';
    require '../db.func.PHP';
    // 1. 判断是否为post提交
    if (!empty($_POST['name'])) {
      // 2. 接收post数据
        $name = htmlentities($_POST['name']);
        $code = htmlentities($_POST['code']);
        $price = doubleval($_POST['price']);
        $stock = intval($_POST['stock']);
        $description = htmlentities($_POST['description']);
        $created_at = date('Y-m-d H:i:s');
        // 3. 写sql语句
        $prefix = getDBPrefix();
        $sql = "INSERT INTO {$prefix}product(name,code,price,stock,description,created_at)
                        VALUES('$name','$code','$price','$stock','$description','$created_at')";
        // 4. 执行插入
        if (execute($sql)) {
            setInfo('添加成功');
        } else {
        setInfo('添加失败');
        }
        // 5. 显示结果
    }


    require 'header.PHP';
    >添加一个商品>商品名称>商品单价="price">商品库存="stock">商品编号="code">商品描述="form-group bmd-form-group"textarea name="description"="form-control" rows="5"textarea?>

购物车列表页carts.PHP

    PHP
    require '../tools.func.PHP';
    require '../db.func.PHP';
    require 'auth.PHP';
    $prefix = getDBPrefix();
    $sql = "SELECT id,quantity,uid,created_at FROM {$prefix}cart ORDER BY created_at DESC";
    $back_cart_data = [];
    $cart = query($sql);
    foreach ($cart as $c) {
      $sql = "SELECT username FROM {$prefix}user WHERE id = '{$c['uid']}'";
      $user = queryOne($sql);
      $c['username'] = $user['username'];
      $back_cart_data[] = $c;
    }
    require 'header.PHP';
    ="col-12">所有购物车> 所有购物车列表
                                购物车用户
                            
                                商品总量
                            
                                购物车总价
                            
                                添加时间
                            PHP foreach ($back_cart_data as $cart): PHP echo $cart['id']; PHP echo $cart['username']; PHP echo $cart['quantity']; PHP echo $cart['price']; PHP echo $cart['created_at']; =""?>

订单列表orders.PHP

    PHP
    require '../tools.func.PHP';
    require 'auth.PHP';
    require '../db.func.PHP';
    $prefix = getDBPrefix();
    $sql = "SELECT id,created_at 
                    FROM {$prefix}order ORDER BY created_at DESC";
    $orders = query($sql);
    require 'header.PHP';
    >所有订单> 所有订单列表
                                下单用户
                            
                                订单价格
                            
                                订单商品数量
                            
                                下单时间
                            PHP foreach($orders as $order): PHP echo $order['id']; PHP echo $order['uid']; PHP echo $order['price']; PHP echo $order['quantity']; PHP echo $order['created_at']; ?>

猜你在找的MySQL相关文章