Mojo::Message::Request

作者: JSON_NULL | 来源:发表于2017-09-30 18:21 被阅读5次

    简介

    use Mojo::Message::Request;
    
    # Parse
    my $req = Mojo::Message::Request->new;
    $req->parse("GET /foo HTTP/1.0\x0d\x0a");
    $req->parse("Content-Length: 12\x0d\x0a");
    $req->parse("Content-Type: text/plain\x0d\x0a\x0d\x0a");
    $req->parse('Hello World!');
    say $req->method;
    say $req->headers->content_type;
    say $req->body;
    
    # Build
    my $req = Mojo::Message::Request->new;
    $req->url->parse('http://127.0.0.1/foo/bar');
    $req->method('GET');
    say $req->to_string;
    

    Mojo :: Message :: Request是基于RFC 7230,RFC 7231,RFC 7235和RFC 2817的 HTTP请求的容器。

    事件

    Mojo :: Message :: Request继承了Mojo :: Message中的所有事件。

    属性

    Mojo :: Message :: Request从Mojo :: Message继承了所有属性,并实现以下属性。

    env

    my $env = $req->env;
    $req    = $req->env({PATH_INFO => '/'});
    

    可用于直接访问CGI或PSGI中的环境变量的哈希。

    # Check CGI version
    my $version = $req->env->{GATEWAY_INTERFACE};
    
    # Check PSGI version
    my $version = $req->env->{'psgi.version'};
    

    method

    my $method = $req->method;
    $req       = $req->method('POST');
    

    HTTP请求的方法,默认为GET。

    proxy

    my $url = $req->proxy;
    $req    = $req->proxy(Mojo::URL->new('http://127.0.0.1:3000'));
    

    请求的代理url。

    reverse_proxy

    my $bool = $req->reverse_proxy;
    $req     = $req->reverse_proxy($bool);
    

    请求是否已经通过反向代码执行。

    url

    my $url = $req->url;
    $req    = $req->url(Mojo::URL->new);
    

    HTTP请求的url,默认为Mojo::URL对象。

    # Get request information
    my $info = $req->url->to_abs->userinfo;
    my $host = $req->url->to_abs->host;
    my $path = $req->url->to_abs->path;
    

    via_proxy

    my $bool = $req->via_proxy;
    $req     = $req->via_proxy($bool);
    

    该请求是否可通过代理服务器执行。

    方法

    Mojo::Message::Request 从Mojo::Message继承了所有方法,并实现了以下方法。

    clone

    my $clone = $req->clone;
    

    返回一个当前“请求”对象的复制,如果复制失败则返回undef。

    cookies

    my $cookies = $req->cookies;
    $req        = $req->cookies(Mojo::Cookie::Request->new);
    $req        = $req->cookies({name => 'foo', value => 'bar'});
    

    访问当前“请求”的cookie,通常是Mojo::Cookie::Request对象。

    # Names of all cookies
    say $_->name for @{$req->cookies};
    

    every_param

    my $values = $req->every_param('foo');
    

    与param方法类似,但返回的是数组引用,其中的内容是共享相同名称的所有值。

    # Get first value
    say $req->every_param('foo')->[0];
    

    extract_start_line

    my $bool = $req->extract_start_line(\$str);
    

    用一个字符串设计“请求”的起始行。

    fix_headers

    $req = $req->fix_headers;
    

    确保消息具有所必须的头部信息。

    get_start_line_chunk

    my $bytes = $req->get_start_line_chunk($offset);
    

    从特定位置获取消息的起始行数据块。

    is_handshake

    my $bool = $req->is_handshake;
    

    为websocket 检查 头部字段 Upgrade 的值。

    is_secure

    my $bool = $req->is_secure;
    

    检查是不是安全连接(https)。

    is_xhr

    my $bool = $req->is_xhr;
    

    为 XMLHttpRequest 检查头部字段 X-Requested-With 的值。

    param

    my $value = $req->param('foo');
    

    从GET或POST方法的请求体中提取application/x-www-form-urlencoded或multipart/form-data的消息体。如果遇到有多个值共享同一名称的情况,则返回这个名称对应的最后一个值;如果你想获取这个名称对应的所有值,可以使用every_param方法。

    注:此方法将对会所有消息体中的数据进行缓存,以后再调用将不会重新从消息体中计算,而是使用先前的缓存;所以在所有消息头接收完成之前,不应该调用此方法。

    整个消息体的需要全部加载到内存中进行解析,所以你需要确保消息体不会太大。默认情况下“请求”体被限制在16MiB 。

    params

    my $params = $req->params;
    

    从GET或POST方法的请求体中提取application/x-www-form-urlencoded或multipart/form-data的消息体。返回一个 Mojo::Parameters 对象。

    注:这个方法会对处理结果进行缓存,所以需要确保所有内容已经全部传输完成再调用此方法。

    消息体的每一块都需要加载到内存中进行解析,所以你需要确保消息体不会太大。默认情况下“请求”体被限制在16MiB 。

    # Get parameter names and values
    my $hash = $req->params->to_hash;
    

    parse

    $req = $req->parse('GET /foo/bar HTTP/1.1');
    $req = $req->parse({PATH_INFO => '/'});
    

    解析HTTP请求消息块,或环境变量哗然。

    query_params

    my $params = $req->query_params;
    

    解析GET方法中的“查询字符串”,通常返回一个Mojo::Parameters对象。

    # Turn GET parameters to hash and extract value
    say $req->query_params->to_hash->{foo};
    

    start_line_size

    my $size = $req->start_line_size;
    

    请求行的尺寸(以字节为单位)。需要注意的是:此方法的调用会结束请求。

    相关文章

      网友评论

        本文标题:Mojo::Message::Request

        本文链接:https://www.haomeiwen.com/subject/nmknextx.html