【php增删改查实例】第十八节 - login.php编写
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,否则,认为用户名和密码错误。还有一种情况,就是单单根据用户名去查,如果查不到这个用户名,就提示用户用户名不存在。
$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>";
- 异步登陆
在上一节中,我们使用的是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编写的更多相关文章
- 【php增删改查实例】第八节 - 部门管理模块(编写PHP程序)
首先,在同级目录新建一个query.php文件: 接着,去刷新页面,打开F12,NetWork,看看当前的请求能不能走到对应的php文件? 这就说明datagrid确实能够访问到query.php 只 ...
- python链接oracle数据库以及数据库的增删改查实例
初次使用python链接oracle,所以想记录下我遇到的问题,便于向我这样初次尝试的朋友能够快速的配置好环境进入开发环节. 1.首先,python链接oracle数据库需要配置好环境. 我的相关环境 ...
- java:JSP(JSPWeb.xml的配置,动态和静态导入JSP文件,重定项和请求转发,使用JSP实现数据库的增删改查实例)
1.JSP的配置: <%@ page language="java" import="java.util.*" pageEncoding="UT ...
- yii2.0增删改查实例讲解
yii2.0增删改查实例讲解一.创建数据库文件. 创建表 CREATE TABLE `resource` ( `id` int(10) NOT NULL AUTO_INCREMENT, `textur ...
- 百度鹰眼Java接口调用增删改查实例
因感觉百度鹰眼的使用场景比较符合实际业务,于是对百度鹰眼做了简单功能调试.刚开始使用springframework封装的RestTemplate,但是测试提示ak参数不存在.后又试了几种方法,均提示a ...
- 【php增删改查实例】第四节 -自己 DIY 一个数据库管理工具
本节介绍如何自己DIY一个数据库管理工具,可以在页面输入sql 进行简单的增删改查操作. 首先,找到xampp的安装目录,打开htdocs: 新建一个php文件,名称为 mysqladmin.php ...
- Maven多模块项目+MVC框架+AJAX技术+layui分页对数据库增删改查实例
昨天刚入门Maven多模块项目,所以简单写了一个小测试,就是对数据库单表的增删改查,例子比较综合,写得哪里不妥还望大神赐教,感谢! 首先看一下项目结构: 可以看到,一个项目MavenEmployee里 ...
- 【php增删改查实例】第十节 - 部门管理模块(新增功能)
正常情况下,在一个部门管理页面,不仅仅需要展示列表数据,还需要基本的增删改操作,所以,我们先把之前写好的新增功能集成进来. 在toolbar中,添加一个新增按钮. <div id="t ...
- 关于利用PHP访问MySql数据库的逻辑操作以及增删改查实例操作
PHP访问MySql数据库 <?php //造连接对象$db = new MySQLi("localhost","root","",& ...
随机推荐
- 《Inside C#》笔记(完) 程序集
程序集内部包含了各种相关的模块.资源文件.配置文件等,将这些在功能上相关的文件整合到单个文件中,以便于部署和维护.使用C#编译器编译程序时,生成的便是程序集. 一.清单数据 a)如果编译的是独立应用程 ...
- Selenium Webdriver 动态设置 Proxy
Step 1: Visiting "about:config" driver.get("about:config"); Step 2 : Run script ...
- Backbone.js学习之旅(一)
前言 刚到粑粑公司,就学习各种框架,进行各种开发,为了纪念挥泪的青春,只好写下…… 希望能合您胃口^_^!!! The First(文件准备) backobone 强制依赖于 underscore.j ...
- .Net Core 2.0 生态(1).NET Standard 2.0 特性介绍和使用指南
.NET Standard 2.0 发布日期:2017年8月14日 公告原文地址 前言 早上起来.NET社区沸腾了,期待已久的.NET Core 2.0终于发布!根据个人经验,微软的产品一般在2.0时 ...
- Appium学习——Appium工作原理
appium的工具原理 Appium-client>>>>Appium-server>>>>移动设备 ========================= ...
- Linux Regulator Framework(2)_regulator driver
转自蜗窝科技:http://www.wowotech.net/pm_subsystem/regulator_driver.html 说实话,这篇好难懂啊... 1. 前言 本文从regulator d ...
- emWin及StemWin使用中关于菜单栏的应用与问题
前言:在我看来,emWin和StemWin就是基本相同的库文件,关于这个库文件的移植,网络上有很多教材,比如“ALIENTEK emWin开发手册”,他们家提供了各种STM32系列的开发手册,我这里记 ...
- spring IOC中三种依赖注入方式
Spring的核心思想是IOC和AOP,IOC-控制反转,是一个重要的面向对象编程的法则,用来消减计算机程序之间的耦合问题,控制反转一般分为两种类型,依赖注入和依赖查找,依赖什么?为什么需要依赖?注入 ...
- ping 127.0.0.1和ping本地ip分别测试什么?
ping 127.0.0.1 是你本地的回环地址! 实际上只要是127.0.0.1到127.255.255.255都是回环地址!都是可以PING检查的! 它能ping通,说明你的TCP/IP协议栈没问 ...
- 启用crontab
1.登录到root用户. 2.在root下输入:crontab -e 3.可能会提示你: no crontab for root - using an empty one 然后会叫你“Select a ...