1、laravel怎么获取cookie
先检查设置的cookie是否有被发送到服务器,然后检查取cookie的方法是否正确
2、laravel 5.4 怎么用全局cookie
Cookie::make('test', 'hello, world', 10);
echo Cookie::get('test');如果你按照这种类似的回答来测试Cookie,肯定会发现设置cookie的值永远都是null。多次测试无效下,你都会怀疑自己的Laravel框架是不是有问题!
其实,在Laravel框架中使用Cookie,就不得不提到Response和Request。经常用浏览器调试程序的开发者可能会留意过,在请求地址的Response Headers和Request Headers中,都包含有cookie信息。没错,如果你在Laravel框架中使用Cookie都离不开Response和Request,下面我们就来介绍Cookie的正确添加和获取方法。
Cookie::make()、Cookie::forever()、Cookie::get()的使用方法:
Route::get('cookieset', function()
{
$foreverCookie = Cookie::forever('forever', 'Success');
$tempCookie = Cookie::make('temporary', 'Victory', 5);//参数格式:$name, $value, $minutes
return Response::make()->withCookie($foreverCookie)->withCookie($tempCookie);
});
Route::get('cookietest', function()
{
$forever = Cookie::get('forever');
$temporary = Cookie::get('temporary');
return View::make('cookietest', array('forever' => $forever, 'temporary' => $temporary, 'variableTest' => 'works'));
});
//先上一个demo写入cookie
$cookie = \Cookie('cookie_name', 'value', 5);
$data = ['title'=>'hello world'];
return \response()
->view('home.hello', $data)
->cookie($cookie);2、Cookie存储数组:
Route::get('cookieset', function()
{
$user_info = array('name'=>'laravel','age'=>12);
$user = Cookie::make('user',$user_info,30);
return Response::make()->withCookie($user);
});
Route::get('cookietest', function()
{
dd(Cookie::get('user'));
});
3、laravel csrf token值存在cookie里有什么意义
方法一
打开抄文件:袭app\Http\Kernel.php
把这行注释掉:
'App\Http\Middleware\VerifyCsrfToken'
方法二
打开文件:app\Http\Middleware\VerifyCsrfToken.php
修改为:
<?php namespace App\Http\Middleware;
use Closure;
use Illuminate\Foundation\Http\Middleware\VerifyCsrfToken as BaseVerifier;
class VerifyCsrfToken extends BaseVerifier {
/**
* Handle an incoming request.
*
4、如何共享laravel的session跟cookie
我这边总结一下,也许以后有人会需要,
其实Laravel的session并不是用PHP自带的session管理器。而是完完全全自己实现了一个。
注意是完完全全自己实现的,并不是传统意义上用session_set_save_handler自定义的session处理器。
所以解决 和另一个ThinkPHP项目的session共用 的问题就很简单了~
在Laravel中启动PHP自带的session就好了,也就是session_start。
这是他们的代码注释 "Note that the Laravel sessions do not make use of PHP "native" sessions in any way since they are crappy."
请记住Laravel在任何地方都没有用到PHP“原生”的session,因为它很蹩脚。
好吧,我现在只要启动蹩脚的session就好了。
by kankana
以上是如何从laravel访问其他程序的session.
以下,则是如何从外部访问laravel的session (file).
当laravel的session driver设置为file, 这些session files都是以json形式存放在app/storage/sessions里面.
关键是,如何找到对应的session文件?
这个文件名是以加密形式存储在cookie的laravel_session里.
如何解密laravel_session获取这个文件名?
1, 首先安装这个库:
https://github.com/illuminate/encryption
2, 获取加密key
位于app/config/app.php 的 key
3,
$encrypter = new Illuminate\Encryption\Encrypter($key);
$session_filename = $encrypter->decrypt($_COOKIE['laravel_session']);
大致如此.
5、laravel 为什么我访问两个任意域名都跳到laravel文件中
yaml的map中不要使用tab,使用空格试试。什么叫跳入文件中?给个图?
6、laravel可否跨域写入cookie
现在的项复目是前后制端分离,用的是laravel+vue组合,由于使用了微信授权登录,在前端请求授权登录时,后端完成跳转微信授权登录并跳转回前端(此时需用cookie带上token),由于目前前后端是不同的域名,这里涉及到跨域,不知laravel可否跨域写入cookie?
比如现在前端的域名是wx.abc.com,然后后端接口的域名是api.bcd.com,微信授权登录调转回前端时可否用类似redirect('http://wx.abc.com/#/setCookie')->setCookie('token','xxxxx');?
7、laravel设置Cookies不生效怎么解决
先检查设置来的cookie是否有被发送到自服务器,然后检查取cookie的方法是否正确。laravel的cookie默认是加密的,如果使用PHP原生的“$_COOKIE”去获取cookie是获取不到的,必须使用“Cookie::get”。在响应里设置response('')->withCookie(cookie('name','laravel',1000))
8、laravel5.4 开发api 怎么设置单独域名
我用“应用之星”,开发手机APP,挺好的
-