登陆例子:(请注意一定要自己敲一遍,不要CV大法)
首先上一下成果图,激起同学们写的欲望,登录页如下:

点击登陆之后如下:


说明哦了,么问题。接下来自己实现一下。

首先数据库信息
新建一个名为 login 的数据库,再建一个 user 表,表的结构如下图:

然后开始编码。

login.php代码

  1. <?php
  2. session_start();
  3. if(( $_POST['username']!=null)&&( $_POST['password']!=null)){
  4. $userName = $_POST['username'];
  5. $password = $_POST['password'];
  6. //从db获取用户信息 数据库信息改成自己的
  7. $conn = mysqli_connect('host','username','password','login');
  8. $res = mysqli_query($conn,"select * from user where `username` = '$userName' ");
  9. $row = mysqli_fetch_assoc($res);
  10. if($row['passwd']== $password){
  11. //密码验证通过,设置session,把用户名和密码保存在服务端
  12. $_SESSION['userName']= $userName;
  13. $_SESSION['password']= $password;
  14. //最后跳转到登录后的欢迎页面 //注意:这里我们没有像cookie一样带参数过去
  15. header('Location: welcome.php');
  16. }
  17. }
  18. ?>
  19. <html>
  20. <head>
  21. <!-- 这里指明页面编码 -->
  22. <metacharset="utf-8">
  23. </head>
  24. <body>
  25. <formaction=""method="POST">
  26. <div>
  27. 用户名:<inputtype="text"name="username"/>
  28. 密 码:<inputtype="text"name="password"/>
  29. <inputtype="submit"value="登录">
  30. </div>
  31. </form>
  32. </body>
  33. </html>

welcome.php 这里我们用的是session中的信息,而不是像cookie一样在url中带参数过来

  1. <?php
  2. session_start();
  3. $userName = $_SESSION['userName'];
  4. ?>
  5. <html>
  6. <head>
  7. </head>
  8. <body>
  9. welcome,<?php echo $userName;?>
  10. </body>
  11. </html>

购物车的例子:(请注意一定要自己敲一遍,不要CV大法)
数据库信息:建立名为test的数据库,库中有个shop表,表结构如下图:

开始编码吧!

goodsList.php 这个是商品展示页,效果图如下:

说明一下,如果是第一次购买某物品,则在购物车中加入该商品信息和计算总价,如果再次点击购买,则已购商品数量加1,总价重新计算,查看购物车链接可以到购物车页面。

  1. <?php
  2. $goods = array();
  3. //从数据库获取商品信息存入$goods二维数组
  4. $i =0;
  5. //这里请换上自己的数据库相关信息
  6. mysqli_connect('host','username','password','test');
  7. $res = mysqli_query($conn,'select * from shop');
  8. //这里把商品信息放到$goods二维数组,每一维存的是单个
  9. //商品的信息,比如商品名、价格。
  10. while($row = mysqli_fetch_assoc($res)){
  11. $goods[$i]['id']= $row['id'];
  12. $goods[$i]['name']= $row['name'];
  13. $goods[$i]['price']= $row['price'];
  14. $i++;
  15. }
  16. ?>
  17. <!DOCTYPE html>
  18. <html>
  19. <head>
  20. <metahttp-equiv="Content-Type"content="text/html;charset=utf-8">
  21. </head>
  22. <body>
  23. <?php
  24. //取出商品信息显示在页面上,并添加购买功能
  25. foreach($goods as $value){
  26. echo ' 商品名 '. $value['name'].' 价格 '. $value['price'];
  27. echo "<a href=buy.php?name=". $value['name'].'&price='. $value['price'].">购买</a>";
  28. echo '<br />';
  29. }
  30. ?>
  31. <ahref="shoppingCart.php">查看购物车</a>
  32. </body>
  33. </html>

buy.php 此页完成购买功能,然后再次跳转到商品列表。主要是做了在session中处理购买商品操作。

  1. <html>
  2. <head>
  3. <metahttp-equiv="Content-Type"content="text/html;charset=utf-8">
  4. </head>
  5. <body>
  6. <?php
  7. //开启session
  8. session_start();
  9. //获取传过来的商品名和价格
  10. $name = $_GET['name'];
  11. $price = $_GET['price'];
  12. //把session中的商品信息和传过来的(刚买的)商品信息对比
  13. $goods = $_SESSION['goods'];
  14. if($name == $goods[$name]['name']){
  15. //买过的话,则总价格增加,相应商品数量增加
  16. $_SESSION['totalPrice']+= $price;
  17. $goods[$name]['number']+=1;
  18. }else{
  19. //第一次买的话,将相应的商品信息添加到session中
  20. $goods[$name]['name']= $name;
  21. $goods[$name]['price']= $price;
  22. $goods[$name]['number']+=1;
  23. $_SESSION['totalPrice']+= $price;
  24. }
  25. $_SESSION['goods']= $goods;
  26. //购买处理完毕后跳转到商品列表
  27. header('location: goodsList.php');
  28. ?>
  29. </body>
  30. </html>

shoppingCart.php 此页展示购物车中的商品、价格、总价等信息。

效果图如下:

  1. <html>
  2. <head>
  3. <metahttp-equiv="Content-Type"content="text/html;charset=utf-8">
  4. </head>
  5. <body>
  6. <?php
  7. session_start();
  8. //将session中的商品信息(即购物车中的商品)和总价显示到页面
  9. $goods = $_SESSION['goods'];
  10. echo '您买了:<br />';
  11. foreach($goods as $value){
  12. echo $value['name'].' 价格 '. $value['price'].' 数量 '. $value['number'].'<br />';
  13. }
  14. echo '总价:'. $_SESSION['totalPrice'].'<br />';
  15. ?>
  16. <ahref="goodsList.php">返回商品列表</a>
  17. </body>
  18. </html>

购物车的例子完成了,自己亲自完成一遍后是不是很有成就感!!你很厉害!!

前端PHP入门-035-Session的实例的更多相关文章

  1. openresty 前端开发入门五之Mysql篇

    openresty 前端开发入门五之Mysql篇 这章主要演示怎么通过lua连接mysql,并根据用户输入的name从mysql获取数据,并返回给用户 操作mysql主要用到了lua-resty-my ...

  2. PHP之session相关实例教程与经典代码

    ·php 中cookie和session的用法比较 ·phpmyadmin报错:Cannot start session without errors问题 ·php中cookie与session应用学 ...

  3. web前端开发入门全套学习方法路径,兼职在家做网站也能月入上万!

    前端学习路径 1.WEB前端快速入门 在本阶段,我们需要掌握 HTML 与 CSS 基础,当然,也包含 H5 和 C3 的新特性.这个部分内容非常简单,而且非常容易掌握.相信你也更愿意学习这个部分,毕 ...

  4. 每天成长一点---WEB前端学习入门笔记

    WEB前端学习入门笔记 从今天开始,本人就要学习WEB前端了. 经过老师的建议,说到他每天都会记录下来新的知识点,每天都是在围绕着这些问题来度过,很有必要每天抽出半个小时来写一个知识总结,及时对一天工 ...

  5. WCF会话(Session)与实例(Instance)管理

    一.理解Session 1.Session的作用:保留Client和Service之间交互的状态,确保Client与Service之间交互唯一性(SessionId),即:多个Client同时访问Se ...

  6. 使用 gulp 搭建前端环境入门篇(转载)

    本文转载自: 使用 gulp 搭建前端环境入门篇

  7. Web前端小白入门指迷

    前注:这篇文章首发于我自己创办的服务于校园的技术分享 [西邮 Upper -- 004]Web前端小白入门指迷,写得很用心也就发在这里. 大前端之旅 大前端有很多种,Shell 前端,客户端前端,Ap ...

  8. Web前端JQuery入门实战案例

    前端jquery入门到实战 为什么要学习Jquery?因为生活. 案例: <!DOCTYPE html> <html lang="zh-CN"> <h ...

  9. ASP.NET MVC下实现前端视图页的Session

    在ASP.NET MVC的控制器中可以实现Session处理.如果要在前端视图页实现Session该如何做呢?可以使用window.sessionStorage来做. AlexChittock用jQu ...

  10. 鸿蒙OS前端开发入门指南:网络图片_Image渲染网络图片

    目录: 1.开启明文传输 2.权限申请 3.引入http插件 4.案例展示 5.<鸿蒙OS前端开发入门指南>文章合集 开启明文传输 在config.json配置文件添加如下配置(如果不开启 ...

随机推荐

  1. Java访问控制

    转自:菜鸟教程

  2. Scrum立会报告+燃尽图(Beta阶段第二周第一次)

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2409 项目地址:https://coding.net/u/wuyy694 ...

  3. timestamp 学习

    该答案摘抄自CSDN. 哇,奇迹,跨度三年了,不知道楼主是否已经解决了此问题. 路过,简单说一下,timestamp 主要是记录该行的最后修改时间戳, 注意,这个时间戳是不可以转换为时间的,只能标注该 ...

  4. C#控制台应用程序

    使用C#创建控制台应用程序的基本步骤: (1)创建项目: (2)编辑C#源代码: (3)编译运行: 例题:在控制台输出“Hello world!”. 第一步:文件→新建→项目:选择“项目类型”为Vis ...

  5. Chrome浏览器超强调试工具

    原文:http://lizanhong2011.blog.163.com/blog/static/18028516720117301312729/ 在Google Chrome浏览器出来之前,我一直使 ...

  6. [二叉查找树] 1115. Counting Nodes in a BST (30)

    1115. Counting Nodes in a BST (30) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Y ...

  7. Nodejs学习笔记(一)--- 操作Mysql数据库

    对于一门语言的学习,我个人觉得最好的方式就是通过一个项目来展示,所以从基本的一些模块去了解是最好的方式对于Mysql怎么去链接数据库这个我是在网上找到的(其实一直想找官方文档的,发现没有它的踪迹,(后 ...

  8. Solr初步研究

    Solr是一个高性能,采用Java5开发,Solr基于Lucene的全文搜索服务器.同时对其进行了扩展,提供了比Lucene更为丰富的查询语言,同时实现了可配置.可扩展并对查询性能进行了优化,并且提供 ...

  9. Scrum Meeting Beta - 4

    Scrum Meeting Beta - 4 NewTeam 2017/12/2 地点:新主楼F座二楼 任务反馈 团队成员 完成任务 计划任务 安万贺 完成了部分页面标题栏颜色的修改和字体的调整Iss ...

  10. QP(Quote-Printable) 编码

    QP(Quote-Printable)   方法,通常缩写为“Q”方法,其原理是把一个 8   bit   的字符用两个16进制数值表示,然后在前面加“=”.所以我们看到经过QP编码 后的文件通常是这 ...