1.对用户名和密码进行非空判断(后台验证)

    $username;
$password; if(isset($_POST['username']) && $_POST['username'] != null){
$username = $_POST['username'];
}else{
echo "<h2 style='color:red'>用户名不能为空!</h2>";
return;
} if(isset($_POST['password']) && $_POST['password'] != null){
$password = md5($_POST['password']);
}else{
echo "<h2 style='color:red'>密码不能为空!</h2>";
return;
}

2. 进行数据库链接

$conn = mysql_connect("localhost","root","");
$db = mysql_select_db("test",$conn);
mysql_query("set names utf8");
  1. 根据用户名和密码进行用户表的查询,如果用户存在,那么查询出来的数量肯定等于1,否则,认为用户名和密码错误。还有一种情况,就是单单根据用户名去查,如果查不到这个用户名,就提示用户用户名不存在。
$sql = "select count(*) as total from tm_users where username = '$username'";

	$rs = mysql_query($sql);

	while($row = mysql_fetch_array($rs)){
if($row["total"] != 1){
echo "<h2 style='color:red'>该用户名不存在!</h2>";
return;
}
} $sql = "select count(*) as total from tm_users where username = '$username' and password = '$password'"; $rs = mysql_query($sql); while($row = mysql_fetch_array($rs)){
if($row["total"] != 1){
echo "<h2 style='color:red'>用户名或者密码错误!</h2>";
return;
}
} echo "<h2 style='color:green'>恭喜,登录成功!</h2>";
  1. 异步登陆

    在上一节中,我们使用的是form表单提交的方式,也就是俗称的同步登陆。这样一来,如果后台不返回数据,那么用户什么都做不了。现在,我们使用sleep函数来模拟后台执行时间过长的问题。
sleep(5000);



如果因为网络等问题,后台处理请求的时间过长,用户除了等待,什么事情也做不了。这个就是同步提交的一个弊端。



如图所示,同步就类似于打电话,如果对方不接,打电话的那个人只能一直等待,不想等了,就把电话挂了。如果是异步的方式,就好比两个人发短信,你什么时候回复,我就什么时候看,不会影响我当期所做的任何事情。

现在来演示异步提交。

16.1 把login2.html 拷贝到这个目录:

C:\xampp\htdocs\5-7\login

打开浏览器,访问地址:http://localhost:8080/5-7/login/login2.html



用户名和密码的非空判断,在前台JS中也有处理。如果用户名和密码都不为空,那么就会进行异步提交,异步提交采用的是ajax方法,在第281行:

16.2 编写login2.php

先进行一下登录成功的测试:

<?php
$resultData = array();
$resultData["errCode"] = 0;
$resultData["errMsg"] = ""; echo json_encode($resultData); ?>

啥也不干,直接返回没有错误的结果对象,然后login2.html就会进入success方法:



这边还做了一个小修改,当登录成功的时候,就去访问main.html。

16.3 后台非空判断

//后台判断用户名和密码是否为空
$username;
$password; if(isset($_POST['account']) && $_POST['account'] != null){
$username = $_POST['account'];
}else{
$resultData["errCode"] = -1;
$resultData["errMsg"] = "用户名不能为空!";
echo json_encode($resultData);
return;
} if(isset($_POST['password']) && $_POST['password'] != null){
$password = md5($_POST['password']);
}else{
$resultData["errCode"] = -1;
$resultData["errMsg"] = "密码不能为空!";
echo json_encode($resultData);
return;
}

16.4 验证用户名是否存在?

	//验证用户名是否存在?
$sql = "select count(*) as total from tm_users where username = '$username'"; $rs = mysql_query($sql); while($row = mysql_fetch_array($rs)){
if($row["total"] != 1){
$resultData["errCode"] = -1;
$resultData["errMsg"] = "该用户名不存在!";
echo json_encode($resultData);
return;
}
}

16.5 验证用户名和密码是否正确?

//验证用户名和密码是否正确?
$sql = "select count(*) as total from tm_users where username = '$username' and password = '$password'"; $rs = mysql_query($sql); while($row = mysql_fetch_array($rs)){
if($row["total"] != 1){
$resultData["errCode"] = -1;
$resultData["errMsg"] = "用户名或者密码错误!";
echo json_encode($resultData);
return;
}
}

源码获取:https://www.jianshu.com/p/4977bd0073d5

【php增删改查实例】第十八节 - login.php编写的更多相关文章

  1. 【php增删改查实例】第八节 - 部门管理模块(编写PHP程序)

    首先,在同级目录新建一个query.php文件: 接着,去刷新页面,打开F12,NetWork,看看当前的请求能不能走到对应的php文件? 这就说明datagrid确实能够访问到query.php 只 ...

  2. python链接oracle数据库以及数据库的增删改查实例

    初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...

  3. java:JSP(JSPWeb.xml的配置,动态和静态导入JSP文件,重定项和请求转发,使用JSP实现数据库的增删改查实例)

    1.JSP的配置: <%@ page language="java" import="java.util.*" pageEncoding="UT ...

  4. yii2.0增删改查实例讲解

    yii2.0增删改查实例讲解一.创建数据库文件. 创建表 CREATE TABLE `resource` ( `id` int(10) NOT NULL AUTO_INCREMENT, `textur ...

  5. 百度鹰眼Java接口调用增删改查实例

    因感觉百度鹰眼的使用场景比较符合实际业务,于是对百度鹰眼做了简单功能调试.刚开始使用springframework封装的RestTemplate,但是测试提示ak参数不存在.后又试了几种方法,均提示a ...

  6. 【php增删改查实例】第四节 -自己 DIY 一个数据库管理工具

    本节介绍如何自己DIY一个数据库管理工具,可以在页面输入sql 进行简单的增删改查操作. 首先,找到xampp的安装目录,打开htdocs: 新建一个php文件,名称为 mysqladmin.php ...

  7. Maven多模块项目+MVC框架+AJAX技术+layui分页对数据库增删改查实例

    昨天刚入门Maven多模块项目,所以简单写了一个小测试,就是对数据库单表的增删改查,例子比较综合,写得哪里不妥还望大神赐教,感谢! 首先看一下项目结构: 可以看到,一个项目MavenEmployee里 ...

  8. 【php增删改查实例】第十节 - 部门管理模块(新增功能)

    正常情况下,在一个部门管理页面,不仅仅需要展示列表数据,还需要基本的增删改操作,所以,我们先把之前写好的新增功能集成进来. 在toolbar中,添加一个新增按钮. <div id="t ...

  9. 关于利用PHP访问MySql数据库的逻辑操作以及增删改查实例操作

    PHP访问MySql数据库 <?php //造连接对象$db = new MySQLi("localhost","root","",& ...

随机推荐

  1. 《Inside C#》笔记(完) 程序集

    程序集内部包含了各种相关的模块.资源文件.配置文件等,将这些在功能上相关的文件整合到单个文件中,以便于部署和维护.使用C#编译器编译程序时,生成的便是程序集. 一.清单数据 a)如果编译的是独立应用程 ...

  2. Selenium Webdriver 动态设置 Proxy

    Step 1: Visiting "about:config" driver.get("about:config"); Step 2 : Run script ...

  3. Backbone.js学习之旅(一)

    前言 刚到粑粑公司,就学习各种框架,进行各种开发,为了纪念挥泪的青春,只好写下…… 希望能合您胃口^_^!!! The First(文件准备) backobone 强制依赖于 underscore.j ...

  4. .Net Core 2.0 生态(1).NET Standard 2.0 特性介绍和使用指南

    .NET Standard 2.0 发布日期:2017年8月14日 公告原文地址 前言 早上起来.NET社区沸腾了,期待已久的.NET Core 2.0终于发布!根据个人经验,微软的产品一般在2.0时 ...

  5. Appium学习——Appium工作原理

    appium的工具原理 Appium-client>>>>Appium-server>>>>移动设备 ========================= ...

  6. Linux Regulator Framework(2)_regulator driver

    转自蜗窝科技:http://www.wowotech.net/pm_subsystem/regulator_driver.html 说实话,这篇好难懂啊... 1. 前言 本文从regulator d ...

  7. emWin及StemWin使用中关于菜单栏的应用与问题

    前言:在我看来,emWin和StemWin就是基本相同的库文件,关于这个库文件的移植,网络上有很多教材,比如“ALIENTEK emWin开发手册”,他们家提供了各种STM32系列的开发手册,我这里记 ...

  8. spring IOC中三种依赖注入方式

    Spring的核心思想是IOC和AOP,IOC-控制反转,是一个重要的面向对象编程的法则,用来消减计算机程序之间的耦合问题,控制反转一般分为两种类型,依赖注入和依赖查找,依赖什么?为什么需要依赖?注入 ...

  9. ping 127.0.0.1和ping本地ip分别测试什么?

    ping 127.0.0.1 是你本地的回环地址! 实际上只要是127.0.0.1到127.255.255.255都是回环地址!都是可以PING检查的! 它能ping通,说明你的TCP/IP协议栈没问 ...

  10. 启用crontab

    1.登录到root用户. 2.在root下输入:crontab -e 3.可能会提示你: no crontab for root - using an empty one 然后会叫你“Select a ...