不论是渗透测试还是代码审计的过程中会碰到用不同的框架搭建起来的网站,熟悉这些框架的基本原理,会帮助我们快速的理解漏洞原理,提高干活效率,所以自己本地搭了个php环境,来入门实例学习下thinkphp5.0框架。

 一、基本概念理解

  (1)MVC结构

  控制器(Controller)- 负责转发请求,对请求进行处理。

  视图(View) - 界面设计人员进行图形界面设计。

  模型(Model) - 程序员编写程序应有的功能(实现算法等等)、数据库专家进行数据管理和数据库设计(可以实现具体的功能)。

  上面三个概念是wiki的解释,我的简单理解就是Controller用来转发请求,View用来显示界面,Model用来联系数据库,Controller就是view和Model的中转站。

  (2)命名空间

  (PHP 5 >= 5.3.0, PHP 7)
  从广义上来说,命名空间是一种封装事物的方法。在很多地方都可以见到这种抽象概念。例如,在操作系统中目录用来将相关文件分组,对于目录中的文件来说,它就扮演了命名空间的角色。具体举个例子,文件foo.txt 可以同时在目录/home/greg 和 /home/other 中存在,但在同一个目录中不能存在两个 foo.txt 文件。另外,在目录 /home/greg 外访问 foo.txt 文件时,我们必须将目录名以及目录分隔符放在文件名之前得到/home/greg/foo.txt。这个原理应用到程序设计领域就是命名空间的概念。这是官网的解释,感觉挺清楚的就直接粘过来了。

  think  ==> ./thinkphp/library/think       (系统核心类库)

  traits ==> ./thinkphp/library/traits     (系统Trait类库)

  app ==> ./application          (应用类库)

  (3)目录概述

 二、简单实例

  数据库中的数据如下图:

  

  (1)控制器

  将index模块的Index控制器类(文件位置位于.\application\index\controller\Index.php)的hello方法修改为读取数据代码,代码如下:

<?php
namespace app\index\controller; use think\Controller;    //文件位置在.\thinkphp\library\think\Controller.php
use think\Db; class Index extends Controller
{
public function hello()
{
$data = Db::name('data')->find();
$this->assign('results', $data);
return $this->fetch();
}
}

  (2)视图

  在application\index\view\index下创建hello.html文件,代码如下:

<html>
<head>
<title></title>
</head>
<body>
{$results.id}--{$results.data}
</body>
</html>

  (3)运行结果

  

 三、url和路由

  (1)URL访问

  thinkphp采用单一入口模式访问应用,对应用的所有请求都定向到应用的入口文件。标准的URL访问格式为:

  http://serverName/index.php/模块/控制器/操作

  模块名强制为小写。

  如果控制器是驼峰的,则要用下划线的方式访问,测试结果如下

  

  (2)路由

  

  运行结果如下图:

  

 四、请求和响应

  thinkphp新增了request请求对象和reponse响应对象的概念。

  (1)Request对象的一个主要职责是统一和更安全地获取请求的变量,用它提供的方法来代替$_GET 、$_POST 、 $_REQUEST 、 $_SESSION 、 $_COOKIE 、以及$_FILES 等全局变量,代码示例如下:

  

<?php
namespace app\index\controller; use think\Request; class index
{
public function hello(Request $request, $name = 'World')
{
echo '路由信息: ';
dump($request->routeInfo());
echo 'url: ' . $request->url() . '<br/>';  //自动注入方式
return 'Hello,' . $name . '!';
}
}

  运行结果如下图:

  

  (2)Response对象用于输出数据给客户端或者浏览器。

  大多数情况,我们不需要关注 Response 对象本身,只需要在控制器的操作方法中返回数据即可。代码示例如下:

<?php
namespace app\index\controller; class index
{
public function hello($name = 'World')
{
$data = ['name' => 'thinkphp', 'status' => '1'];
return xml($data,201);
}
}

  返回结果如下图:

  

 五、3.2和5.0的主要区别

  (1)5.0 的URL访问不再支持普通 URL 模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则;

  (2)5.0新增了请求对象Request和响应对象 Response;

  (3)5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数;

  其他区别没列出,自己感觉不是太重要。

  六、小结

  以上就是自己的学习过程,不对的地方还请指教。

对thinkphp5.0框架的实例学习的更多相关文章

  1. thinkPHP5.0框架验证码调用及点击图片刷新简单实现方法

    这篇文章主要介绍了thinkPHP5.0框架验证码调用及点击图片刷新简单实现方法,结合简单示例形式分析了thinkPHP5框架验证码相关配置.后台验证.前台刷新等操作技巧,学习thinkphp源码的朋 ...

  2. ThinkPHP5.0框架事务处理操作简单示例

    本文介绍ThinkPHP5.0框架事务处理操作,结合实例形式分析了ThinkPHP5针对删除操作的事务处理相关操作技巧,可以加深对ThinkPHP源码的理解,需要的朋友可以参考下 事务的调用在mysq ...

  3. ThinkPHP5.0框架开发实现简单的页面跳转

    ThinkPHP5.0框架开发实现简单的页面跳转 一.效果 登录界面 登录成功界面 登录失败界面 二.目录结构 三.代码 控制器中的Login.php <?php // 声明命名空间 names ...

  4. ThinkPHP5.0框架开发--第5章 TP5.0 控制器

    ThinkPHP5.0框架开发--第5章 TP5.0 控制器 第5章 TP5.0 控制器 ============================================== 上次复习 1.路 ...

  5. ThinkPHP5.0框架开发--第4章 TP5.0路由

    ThinkPHP5.0框架开发--第4章 TP5.0路由 第4章 TP5.0 路由 ================================================== 上次复习 1. ...

  6. ThinkPHP5.0框架开发--第3章 TP5.0 配置

    ThinkPHP5.0框架开发--第3章 TP5.0 配置 第3章 TP5.0 配置 ========================================================= ...

  7. ThinkPHP5.0框架开发--第1章 Tp5.0安装

    ThinkPHP5.0框架开发--第1章 Tp5.0安装 第1章 Tp5.0 安装 ======================================================== 今 ...

  8. ThinkPHP5.0框架开发--第2章 TP5.0架构

    ThinkPHP5.0框架开发--第2章 TP5.0架构 第2章 TP5.0架构 ================================================== 上次复习 1.如 ...

  9. ThinkPHP5.0框架开发--第11章 TP5.0 杂项

    ThinkPHP5.0框架开发--第11章 TP5.0 杂项 第11章 TP5.0 杂项 =============================================== 今日学习 1. ...

随机推荐

  1. Python随笔--正则表达式匹配IP

  2. 链接中 href='#' 和 href='###' 的区别

    <a> 标签 + onclick='{jscode}' 是很常用的一种 js 运用方式,而不使用 href='javascript:{jscode}' 是为了兼容多种浏览器对 <a& ...

  3. python机器可读数据-csv

    逗号分隔值(Comma-Separated Values,CSV) 1 csv数据 还有一种数据类型,叫制表分隔值(tab-separated values,TSV)数据,有时与CSV归为一类. 若文 ...

  4. Delphi中播放Flash

    在delphi中可以直接打开flash动画,并控制它播放和停止,还可以得到它的总帧数. 具体操作步骤:①Component -> Import ActiveX Contrals -> Sh ...

  5. python3读取sqlyog配置文件中的MySql密码

    这个人有什么目的?: 我多多少少听过一些安全圈的大牛说到类似的思路,大意是可以通过扫描各种程序和服务的配置文件(比如SVN的文件,RSYNC的配置文件等), 从中发现敏感信息,从而找到入侵的突破口.沿 ...

  6. Fiddler Mock长度变化的response不成功

    使用Fiddler的AutoResponder的功能来mock一个接口,目的是mock返回更多的数据.结果我发现如果只修改response data的内容而不改变长度可以mock成功,一旦改变resp ...

  7. 通过配置文件添加MIME类型

    在web.config配置文件中的configuration节点下添加如下节点: <system.webServer> <staticContent> <mimeMap ...

  8. Docker入门教程

    一.入门介绍 Docker是一个开源引擎,类似于一个集装箱,开发者通过它可以为任何应用创建一个轻量级.环境无关可移植的容器.开发者在本地编译测试过的容器可以在不同的环境中部署. 通常适用于如下场景: ...

  9. linux安装虚拟机ping不通网关,ping不通外网问题解决(nat模式)

    1.将网关字段改成自己想要的字段

  10. TP5 数据库迁移工具 migrate 教程

    第一步: 安装compose,不赘述,安装详情可百度或查看https://pkg.phpcomposer.com/#how-to-install-composer 第二步: 通过 composer   ...