我将分享我的基本配置,希望有人可以了解我的问题在于我的会话变量。会话不会在页面加载之间保存,对于我的生活,我无法确定原因。
这是我正在构建的第一个Windows PHP应用程序,所以在尝试了我能想到的所有内容后,我现在感到很茫然。
会话保存路径是IS WRITABLE。使用此代码验证:
if (!is_writable(session_save_path()) ) {
echo 'Session path "'.session_save_path().'" is not writable for PHP!';
}
session.cookie_domain
为空(未设置为任何内容)。同样,根据我的经验,这是正确的。
我正在使用ToroPHP作为我的简单路由器。对于我的测试,我只是路由到一个非常简单的类。你会在下面看到它。
这是我的Web.Config文件。这是允许我使用ToroPHP
的原因<?xml version="1.0" encoding="UTF-8"?>
<configuration>
<system.webServer>
<rewrite>
<rules>
<rule name="Toro" stopProcessing="true">
<match url="^(.*)$" />
<conditions logicalGrouping="MatchAll">
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
</conditions>
<action type="Rewrite" url="index.php/{R:1}" />
</rule>
</rules>
</rewrite>
<httpErrors errorMode="Detailed" />
<asp scriptErrorSentToBrowser="true"/>
</system.webServer>
<system.web>
<customErrors mode="Off"/>
<compilation debug="true"/>
</system.web>
</configuration>
这是我的配置脚本,它是第一个被调用的东西(除了设置我的$ ABS_SITE_PATH var):
error_reporting(E_ALL);
ini_set('display_errors', 'On');
//SET TIMEZONE
date_default_timezone_set('America/New_York');
$expireTime = 60 * 60 * 7 * 20; // 20 week expire time: seconds, minutes, days, weeks.
ini_set('session.save_path', $ABS_SITE_PATH.'/sess');
session_set_cookie_params($expireTime,"/",NULL, TRUE, TRUE);
session_start();
这是我正在进行的简单测试:
class sessionTestHandler{
public function get()
{
if (!isset($_SESSION['count'])) {
$_SESSION['count'] = 0;
} else {
$_SESSION['count']++;
}
var_dump($_SESSION['count']);
}
}
无论如何,我会在每次加载页面时将int(0)
输出到我的屏幕。如果我var_dump整个会话变量,我得到:array(1) { ["count"]=> int(0) }
如果需要任何其他信息,我很乐意提供。感谢。
更新: 这适用于所有浏览器。
更新1/14:
在每次加载页面时,我输出session_id();
并在每次加载时显示不同的ID。因此,会话ID在页面加载之间不会持久。
答案 0 :(得分:2)
您的代码对我来说很好。我认为这是测试过程中的错误或配置错误。由于没有进一步的信息,我将提出一些一般性建议:
启动更改会话路径should happen before the session:
需要在session_start()之前调用session_save_path()
您可能会在更改保存路径之前无意中启动会话(例如session.auto_start
或框架中的某个session_start()
。会话未启动的双check!如果是,建议将特定于应用程序的运行时配置移动到.htaccess。
$_SESSION
在访问测试用例的会话之前,请确保session is started。
在浏览器端检查您为每个后续请求使用相同的会话ID。您可以通过检查URI中的会话ID或检查会话cookie来执行此操作。在服务器端仔细检查session_id()
的结果。 请注意,session.cookie_secure
可以限制在您的情况下仅限制会话传播到HTTPS。如果是这种情况,请采用您的测试程序进行HTTPS或允许通过http cookie进行会话传播(例如session_set_cookie_params($expireTime,"/",NULL, FALSE, TRUE);
)。
phpinfo()
您正在对配置进行一些运行时更改。有些情况下不会应用这些。将phpinfo()
的输出与您的期望进行比较。在您的情况下,请检查每个session.*
属性。