小智 90
将编码的json放入cookie中是我最喜欢的方法,可以从cookie中获取正确的格式化数据.试试看:
$expiry = time() + 12345;
$data = (object) array( "value1" => "just for fun", "value2" => "i'll save whatever I want here" );
$cookieData = (object) array( "data" => $data, "expiry" => $expiry );
setcookie( "cookiename", json_encode( $cookieData ), $expiry );
Run Code Online (Sandbox Code Playgroud)
然后当你下次拿到你的cookie时:
$cookie = json_decode( $_COOKIE[ "cookiename" ] );
Run Code Online (Sandbox Code Playgroud)
您可以简单地提取到期时间,该时间作为数据插入到cookie本身中.
$expiry = $cookie->expiry;
Run Code Online (Sandbox Code Playgroud)
另外还有作为可用对象的数据:)
$data = $cookie->data;
$value1 = $cookie->data->value1;
Run Code Online (Sandbox Code Playgroud)
我发现这是一种更简洁的使用cookie的方式,因为你可以根据自己的意愿在其他对象中嵌入尽可能多的小对象!
Tha*_*ama 48
这很难实现,但cookie的到期日期可以在另一个cookie中设置.然后可以稍后阅读此cookie以获取到期日期.也许有更好的方法,但这是解决问题的方法之一.
您可以设置包含到期日期的cookie值,并从cookie值获得到期日期.
// set
$expiry = time()+3600;
setcookie("mycookie", "mycookievalue|$expiry", $expiry);
// get
if (isset($_COOKIE["mycookie"])) {
list($value, $expiry) = explode("|", $_COOKIE["mycookie"]);
}
Run Code Online (Sandbox Code Playgroud)
//请记住,在这种情况下,某些双向加密会更安全.请参阅:https://github.com/qeremy/Cryptee
当您通过PHP创建cookie时,默认值为0,来自手册:
如果设置为0或省略,cookie将在会话结束时(浏览器关闭时)到期
否则,您可以将cookie生命周期设置为秒,作为第三个参数:
http://www.php.net/manual/en/function.setcookie.php
但是如果你的意思是获得已经存在的cookie的剩余寿命,我担心这是不可能的(至少不是直接的).
归档时间: |
|
查看次数: |
88423 次 |
最近记录: |