当前位置: 首页 > news >正文

thinkphp8 从入门到放弃(后面会完善用到哪里写到哪)

thinkphp8 从入门到放弃

    • 引言 thinkphp* 大道至简
    • 一、 thinkphp8 安装
        • 安装Composer
        • thinkphp 安装命令(tp-项目名称)
        • 多应用安装(一个项目不会只有一个应用)
        • 安装完文件目录如下
        • 本地部署配置伪静态
        • 好了项目可以run
    • 二、架构
        • 服务(Service)
        • 门面(Facade)
        • token 创建(使用php-jwt)

引言 thinkphp* 大道至简

感谢thinkphp 开发团队,多年的努力 一直在更新。
TP8 看云手册-点击进入看云

一、 thinkphp8 安装

安装Composer

访问Composer官方网站(https://getcomposer.org/),下载适合您操作系统的安装程序。

运行安装程序:Windows: 双击下载的composer-setup.exe文件,然后按照向导操作。

thinkphp 安装命令(tp-项目名称)

composer create-project topthink/think tp(项目名称自己定义即可)

多应用安装(一个项目不会只有一个应用)

如果要使用多应用模式,你需要安装多应用模式扩展think-multi-app。
composer require topthink/think-multi-app

安装完文件目录如下

在这里插入图片描述

本地部署配置伪静态
<IfModule mod_rewrite.c> 
Options +FollowSymlinks -Multiviews 
RewriteEngine on 
RewriteCond %{REQUEST_FILENAME} !-d 
RewriteCond %{REQUEST_FILENAME} !-f 
RewriteRule ^(.*)$ index.php [L,E=PATH_INFO:$1] 
</IfModule>
好了项目可以run

在这里插入图片描述

二、架构

服务(Service)

负责具体的业务逻辑实现,将原本控制器的负责流程按模块拆分为一个个小的服务,方便给控制器层组合调用,一般不要跨模块调用服务,服务中可以调用本模块的仓库层方法

门面(Facade)
token 创建(使用php-jwt)

PHP JWT(JSON Web Token)是一种用于身份验证和授权的开放标准。JWT是一个包含有关用户或实体身份信息的安全令牌,它由三部分组成:头部(Header)、载荷(Payload)和签名(Signature)。

为什么不建议你使用 JWT
JWT 的生成和解码都不涉及到存储(对 MySQL 或者 Redis 的访问获取),所以如果你存在拉黑或禁止某生成的令牌,则 JWT 不适合你的业务。
因为,JWT 不涉及存储,如果涉及,那就不是 JWT。
千万,不要为了用而用。

composer require firebase/php-jwt
安装完如下图:
在这里插入图片描述

use \Firebase\JWT\JWT;
use \Firebase\JWT\Key;//生成验签
function signToken($uid, $type)
{$key = Config::get('app.salt') . $type;//这里是自定义的一个随机字串,应该写在config文件中的,解密时也会用,相当    于加密中常用的 盐  salt$token = array("iss" => $key,        //签发者 可以为空"aud" => '',          //面象的用户,可以为空"iat" => time(),      //签发时间"nbf" => time() + 3,    //在什么时候jwt开始生效  (这里表示生成100秒后才生效)"exp" => time() + 86400, //token 过期时间"data" => [           //记录的userid的信息,这里是自已添加上去的,如果有其它信息,可以再添加数组的键值对'uid' => $uid,'type' => $type]);$jwt = JWT::encode($token, $key, "HS256");  //根据参数生成了 tokenreturn $jwt;
}//验证token
function checkToken($token, $type)
{$key = Config::get('app.salt') . $type;$status = array("code" => -1);try {JWT::$leeway = 60;//当前时间减去60,把时间留点余地$decoded = JWT::decode($token, new Key($key, 'HS256')); //HS256方式,这里要和签发的时候对应$arr = json_decode(json_encode($decoded), 1);$res['code'] = 1;$res['data'] = $arr['data'];return $res;} catch (\Firebase\JWT\SignatureInvalidException $e) { //签名不正确$status['msg'] = "签名不正确";return $status;} catch (\Firebase\JWT\BeforeValidException $e) { // 签名在某个时间点之后才能用$status['msg'] = "token失效";return $status;} catch (\Firebase\JWT\ExpiredException $e) { // token过期$status['msg'] = "token失效";return $status;} catch (Exception $e) { //其他错误$status['msg'] = "未知错误";return $status;}
}
http://www.lryc.cn/news/445952.html

相关文章:

  • 对于电商跨境电商独立站中源代码建站和SaaS建站的区别
  • 使用vite+react+ts+Ant Design开发后台管理项目(二)
  • C++之 string(中)
  • 双向链表的基本结构及功能实现
  • stm32定时触发软件中断
  • blender设置背景图怎么添加?blender云渲染选择
  • MMD模型及动作一键完美导入UE5-Blender方案(三)
  • 网络安全自学入门:(超详细)从入门到精通学习路线规划,学完即可就业
  • 如何在O2OA中使用ElementUI组件进行审批流程工作表单设计
  • 三、LLM应用开发准备工作
  • 机器学习-可解释性机器学习:随机森林与fastshap的可视化模型解析
  • 使用Assimp加载glb/gltf文件,然后使用Qt3D来渲染
  • vue实现左侧数据拖拽到右侧区域,且左侧数据保留且左侧数据不能互相拖拽改变顺序
  • 人工智能与机器学习原理精解【21】
  • 【MySQL 01】数据库基础
  • C语言字符学习中级使用库解决问题
  • 网络管理:网络故障排查指南
  • Springboot常见问题(bean找不到)
  • 架构设计笔记-5-软件工程基础知识
  • Solidity——抽象合约和接口详解
  • Fyne ( go跨平台GUI )中文文档-入门(一)
  • Google 扩展 Chrome 安全和隐私功能
  • css 缩放会变动的需要使用转换
  • (17)数据库neo4j数据备份
  • 从零开始学习Python
  • 前端框架的对比和选择
  • 《机器学习》周志华-CH7(贝叶斯分类)
  • 【C/C++】错题记录(一)
  • 【代码随想录训练营第42期 Day60打卡 - 图论Part10 - Bellman_ford算法系列运用
  • vue复制信息到粘贴框