PHP:注册信息存储/登录信息验证基本原理

  在网站用户经常需要注册新的账号以及对已经注册过的账号进行登录。
  本文使用 php 实现基本功能并对基本原理进行讲解。

一. 注册(非 JSON)

1. HTML部分(register.html)

  首先完成 HTML 页面的基本布局

<!doctype html>
<html lang="en">
<head>
 <meta charset="UTF-8" />
 <title>Register_Page</title>
</head>
<body>
 <form action="registerHandler.php" method="post">
  Name:<input type="text" name="user" id="user" />
  Code:<input type="text" name="pass" id="pass" />
  <input type="submit" value="register"/>
 </form>
</body>
</html>
  • 这里采用 post 方式
  • action 的对象为将要创建的 registerHandler.php 文件

2. php 部分(registerHandler.php)

  我们在 HTML 文件里得到了 user 和 pass 的两个值,并将他们传递给了.php 文件。
php 文件内利用字符串的拼接特性将这两个值拼接为一个字符串。
  再将这个字符串写入指定的 txt 文件,注意 file 函数如果在没有找到指定 txt 文件的时候,会重新创建一个 txt 文件。这样信息就被保存在了指定的空间内。

代码如下:

<?php
 // 获取 post 请求中包含的注册数据
 $user = $_POST["user"];
 $pass = $_POST["pass"];
 // 组成一个有规则的字符串,等待写入文件
 $str = "user = {$user};pass = {$pass}\n";
 $f = fopen("file/user.txt", "a");
 // 把本次获得的字符串写入到文档中
 fwrite($f, $str);
 // 关闭文件
 fclose($f);
?>

二. 将用户信息以 Table 格式显示(非必须,只为看效果)

原理:
  1. 将 php 文件嵌入到 HTML 文件内。
  2. 使用 explode 函数,将$str = "user = {$user};pass = {$pass}\n";按照;拆分为user = {$user}pass = {$pass}。再分别通过=拆分,分别获取$user$pass。通过循环分别获取,并创建 table 标签,然后依次 echo 写入,达到目标。

<!doctype html>
<html lang="en">
 <head>
  <meta charset="UTF-8" />
  <title>
  </title>
 </head>
 <body>
  <table border="1">
   <tr><th>用户名</th><th>密码</th></tr>
   <?php
   // 1. 读取文件,获取信息数组
   $arr = file("file/user.txt");
   // print_r($arr);
   echo "<hr>"."下面是把 user.txt 的用户名和密码输出为表格";
   foreach ($arr as $value) {
   $userinfo = explode(";", $value);
   ?>
   <tr>
    <td>
     <?php
     $username = explode("=", $userinfo[0])[1];
     echo $username;
     ?>
    </td>
    <td>
     <?php
     $userpass = explode("=", $userinfo[1])[1];
     echo $userpass;
     ?>
     <?php } ?>
    </td>
   </tr>
  </table>
 </body>
</html>
生成包含用户名及密码的 Table 表格

三. 登录验证

原理:
  1. 布局与注册相似,但是 action 指向另一个创建的 login.php 文件。
  2. 在 login.php 文件中,获取到此次输入的 user 和 pass 值,以注册相同的格式拼接为字符串 $str
  3. 通过 file_get_contents() 函数将user.txt 文件以整个字符串的形式导出,定义为$f
  4. 判断:若 $f 中包含 $str,那么代表我输入的这一段用户名和密码在数据库中是能找到的,即登陆成功。
  5. 判断方法:explode 方法,若$f可以被$str拆分为含有两个或两个以上元素的数组,那么代表$f中包含 $str(在这里也可以使用 strpos 函数进行判断)。

代码如下:

<?php
header("Content-type:text/html;charset=utf-8");
$user = $_POST["user"];
$pass = $_POST["pass"];
$str = "user = {$user};pass = {$pass}\n";
$f = file_get_contents("file/user.txt");
$tmpArr = explode($str, $f);
if (count($tmpArr) > 1) echo "登陆成功!数据库有你的信息!";
else echo "登录失败!数据库里找不到你!";
?>

  至此,我们完成了登录的判断,当然,方法不唯一。

四. 注册(JSON)

  在这段代码里注册信息,我们使用了json_encodejson_decode方法将信息转化为 JSON 格式写入文档中,方便了操作和以后的使用。登录方法同以上。
  JSON 的操作方式与非 JSON 类似,并没有本质的区别,不做赘述。

代码如下:

1. HTML部分(json_register.html)
<!doctype html>
<html>
<head>
 <meta charset="UTF-8" />
 <title>Document</title>
</head>
<body>
 <form action="json_registerHandler.php" method="post">
  用户名:<input type="text" name="user"/><br>
  密__码:<input type="text" name="pass"/><br>
  <input type="submit" value="注册"/>
 </form>
</body>
</html>
2. php 写入注册信息部分
<?php
if (count($_POST) != 0) {
 $str = json_encode($_POST) . "\n";
 $f = fopen("file/jason_user.txt", "a");
 fwrite($f, $str);
 fclose($f);
}
?>
3. Table 打印注册信息部分
<!doctype html>
<html>
 <head>
  <meta charset="UTF-8" />
  <title>Document</title>
 </head>
 <body>
  <table border="1">
   <tr><th>用户名</th><th>密码</th></tr>
   <?php
    $arr = file("file/jason_user.txt");
    foreach ($arr as  $value) {
    $userL = json_decode($value);
   ?>
   <tr>
    <td>
     <?php 
      $userName = $userL -> user;
      echo $userName;
     ?>
    </td>
    <td>
     <?php 
      $passName = $userL -> pass;
      echo $passName;
     ?>
    </td>
   </tr>
   <?php } ?>
   <!--把 json_user.txt 打一下看看样子而已-->
   <?php
    echo file_get_contents("file/jason_user.txt");
   ?>
  </table>
 </body>
</html>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,444评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,421评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,363评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,460评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,502评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,511评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,280评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,736评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,014评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,190评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,848评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,531评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,159评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,411评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,067评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,078评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,644评论 18 139
  • (源自摘抄整理)https://www.91ri.org/11494.html Webshell实现与隐藏探究 一...
    JackyTsuuuy阅读 20,750评论 2 13
  • 一、php可以做什么 php是一种可以在服务器端运行的编程语言,可以运行在Web服务器端。 php是一门后台编程语...
    空谷悠阅读 3,091评论 4 97
  • 1 她虽疲累但已习惯在高楼林立间的水泥路面上为了挣食奔走。高价租来的公寓其实只有那张松软的床属于她,其他的东西整齐...
    vitors阅读 257评论 2 1
  • 四天三夜的复训结束了!不舍同修们在一起的敞开、看见、陪伴!感恩爸爸(陈浪老师),感恩修文老师,感恩同修们! ...
    陈玫瑰7W6阅读 607评论 2 3