为了账号安全,请及时绑定邮箱和手机立即绑定

我怎样确保session_start只被调用一次,且是开头呢?同理还有header()

我怎样确保session_start只被调用一次,且是开头呢?同理还有header()

PHP
慕雪6442864 2023-05-02 12:08:36
首先我知道应该是在头部 比如:session_start();$_SESSION['name'] = 'levi';但是如果有多个文件调用,且都用到了sessionstart,怎么办? 这样sessionstart就被多次调用了// set.php session_start();$_SESSION['name'] = 'levi';// conr.php include 'set.php'; session_start(); echo $_SESSION['name'];
查看完整描述

2 回答

?
手掌心

TA贡献1942条经验 获得超3个赞

这说明你的网站架构设计不合理。一个通用的做法是,通过rewrite保证所有的页面都只有一个入口,然后解析url来完成分发;页面的组装(包括header,尤其是其中的cookie)也应该交给某个模板引擎在处理流程的末尾完成。这样就可以保证session_start()只调用一次,header也不会被混用。

查看完整回答
反对 回复 2023-05-04
?
慕盖茨4494581

TA贡献1850条经验 获得超11个赞

通常放在公共文件头部,这样各页面调用的时候就不会冲突了, 设置时区,编码,开启ob等操作一般都放那儿, 例如typecho的Widget_Init类的execute入口方法.

查看完整回答
反对 回复 2023-05-04
  • 2 回答
  • 0 关注
  • 87 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信