• laravel5.2总结--请求


     
     

    1 获取请求

    1.1 获取请求的 URI
    1>path 方法会返回请求的 URI。所以,如果接收到的请求目标是 http://domain.com/foo/bar,那么 path 方法就会返回 foo/bar:
    $uri = $request->path();
    2>is 方法可以验证接收到的请求 URI 与指定的规则是否相匹配。使用此方法时你可以将 * 符号作为通配符:
    if ($request->is('admin/*')) { // }
    3>使用 url 方法,可以获取完整的网址:
    $url = $request->url();
    1.2 获取请求的方法
    method 方法会返回此次请求的 HTTP 动作。也可以通过 isMethod 方法来验证 HTTP 动作和指定的字符串是否相匹配:
    $method = $request->method(); if ($request->isMethod('post')) { // }
     

    2 获取输入数据

    2.1 获取特定输入值
    $name = $request->input('name');
    2.2 此外,可以使用 IlluminateHttpRequest 的属性访问用户输入。
    $name = $request->name;
    2.3 当请求的输入数据不存在于此次请求时,就会返回默认值(input的第二个参数):
    $name = $request->input('name', 'Sally');
    2.4 如果是「数组」形式的输入数据,则可以使用「点」语法来获取数组:
    $input = $request->input('products.0.name');
    2.5 确认是否有输入值,使用 has 方法。当该数据存在并且字符串不为空时,has 方法就会传回 true:
    if ($request->has('name')) { // }
    2.6 获取所有输入数据:
    $input = $request->all();
    2.7 获取部分输入数据
    如果你想获取输入数据的子集,则可以使用 only 及 except 方法。这两个方法都接受单个数组或是动态列表作为参数:
    $input = $request->only(['username', 'password']); $input = $request->only('username', 'password'); $input = $request->except(['credit_card']); $input = $request->except('credit_card');
     

    3 旧输入数据

    Laravel 可以让你将本次的输入数据保留,它只在下一次的请求内有效.可以使用 flash 方法保存 session,将数据保留到下个 HTTP 请求,然后就会被自动删除,这对于在表单验证失败后重新填入表单值相当有用.
    3.1 将输入数据闪存至 Session
    1> flash 方法会将当前的输入数据存进session中,所以下次用户发出请求至应用程序时就可以使用它们:
    $request->flash();
    2> 你也可以使用 flashOnly 及 flashExcept 方法将请求数据的子集保存至 Session:
    $request->flashOnly('username', 'email'); $request->flashExcept('password');
    3> 闪存输入数据至 Session 后重定向
    return redirect('form')->withInput(); return redirect('form')->withInput($request->except('password'));
    3.2 获取旧输入数据
    注意上面两种闪存方式使用session('username')是拿不到数据的,若要获取上一次请求后所闪存的输入数据,则可以使用 Request 实例中的 old 方法,
    $username = $request->old('username');
    Laravel 也提供了全局辅助函数 old。如果你要在Blade模板中显示旧输入数据,可以使用更加方便的 old 辅助函数:
    {{old('username')}}
     
    举例:登录操作
    登录失败,再次跳转到登录页面,此时我们不做任何操作,其实后台已经发送了一次请求到/user/login,进行登录失败的跳转操作,此时闪存内容还存在.
    我们再次刷新页面,会再次产生一次请求,此时闪存内容就不存在了
     
     
     
     
     
  • 相关阅读:
    Python与常见加密方式
    ERROR 2002 (HY000):Can't connect to local MySQL server though socket '/var/lib/mysql/mysql.sock'(2)
    hive的分区表
    内部表和外部表的区别
    hive之SQL
    执行wc的时候提示连接被拒绝。Connection refused
    hive的简介
    hive的部署
    top命令信息
    web界面解读
  • 原文地址:https://www.cnblogs.com/redirect/p/6213531.html
Copyright © 2020-2023  润新知