第四周深入理解ThinkPhp5.1

本文详细介绍了一个基于MVC架构的用户登录验证流程,包括验证器的规则设定、模型中的用户检查逻辑、控制器的场景应用及视图展示,辅以实际代码示例。

一、常用的命令行操作

使用Sublime Tex编辑器来编写,首先你得先下载Triminal插件,才能进行以下操作,当然win10不用,直接按win+x就能看到,废话不多说,切入正题。

1、创建各个常用的模块。

在这里插入图片描述

2、下载指定的框架版本

在这里插入图片描述

二、登录的验证跟实战

1、MVC的一些理解

先理理mvc的一些基本概念,如下图所示,可以清晰的用一句简单的概括什么mvc,即:前台获取用户数据,通过一系列的请求交给后端,后端通过控制器来调度相应的modal操作数库,返回相应的数据通过控制器交给前台去渲染和与用户响应。
在这里插入图片描述

2、验证器源码如下:
<?php 
//user数据表的验证器

namespace app\index\validate;

use think\Validate;

class User extends Validate 
{
    //验证规则
    protected $rule =   [
        'name'  => 'require|min:3|max:20',
        'age'   => 'number|between:18,50',
        'salary' => 'float|gt:2000',

        'email' => 'require|email',
        'password' => 'alphaNum|min:3|max:10',
    ];
    
    //自定义错误信息
    protected $message  =   [
        'name.require' => '用户姓名必须填写',
        'name.min'     => '名称不能小于3个字符',
        'name.max'     => '名称最多不能超过20个字符',
        'age.number'   => '年龄必须是数字',
        'age.between'  => '年龄只能在18-50之间',
        'salary.float' => '工资必须是数字', 
        'salary.gt'   => '工资不得低于政符最低标准',

        'email.require' => '邮箱必须填', 
        'email.email' => '邮箱格式不对',
        'password.alphaNum' => '密码必须是字母和数字',
        'password.between' => '密码长度必须在3-15位之间',
    ];

    //验证场景
    protected $scene = [
        'edit'  =>  ['age','salary'],
        'add'   =>  ['name','age'],

        'login' => ['email','password']
    ];
}
3、模型源码:
<?php 
namespace app\model;

use think\Model;

class User extends Model 
{
    public function checkUser($data)
    {
        $email = $data['email'];
        $password = sha1($data['password']);

        $res = $this->where('email',$email)->where('password',$password)->find();

        return $res ? true : false;
    }
}
4、登录模板源码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>登录</title>
</head>
<body>
<h2>用户登录</h2>
<form action="{:url('check')}" method="post">
    <p>邮箱: <input type="email" name="email"></p>
    <p>密码: <input type="password" name="password"></p>
    <p><button>提交</button></p>
</form>
</body>
</html>
5 控制器源码、
<?php 

namespace app\index\controller;

use app\model\User as UserModel;
use app\index\validate\User as UserValidate;
use think\facade\View;
use think\facade\Request;
use think\facade\Session;

class User 
{
    use \traits\controller\Jump;

    public function login()
    {
        //检测是否已经登录?
        if (Session::has('email') && !empty(Session::get('email'))) {
            $this->error('不要重复登录','hello');
        }

        return View::fetch('login');
    }

    public function check(UserValidate $validate, UserModel $user)
    {
        $data = Request::param();

        if ($validate->scene('login')->check($data)) {
            //在模型中进行用户验证
            if ($user->checkUser($data)) {
                Session::set('email', $data['email']);

                $this->success('验证通过', 'hello');
            } else {
                $this->error('邮箱或密码错误','login');
            }

        } else {
            $this->error($validate->getError(),'login');
        }

    }

    public function hello()
    {
        $email = Session::get('email');
        $url = url('logout');

        return View::display("<h2>欢迎进入网站后台: {$email} </h2><a href='{$url}'>退出</a>");
    }

    public function logout()
    {
        Session::delete('email');
        $this->success('退出成功', 'login');
    }
}

6 一些操作截图

邮箱格式不对
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

AI 代码审查Review工具 是一个旨在自动化代码审查流程的工具。它通过集成版本控制系统(如 GitHub 和 GitLab)的 Webhook,利用大型语言模型(LLM)对代码变更进行分析,并将审查意见反馈到相应的 Pull Request 或 Merge Request 中。此外,它还支持将审查结果通知到企业微信等通讯工具。 一个基于 LLM 的自动化代码审查助手。通过 GitHub/GitLab Webhook 监听 PR/MR 变更,调用 AI 分析代码,并将审查意见自动评论到 PR/MR,同时支持多种通知渠道。 主要功能 多平台支持: 集成 GitHub 和 GitLab Webhook,监听 Pull Request / Merge Request 事件。 智能审查模式: 详细审查 (/github_webhook, /gitlab_webhook): AI 对每个变更文件进行分析,旨在找出具体问题。审查意见会以结构化的形式(例如,定位到特定代码行、问题分类、严重程度、分析和建议)逐条评论到 PR/MR。AI 模型会输出 JSON 格式的分析结果,系统再将其转换为多条独立的评论。 通用审查 (/github_webhook_general, /gitlab_webhook_general): AI 对每个变更文件进行整体性分析,并为每个文件生成一个 Markdown 格式的总结性评论。 自动化流程: 自动将 AI 审查意见(详细模式下为多条,通用模式下为每个文件一条)发布到 PR/MR。 在所有文件审查完毕后,自动在 PR/MR 中发布一条总结性评论。 即便 AI 未发现任何值得报告的问题,也会发布相应的友好提示和总结评论。 异步处理审查任务,快速响应 Webhook。 通过 Redis 防止对同一 Commit 的重复审查。 灵活配置: 通过环境变量设置基
【直流微电网】径向直流微电网的状态空间建模与线性化:一种耦合DC-DC变换器状态空间平均模型的方法 (Matlab代码实现)内容概要:本文介绍了径向直流微电网的状态空间建模与线性化方法,重点提出了一种基于耦合DC-DC变换器的状态空间平均模型的建模策略。该方法通过数学建模手段对直流微电网系统进行精确的状态空间描述,并对其进行线性化处理,以便于系统稳定性分析与控制器设计。文中结合Matlab代码实现,展示了建模与仿真过程,有助于研究人员理解和复现相关技术,推动直流微电网系统的动态性能研究与工程应用。; 适合人群:具备电力电子、电力系统或自动化等相关背景,熟悉Matlab/Simulink仿真工具,从事新能源、微电网或智能电网研究的研究生、科研人员及工程技术人员。; 使用场景及目标:①掌握直流微电网的动态建模方法;②学习DC-DC变换器在耦合条件下的状态空间平均建模技巧;③实现系统的线性化分析并支持后续控制器设计(如电压稳定控制、功率分配等);④为科研论文撰写、项目仿真验证提供技术支持与代码参考。; 阅读建议:建议读者结合Matlab代码逐步实践建模流程,重点关注状态变量选取、平均化处理和线性化推导过程,同时可扩展应用于更复杂的直流微电网拓扑结构中,提升系统分析与设计能力。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值