您好,欢迎访问一九零五行业门户网

php开发中关于cookie无效的常见解决办法

php开发中关于cookie无效的常见解决方法
php开发中关于cookie无效的常见解决方法
cookie存在客户端,跟服务器没有关系的,注意你程序里大小写问题,linux是大小写敏感的,还有php教程的配置,比如是否   register_globals   =   off   的配置在两边都一样等等。
php 的 @、# 符号的意思
function foo($n)
{
    $result = 1/$n;
    return $result;
}
echo @foo(0); // 函数中会产生除 0 错误,但加上 @ 后并不显示该错误。
echo end; // 输出 end
# 注释符号
同 // 一样,# 是单行注释符(多行注释符为 /* */)。
由于使用了@setcookie,即便在写入cookies是发生错误,也不会输出,造成了无法发现问题。最后把@setcookie改成 setcookie,程序输出如下错误信息:
warning: cannot modify header information - headers already sent by (output started at
经过上网一查,发现原来在进行setcookie设置前不能有任何输出内容,然后就去检查代码,也没有发现在setcookie之前输出了东西,在搜索了一下,发现了问题所在,具体内容如下:
今天在wordpress中文论坛逛了一圈。坛子里人气不高,不过还是有很多高手的。会编写插件和模版的高手和连编辑文件都不会的初学者混在一起,论坛就是这样,哈哈。
看到好几个帖子里提到同一个错误,比如这个帖子里提到的:warning: cannot modify header information - headers already sent by (output started at c:program fileseasyphp1-8wwwwp-config.php:1) in c:program fileseasyphp1-8wwwwp-login.php on line 9
这是一个很典型的问题。wordpress的程序执行时会首先调用wp-config.php一类的配置文件,也会调用wp-db.php建立数据库教程连接以备后用。这些文件只是做一些设置,并不输出html代码。设置完了后,程序本身开始执行了,有些程序会使用header命令设置一个http头。由于 http头必须在html代码输出之前设置好,否则html代码已经开始往客户端发送了,http也就已经发送过了,没法追回来重新设置了。 wordpress codex里对这个问题作出了说明:《how do i solve the headers already sent warning problem?》。文章指出:要确保各个文件――尤其是经常被编辑的wp-config.php文件――以结尾,前后不能有其他字符。具体到上面的例子,很明显,提示信息说wp-config.php的第一行就开始了html输出,这有可能是第一行的解决方法
wordpress中文论坛没有提供全文搜索的功能,只能搜索标题,所以我用google搜索了一下cannot modify header information site:wordpress.org.cn,好像碰到这个问题的人还真不少。目前大家用的wordpress主要是wordpress英文原版和几个 wordpress中文版。我的中文包又不包含wp-config-sample.php文件,自然不关我的事;wordpress原版用的ascii 码,自然不包含bom,也不会出这样的错误;xigang制作的wordpress中文版在wordpress中文论坛有下,我去下载了 wordpress 2.0.4和2.0.3这两个,检查了一下,没有问题;点点游的wordpress 2.0.4中文版里,wp-config-sample.php文件用的是gb2312编码和dos行尾符,god!不过这样也好,如果有人用记事本修改了这个文件,dos行尾符不会造成编辑问题,gb2312编码不会造成bom的问题
cookie用法
关于删除cookie的说明开始-----
bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, bool secure]]]]] )
要删除cookie需要确保它的失效期是在过去,才能触发浏览器的删除机制。
下面的例子说明了如何删除刚才设置的cookie:
-----关于删除cookie的说明结束-----
删除一个cookie的方法就是把这个cookie的有效期设置为当前时间以前,这也是几乎所有php程序员都会这么做。
后来一个初接触php的朋友告诉我,他在程序中本想把一个cookie的值设置为空,结果导致这个cookie直接被删除。我当时的第一反应是不相信,于是测试
了一下:
setcookie(testcookie, '');
print_r($_cookie);
结果果然是整个$_cookie数组都是空的,而非仅仅$_cookie['testcookie']为空。于是用winsock抓包,观察返回的 http头,发现http头竟然是“set-cookie: testcookie=deleted; expires=mon, 18-jun-2007 02:42:33 gmt”,这说明“setcookie(testcookie, '');”的的确确是将testcookie这个cookie直接删除,而关于这种情况在php手册中完全没有说明。
其它类似信息

推荐信息