我想知道为什么我们在网页中的任何其他内容之前调用session_start()?
答案 0 :(得分:1)
让我试着描述一下HTTP协议是如何工作的。
来自浏览器的请求如下所示:
GET /somefolder/somescript.php HTTP/1.1
Host: www.yourhost.com
Connection: keep-alive
Cache-Control: max-age=0
Upgrade-Insecure-Requests: 1
User-Agent: Your_Useragent
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,image/webp;q=0.8
Referer: http://testreferer.com/
Accept-Encoding: gzip, deflate, sdch, br
Accept-Language: ru-RU,ru;q=0.8,en-US;q=0.6,en;q=0.4,bg;q=0.2
Another-Header: Value1
Another-Header1: Value2
来自服务器的请求看起来几乎是这样的:
HTTP/1.1 200 OK
Cache-Control: max-age=21600
Strict-Transport-Security: max-age=15552000; includeSubdomains; preload
Content-Security-Policy: upgrade-insecure-requests
Some-Other-Header: Value1
And-Another-Header: Value2\n\n
<YOUR WEBPAGE CONTENTS>
因此,第一台服务器最后发送标头和\n\n
,然后开始发送您的网页内容。
但是session_start()
正在发送“它自己的”标题,但是当它们已经完成发送时你就无法发送任何标题!
示例:
<?php
Header("SomeCoolHeader: Value1"); //Sending custom headers
session_start(); //Sending session header
Header("AnotherHeader: Value2"); //Sending custom headers
echo "Some text"; //Header sending automatically finished and sent some html text
?>
示例2(有错误):
<?php
Header("CustomHeader1: Value1"); //sending custom headers
echo "Some text"; //Header sending automatically finished and sent some html text
Header("CustomHeader2: Value2"); //Cannot add header information - headers already sent
?>
示例3(有错误):
<?php
Header("CustomHeader1: Value1"); //sending custom headers
echo "Some text"; //Header sending automatically finished and sent some html text
session_start(); //Cannot add header information - headers already sent
?>
如果您还有任何疑问 - 可以在评论中问我。
答案 1 :(得分:0)
session_start()根据通过GET或POST请求传递的会话标识符创建会话或恢复当前会话,或通过cookie传递。
当调用session_start()或会话自动启动时,PHP将调用open和read会话保存处理程序。这些将是默认提供的内置保存处理程序或PHP扩展(如SQLite或Memcached);或者可以是session_set_save_handler()定义的自定义处理程序。读取回调将检索任何现有的会话数据(以特殊的序列化格式存储),并且将被反序列化并用于在读取回调将已保存的会话数据返回到PHP会话处理时自动填充$ _SESSION超全局。
要使用命名会话,请在调用session_start()之前调用session_name()。
当启用session.use_trans_sid时,session_start()函数将注册一个内部输出处理程序以进行URL重写。
如果用户使用ob_gzhandler或与ob_start()类似,则函数顺序对于正确输出很重要。例如,必须在开始会话之前注册ob_gzhandler。
答案 2 :(得分:0)
我们知道cookie存储在浏览器中,会话存储在服务器中。会话中没有大小限制。 要解决这个问题,我们必须看看PHP如何在内部工作。查看php.ini文件,您可以在会话中看到类似下面的内容,
[Session]
session.save_handler = files
session.save_path = "/tmp"
session.use_cookies = 1
session.use_only_cookies = 1
session.name = PHPSESSID
session.auto_start = 0
在默认配置中,php存储会话作为服务器中的文件,默认路径为“/ tem”。在tmp中,您可以看到名为“sess_4b1e384ad74619bd212e236e52a5a174If”的文件,这只是一个会话文件。在正常情况下,有许多用户同时访问同一个Web。然后tmp文件夹中有很多这样的文件。虽然php在tmp文件夹php中创建一个文件,但在客户端浏览器中将cookie设置为PHPSESSID作为名称和值。此cookie显示在下图中。 enter image description here
对于每个请求,浏览器都会将此cookie发送到服务器。 enter image description here