thinkphp5框架之请求

又看到请求这一部分,个人认为这部分是算重要的一部分 单独记一篇笔记。

 

 

0x01 request请求对象

如果要获取当前的请求信息,可以使用\think\Request类,完全开发手册中也有提到,继承系统控制器类可以直接调用 Request 类

来看看thinkphp中的源码:

 /**
     * 构造方法
     * @param Request $request Request对象
     * @access public
     */
    public function __construct(Request $request = null)
    {
        if (is_null($request)) {
            $request = Request::instance();
        }
        $this->view    = View::instance(Config::get('template'), Config::get('view_replace_str'));
        $this->request = $request;

        // 控制器初始化
        $this->_initialize();

        // 前置操作方法
        if ($this->beforeActionList) {
            foreach ($this->beforeActionList as $method => $options) {
                is_numeric($method) ?
                $this->beforeAction($options) :
                $this->beforeAction($method, $options);
            }
        }
    }

 

 

 

控制器中然后快速获取各类参数值:

        //获取所有get值
        $this->request->get();
        //获取指定name名称的get值
        $this->request->get('name');

        //获取所有post值
        $this->request->post();
        //获取指定name名称的post值
        $this->request->post('name');
        //获取所有参数值(get post都可以)

        $this->request->param();
        //获取指定name名称的参数值(get post都可以)
        $this->request->param('name');

 

 

类方法:

获取当前系统参数

      // 获取当前域名
      echo '获取当前域名:'.$request->domain() . '<br/>';

      // 获取当前入口文件
      echo '获取当前入口文件:'.$request->baseFile() . '<br/>';

      // 获取当前URL地址,不含域名
      echo '获取当前URL地址,不含域名:'.$request->url() . '<br/>';

      // 获取包含域名的完整url地址
      echo '获取包含域名的完整url地址:'.$request->url(true) . '<br/>';

      // 获取URL地址 不含QUERY_STRING
      echo '获取URL地址 不含QUERY_STRING:'.$request->baseurl() . '<br/>';

      // 获取URL访问的ROOT地址
      echo '获取URL访问的ROOT地址:'.$request->root() . '<br/>';

      // 获取URL访问的ROOT地址
      echo '获取URL访问的ROOT地址 :'.$request->root(true) . '<br/>';

      // 获取URL地址中的 PATH_INFO 信息
      echo '获取URL地址中的 PATH_INFO 信息:'.$request->pathinfo() . '<br/>';

      // 获取URL地址中的 PATH_INFO 信息,不含后缀
      echo '获取URL地址中的 PATH_INFO 信息,不含后缀:'.$request->path() . '<br/>';

      // 获取URL地址中的后缀信息
      echo '获取URL地址中的后缀信息:'.$request->ext() . '<br/>';

 

获取请求的参数

      echo '请求方法:'.$request->method() . '<br/>';

      echo '资源类型:'.$request->type() . '<br/>';

      echo '访问ip:'.$request->ip() . '<br/>';

      echo '是否为ajax请求:'.var_export($request->isAjax(), true) . '<br/>';

      echo '请求参数:';
      dump($request->param());

      echo '请求参数:仅包含name';
      dump($request->only(['name']));

      echo '请求参数:排除name';
      dump($request->except(['name']));

 

获取get,post参数

        echo 'GET参数:';
        dump($request->get());

        echo 'GET参数:name';
        dump($request->get('name'));

        echo 'POST参数:name';
        dump($request->post('name'));

        echo 'cookie参数:name';
        dump($request->cookie('name'));

        echo '上传文件信息:image';
        dump($request->file('image'));

        echo '获取参数name,无论get还是post';
        echo $request->param('name');

 

 

 

获取当前的控制器,方法

      echo '模块:'.$request->module();

      echo '<br/>控制器:'.$request->controller();

      echo '<br/>操作:'.$request->action();

 

获取路由和调度信息

      echo '路由信息:';
      dump($request->routeInfo());

      echo '调度信息:';
      dump($request->dispatch());

 

 

0x02 常见获取request对象方法

助手函数request()

thinkphp5框架之请求

 

thinkphp5框架之请求

 

 

 use think\Request ; Request是单例模式  通过Request::instance() ;获取对象

thinkphp5框架之请求

thinkphp5框架之请求

 

 

方法传参 request对象 ---public function index(Request $request){}【推荐】

thinkphp5框架之请求

 

 

0x03 输入变量

检测变量是否设置

可以使用has方法来检测一个变量参数是否设置,如下:

Request::instance()->has('id','get');
Request::instance()->has('name','post');

或者使用助手函数

input('?get.id');
input('?post.name');

变量检测可以支持所有支持的系统变量。

 

 

判断请求类型:

        $this->request->isGet();
        $this->request->isPost();
        $this->request->isAjax();

 

 

变量过滤

框架默认没有设置任何过滤规则,你可以是配置文件中设置全局的过滤规则:

// 默认全局过滤方法 用逗号分隔多个
'default_filter'         => 'htmlspecialchars',

也支持使用Request对象进行全局变量的获取过滤,过滤方式包括函数、方法过滤,以及PHP内置的Types of filters,我们可以设置全局变量过滤方法,例如:

Request::instance()->filter('htmlspecialchars');

 

 

支持设置多个过滤方法,例如:

Request::instance()->filter(['strip_tags','htmlspecialchars']),

 

 

也可以在获取变量的时候添加过滤方法,例如:

Request::instance()->get('name','','htmlspecialchars'); // 获取get变量 并用htmlspecialchars函数过滤
Request::instance()->param('username','','strip_tags'); // 获取param变量 并用strip_tags函数过滤
Request::instance()->post('name','','org\Filter::safeHtml'); // 获取post变量 并用org\Filter类的safeHtml方法过滤

 

 

获取部分变量

如果你只需要获取当前请求的部分参数,可以使用:

// 只获取当前请求的id和name变量
Request::instance()->only('id,name');

或者使用数组方式

// 只获取当前请求的id和name变量
Request::instance()->only(['id','name']);

默认获取的是当前请求参数,如果需要获取其它类型的参数,可以使用第二个参数,例如:

// 只获取GET请求的id和name变量
Request::instance()->only(['id','name'],'get');
// 只获取POST请求的id和name变量
Request::instance()->only(['id','name'],'post');

 

变量修饰符

input('变量类型.变量名/修饰符');

 

或者

Request::instance()->变量类型('变量名/修饰符');

例如:

input('get.id/d');
input('post.name/s');
input('post.ids/a');
Request::instance()->get('id/d');

ThinkPHP5.0版本默认的变量修饰符是/s,如果需要传入字符串之外的变量可以使用下面的修饰符,包括:

修饰符 作用
s 强制转换为字符串类型
d 强制转换为整型类型
b 强制转换为布尔类型
a 强制转换为数组类型
f 强制转换为浮点类型

 

HTTP头信息

可以使用Request对象的header方法获取当前请求的HTTP 请求头信息,例如:

$info = Request::instance()->header();
echo $info['accept'];
echo $info['accept-encoding'];
echo $info['user-agent'];

 

也可以直接获取某个请求头信息,例如:

$agent = Request::instance()->header('user-agent');

 

HTTP请求头信息的名称不区分大小写,并且_会自动转换为-,所以下面的写法都是等效的:

$agent = Request::instance()->header('user-agent');
$agent = Request::instance()->header('User-Agent');
$agent = Request::instance()->header('USER_AGENT');

 

 

URL伪静态

URL伪静态通常是为了满足更好的SEO效果,ThinkPHP支持伪静态URL设置,可以通过设置url_html_suffix参数随意在URL的最后增加你想要的静态后缀,而不会影响当前操作的正常执行。例如,我们设置

'url_html_suffix' => 'shtml'

 

我们可以把下面的URL http://serverName/Home/Blog/read/id/1 变成 http://serverName/Home/Blog/read/id/1.shtml

后者更具有静态页面的URL特征,但是具有和前面的URL相同的执行效果,并且不会影响原来参数的使用。

默认情况下,伪静态的设置为html,如果我们设置伪静态后缀为空字符串,

'url_html_suffix'=>''

则支持所有的静态后缀访问,如果要获取当前的伪静态后缀,可以使用Request对象的ext方法。

例如:

http://serverName/index/blog/3.html
http://serverName/index/blog/3.shtml
http://serverName/index/blog/3.xml
http://serverName/index/blog/3.pdf

 

 

更多参考tp5完全开发手册

上一篇:thinkphp5 设置路由请求方式


下一篇:layui+thinkphp5上传七牛云