php中的$_COOKIE,页面传递问题
<html><head><title>登陆验证</title></head><body><?php$_COOKIE["user_name"]=$_POST["user_n...
<html>
<head>
<title>登陆验证</title>
</head>
<body>
<?php
$_COOKIE["user_name"]=$_POST["user_name"]; //使用cookie
$_COOKIE["user_password"]=$_POST["user_password"];
if($_COOKIE["user_name"]=="php"&&$_COOKIE["user_password"]=="php5"){
echo "恭喜你,登陆成功!";
echo "您输入的用户名是".$_COOKIE["user_name"]."<br>";
echo "您输入的口令是".$_COOKIE["user_password"]."<br>"; }
else{
echo "不正确,请尝试php和php5";
}
?>
<br>
<a href="检测cookie.php">单击检测cookie是否可以页面传递</a>
</body>
</html>
<html>
<head>
<title>检测COOKIE页面传递</title>
</head>
<body>
<?php
if($_COOKIE["user_name"]!=""&&$_COOKIE["user_password"]!=""){
echo "您输入的用户名是".$_COOKIE["user_name"]."<br>";
echo "您输入的口令是".$_COOKIE["user_password"]."<br>";
}
else echo "cookie页面间传递失败,其值为空";
?>
</body>
</html>
这个是表单登陆的程序,为什么在第二个程序中,COOKIE是空值?
有没有可能是在PHP配置中有错误? 展开
<head>
<title>登陆验证</title>
</head>
<body>
<?php
$_COOKIE["user_name"]=$_POST["user_name"]; //使用cookie
$_COOKIE["user_password"]=$_POST["user_password"];
if($_COOKIE["user_name"]=="php"&&$_COOKIE["user_password"]=="php5"){
echo "恭喜你,登陆成功!";
echo "您输入的用户名是".$_COOKIE["user_name"]."<br>";
echo "您输入的口令是".$_COOKIE["user_password"]."<br>"; }
else{
echo "不正确,请尝试php和php5";
}
?>
<br>
<a href="检测cookie.php">单击检测cookie是否可以页面传递</a>
</body>
</html>
<html>
<head>
<title>检测COOKIE页面传递</title>
</head>
<body>
<?php
if($_COOKIE["user_name"]!=""&&$_COOKIE["user_password"]!=""){
echo "您输入的用户名是".$_COOKIE["user_name"]."<br>";
echo "您输入的口令是".$_COOKIE["user_password"]."<br>";
}
else echo "cookie页面间传递失败,其值为空";
?>
</body>
</html>
这个是表单登陆的程序,为什么在第二个程序中,COOKIE是空值?
有没有可能是在PHP配置中有错误? 展开
1个回答
展开全部
COOKIE 机制看来你不是很明白。我给你解释一下吧。
COOKIE 是在网页内容发送之前。先发送出去的信息。也就是说。在这之前不能有任何的 HTML 代码和 echo 等,即使是一个空格也是不允许的。。
在PHP中,要用 setcookie 函数来注册 COOKIE 变量,你上面的代码没有注册 COOKIE 变量。怎么可能送得过去呢。正确的写法如下:
<?
setCOOKIE("user_name",$_POST["user_name"]);
setCOOKIE("user_password",$_POST["user_password"]);
?>
然后才是 HTML 码。。
PS:楼上的,你在使用 setcookie 的时候,之前输出了一些HTML码,COOKIE 跟本不能注册,你的代码本身就是错误的,不要误导人了。
COOKIE 是在网页内容发送之前。先发送出去的信息。也就是说。在这之前不能有任何的 HTML 代码和 echo 等,即使是一个空格也是不允许的。。
在PHP中,要用 setcookie 函数来注册 COOKIE 变量,你上面的代码没有注册 COOKIE 变量。怎么可能送得过去呢。正确的写法如下:
<?
setCOOKIE("user_name",$_POST["user_name"]);
setCOOKIE("user_password",$_POST["user_password"]);
?>
然后才是 HTML 码。。
PS:楼上的,你在使用 setcookie 的时候,之前输出了一些HTML码,COOKIE 跟本不能注册,你的代码本身就是错误的,不要误导人了。
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询