php 实现简单的登录功能示例【基于thinkPHP框架】

下面是详细的“php 实现简单的登录功能示例【基于thinkPHP框架】”攻略。

前言

在网站开发中,登录功能是非常常见的功能。本文将介绍如何基于thinkPHP框架实现简单的登录功能。

思路

实现登录功能,最主要的点就是如何对用户的账号和密码进行验证。我们可以将用户账号和密码存储在数据库中,当用户输入账号和密码时,我们可以对数据库中存储的账号和密码进行比较,如果账号和密码匹配,则登录成功;反之登录失败。

实现步骤

1. 创建数据库

首先我们需要创建一个用户表,用于存储用户的账号和密码信息。可以使用如下 SQL 语句创建一个名为 user 的表。

CREATE TABLE `user` (
    `id` INT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
    `username` VARCHAR(50) NOT NULL,
    `password` CHAR(32) NOT NULL,
    PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;

2. 创建登录页面

在thinkPHP框架中,我们可以使用MVC模式来开发网站,首先我们需要创建一个登录页面的视图文件。

<!-- login.html -->
<!DOCTYPE html>
<html>
    <head>
        <title>登录页面</title>
    </head>
    <body>
        <form method="post" action="{:url('login/check')}">
            <label for="username">用户名:</label>
            <input type="text" name="username" id="username" /><br /><br />

            <label for="password">密码:</label>
            <input type="password" name="password" id="password" /><br /><br />

            <button type="submit">登录</button>
        </form>
    </body>
</html>

3. 创建登录控制器

接下来,我们需要创建一个用于处理用户登录的控制器。通过 M 告诉控制器找到模型,再通过 V 把模型处理后的数据渲染到相应的视图文件中,C 数据控制器是 M 和 V 的连接部分,负责接收数据并处理后再交给视图层。

<?php
namespace app\index\controller;

use think\Controller;
use think\Request;
use app\index\model\User;

class Login extends Controller
{
    public function index()
    {
        return $this->fetch('login');
    }

    public function check(Request $request)
    {
        $username = $request->post('username');
        $password = $request->post('password');

        $user = User::where('username', $username)
                    ->where('password', md5($password))
                    ->find();

        if($user){
            session('user', $user);
            return $this->success('登录成功', url('index/index'));
        }else{
            return $this->error('用户名或者密码错误');
        }
    }
}

4. 创建用户模型

接下来,我们需要创建一个User模型类,用于处理与用户数据相关的操作。

<?php
namespace app\index\model;

use think\Model;

class User extends Model
{
    protected $pk = 'id';
    protected $table = 'user';
}

5. 配置路由

最后一步,我们需要在应用的入口文件中配置路由,让页面能够正常跳转。

<?php
use think\Route;

Route::get('/', 'index/index');
Route::get('/login', 'login/index');
Route::post('/login/check', 'login/check');

现在,我们的登录功能已经实现了。当用户访问网站时,会跳转到登录页面,输入账号和密码后,会跳转到相应的页面。如果账号和密码错误,则会返回错误信息。

示例说明

示例一

假设我们要实现一个基于管理员角色的登录功能,可以在用户表中增加一个角色字段,用于存储用户的角色信息。那么我们只需要在控制器中增加一行代码即可实现这个功能。

$user = User::where('username', $username)
            ->where('password', md5($password))
            ->where('role', 'admin')
            ->find();

if($user){
    session('user', $user);
    return $this->success('登录成功', url('admin/index'));
}else{
    return $this->error('用户名或者密码错误');
}

示例二

假设我们要对用户输入的密码进行强度校验,检查密码是否包含数字,字母和特殊字符等符号。那么我们可以在模型中增加一个方法,用于校验密码的强度。

<?php
namespace app\index\model;

use think\Model;

class User extends Model
{
    protected $pk = 'id';
    protected $table = 'user';

    public function checkPasswordStrength($password)
    {
        $hasNum = preg_match('/\d+/', $password);
        $hasLetter = preg_match('/[a-zA-Z]+/', $password);
        $hasSpecial = preg_match('/[\W]+/', $password);

        if(!$hasNum || !$hasLetter || !$hasSpecial){
            return false;
        }

        return true;
    }
}

然后我们只需要在控制器中调用这个方法即可。

$password = $request->post('password');

$user = User::where('username', $username)
            ->where('password', md5($password))
            ->find();

if($user && $user->checkPasswordStrength($password)){
    session('user', $user);
    return $this->success('登录成功', url('index/index'));
}else{
    return $this->error('用户名或者密码错误');
}

总结

本文介绍了如何基于thinkPHP框架实现简单的登录功能,主要包括创建数据库,创建登录页面,创建登录控制器,创建用户模型和配置路由等步骤。同时还演示了如何通过控制器和模型的拓展,来实现一些额外的功能。对于刚开始学习thinkPHP框架的同学来说,这篇文章应该是一个很好的入门教程。

本文链接:https://my.lmcjl.com/post/15374.html

展开阅读全文

4 评论

留下您的评论.