繁体   English   中英

序列化对象中的特殊字符正在破坏PHP会话

[英]Special chars in serialized object are destroying PHP session

登录用户后,我将用户对象序列化并将其存储在他的会话中,就像这样

$_SESSION['User'] = serialize($this);

因此,在以后的步骤中,我可以更快地访问他的数据。

现在,有时用户无法保持登录状态,因为下一页请求会立即破坏其会话。 我发现这是由于用户将特殊字符存储在他的数据中。 例如,在一个案例中,通知中有一些甜言蜜语

s:72:"♥ Aufsicht ♥ <br>...;"

在另一种情况下,从Apple联系人中复制了电话号码,依此类推。 在会话中是否有存储限制,例如仅ASCII字符? 我是否必须将整个字符串转换为其他格式,例如Base64? 或如何最好地处理? 谢谢

非常感谢Sammitch在评论中的注释:问题是预序列化。 如果我只是将对象分配给$_SESSION

$_SESSION['User'] = $this;

如果对象的字段包含这些字符是没有问题的

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM