不论是渗透测试还是代码审计的过程中会碰到用不同的框架搭建起来的网站,熟悉这些框架的基本原理,会帮助我们快速的理解漏洞原理,提高干活效率,所以自己本地搭了个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. 完全关闭及再次启动cdh集群

    关闭集群 - 关闭集群所有组件 关闭Cloudera Management Service 关闭cdh所有客户端节点 sudo /opt/cloudera-manager/cm-5.11.1/etc/ ...

  2. Eclipse控制台输出log日志中文乱码

    今天在工作中,调试程序的时候突然发现控制台的log日志,输出的中文全都是乱码. 看到这就在想,这是项目编码还是log.xml编码配置被改掉了呢?于是统统检查了一遍发现所有的编码格式都是统一用的utf- ...

  3. java 的重写(覆盖) 和重载的区别

    方法的的重写(覆盖) 在类继承中,子类可以修改从父类继承来的行为,也就是说子类能创建一个与父类方法有不同功能的方法,但具有相同的:名称.返回类型.参数列表.如果在子类中定义一个方法,其方法名称.返回值 ...

  4. 循环输出ViewBag集合

    <tr>            <td>                权限分配:            </td>            <td>   ...

  5. web开发中 代码解决部分IE兼容问题

    首先是自己遇到问题: 一套系统,以前的开发asp旧+c#新后台管理扩展.完善后,在2013年前基本无问题,很是畅顺. 其中.到升级了浏览器后.例如ie9以后,则问题出现了. 如图:   这是一个js的 ...

  6. 马凯军201771010116《面向对象与程序设计Java》第十一周学习总结

    一.理论知识部分 第九章  集合 1.数据结构介绍:线性结构:线性表,栈,队列,串,数组,文件.非线性结构:树,图. 散列表:又称为哈希表. 散列表算法的基本思想是:以结点的关键字为自变量,通过一定的 ...

  7. 洛谷P1966 【火柴排队】

    题解 P1966 [火柴排队] 说明: 在数学中有个公式: (a1-b1)^2+(a2-b2)^2<(a2-b1)^2+(a1-b2)^2 (你可以自己试着证一下) 两列火柴对应的两根火柴在各列 ...

  8. JAVA对mongodb的基本操作

    public class test3 { //连接数据库(不需要验证,用于测试连接本地的mongodb) public static MongoDatabase getDatabase(String ...

  9. SQL注入之Sqli-labs系列第三十八关、第三十九关,第四十关(堆叠注入)

    0x1 堆叠注入讲解 (1)前言 国内有的称为堆查询注入,也有称之为堆叠注入.个人认为称之为堆叠注入更为准确.堆叠注入为攻击者提供了很多的攻击手段,通过添加一个新 的查询或者终止查询,可以达到修改数据 ...

  10. EmptyBeanUtil

    package com.rscode.credits.util; import java.util.List; /** * * 判断实体是否为空 * @author tn * */ public cl ...