您的位置:首页 > 编程语言 > PHP开发

php学习——登录验证(第一级)

2016-01-21 22:30 591 查看
最近一段时间在学php,昨天和今天又在W3C上快速的过了一遍HTML,CSS,有些东西总是记不住,然后之前又快速的过了一边php,打算写一个登录验证的小代码练练手,也记录一下过程中新学习到的一些知识点,一级级往上升。
话不多说,上代码先~~~

说明一下代码目录结构,在同一个目录下三个文件:
index.html//登录页面
login_auth.php//验证页面
index.php//登录成功页面

数据库的结构是:
user:数据库
=》username表

=>username 字段名

=>password 字段名

在index.html页面中,代码如下,比较简单,我就不多说啦。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>login</title>
<style>
body {text-align: center;position: relative;}
</style>
</head>
<body>
<form name="login" action="login_auth.php" method="post">
username:
<input type="text" name="user"/></br>
password:
<input type="password" name="pwd"/></br>
<input class="submit" type="submit" value="登录"/>
</form>
</body>
</html>
点击登录后,会触发表单动作,跳转到login_auth.php页面认证

login_auth.php:
<?php
header("Content-Type: text/html;charset=utf-8");
$username=$_POST['user']; //$_POST 变量是一个数组,内容是由 HTTPPOST方法发送的变量名称和值
$password=$_POST['pwd'];
if($username==""){
echo "请输入用户名";
echo "<a href='index.html'>返回</a>";
}elseif($password==""){
echo  "请输入密码";
echo "<a href='index.html'>返回</a>";
}else{
$link=mysql_connect("localhost","root","")or die("不能连接数据库");
mysql_select_db("user",$link)or die("选择错误");
$sql="select * from username where username='$username' AND password='$password'";
$result=mysql_query($sql,$link);
$news=mysql_fetch_assoc($result);
mysql_free_result($result);
if($news){
echo "登陆成功";
echo "<a href='index.php'>登陆</a>";
}else{
echo "密码错误或用户名不正确";
echo "<a href='index.html'>返回</a>";
}
}
?>
由于页面中有中文,为防止乱码,需要在头部增加一句:
header("Content-Type: text/html;charset=utf-8");
以上使用了几个mysql数据库的函数
mysql_connect:连接一个数据库
语法:
mysql_connect(servername,username,password);
servername	可选。规定要连接的服务器。默认是 "localhost:3306"。
username	可选。规定登录所使用的用户名。默认值是拥有服务器进程的用户的名称。
password	可选。规定登录所用的密码。默认是 ""。
mysql_select_db:选择数据库
mysql_select_db(database,connection)
database	必需。规定要选择的数据库。
connection	可选。规定 MySQL 连接。如果未指定,则使用上一个连接。
如果成功,则该函数返回 true。如果失败,则返回 false。
mysql_query:执行一条 MySQL 查询。

mysql_query(query,connection)
query 必需。规定要发送的 SQL 查询。注释:查询字符串不应以分号结束。
connection 可选。规定 SQL 连接标识符。如果未规定,则使用上一个打开的连接。
mysql_fetch_assoc:从结果集中取得一行作为关联数组。返回根据从结果集取得的行生成的关联数组,如果没有更多行,则返回 false。如

Array
(
[userame] => admin
[password] => 123456
)

mysql_fetch_assoc(data)
mysql_free_result:mysql_free_result() 函数释放结果内存。如果成功,则返回 true,如果失败,则返回 false。
所以有了以上的代码啦~~~
是die() 函数输出一条消息,并退出当前脚本。该函数是 exit() 函数的别名。
这里特地在说一下 or这个语法:之所以 用 or 可以达到,当函数错误后,执行or后面的函数是因为:
1.逻辑运算的运算顺序是从左向右
2.or运算符的左结合性
3.or运算中,如果运算时有值为真了,则整个表达式为真,后面不需要运算
终合上面三个因素,当or左侧函数运行正常(返回非假值),则不会执行后面的函数
这里利用了or的这个特性,将die(终止并输出函数)用于此处,巧妙的实现了函数异常而报错的功能
根据上面的分析,想到如果左侧函数就是返回假的函数,或者无返回值的函数,应该也是执行后面的函数mysql_connect()执行错误,并不是这个函数本身执行错误了,如果是它本身执行错误是PHP的系统错误
它仅仅是返回了一个假值而已。
那这是一个非常简陋的代码,时间不早啦,今天就先写到这,下一次介绍一下其中存在的一些隐患与改进的地方~~
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  php 登录 验证