PHP $ _SESSION正在运行,但无法让$ _GET工作

时间:2015-08-08 11:13:41

标签: php session

我正在努力在我的网站上使用$ _GET。我已经设置了登录页面,登录后用户被重定向到他/她的个人资料。我想创建一个动态url变量。我在登录页面上设置了一个会话,并在被重定向到配置文件“echo $ _SESSION ['username']后正确回应。但是当尝试使用$ _GET执行相同操作时,不会显示任何内容。我已经检查了很多教程,即使我完全按照所示,我从来没有让它工作。这是我的代码:

的login.php

 <?php 
 include ("./Various/header.php");
 require './Various/connections.php';

 if(isset($_POST['login'])) {
      session_start();

 //Set Variables
 $loginusername = $_POST['userlogin'];
 $loginpassword = $_POST['passwordlogin'];

 if(!empty($loginusername)&& !empty($loginpassword)){
     $sql = mysql_query("SELECT * FROM users WHERE username='$loginusername'");
     $checkuser=mysql_num_rows($sql);

     if($checkuser == 1) {

         $passrow = mysql_fetch_assoc($sql);
         $checkpass = $passrow['password'];

         $userdb = $passrow['username'];
         $iddb = $passrow['id'];

    if ($checkpass == $loginpassword)
    {
        $_SESSION['username'] = $loginusername;
        $_SESSION['id'] = $iddb;
        header("Location: testprofile.php?username = $loginusername");
        exit();

    }
    else {
        echo "Password is incorrect";
    }

     }
     else {
         echo "$loginusername doesn't exist";
     }
 }
 else {
     echo "Please fill out the fields";
 }

 }

?>


<div style=" width: 400px; margin: 0px auto 0px auto" class="LoginForm">
        <table class= "logintable">
             <tr><td width="60%" valign="top">
                  <h3>MySite</h3>
            <h2>Login</h2>
                 <form action="login.php" method="post">
                     <input type="text" name="userlogin" size="12" placeholder="Username"/><br/> <br/>
                <input type="password" name="passwordlogin" size="12" placeholder="Password"/><br/> <br/>
                     <input type="submit" name="login" value="Login!"/>
                     </form>
                 <div id="forgotpassword">
    <a href="#">I forgot my password</a>
    </div>   
            </td>
            </tr>
        </table>

            </div>

为了简化这个例子,我创建了一个几乎空白的配置文件页面,名为testprofile.php

testprofile.php

<?php
session_start();
echo $_GET['username']; 
echo $_GET['id'];

?>

这对我没有任何帮助。但是,如果你这样做:

<?php
session_start();
echo $_SESSION['username']; 
echo $_SESSION['id'];

?>

您可以看到登录用户的用户名和ID。我已经尝试将login.php中的session_start()移到最顶层(这就是它在开头的时候),但它根本没有帮助。 我能够设置整个用户个人资料页面,但是用户无法查看其他用户的个人资料。这就是为什么我现在正在努力解决这个问题。 我希望有人能告诉我这是一个非常微不足道的错误,我已经无缘无故地拔了头发。

最好的问候

大卫

好的,我要粘贴我的代码,因为这太荒谬了。我没有得到这个$ _GET函数,它似乎在其他地方工作但是这个配置文件页面。

login.php

     <?php 
 include ("./Various/header.php");
 require './Various/connections.php';

 if(isset($_POST['login'])) {
      session_start();

 //Set Variables
 $loginusername = $_POST['userlogin'];
 $loginpassword = $_POST['passwordlogin'];

 if(!empty($loginusername)&& !empty($loginpassword)){
     $sql = mysql_query("SELECT * FROM users WHERE username='$loginusername'");
     $checkuser=mysql_num_rows($sql);

     if($checkuser == 1) {

         $passrow = mysql_fetch_assoc($sql);
         $checkpass = $passrow['password'];

         $userdb = $passrow['username'];
         $iddb = $passrow['id'];

    if ($checkpass == $loginpassword)
    {
        $_SESSION['username'] = $loginusername;
        $_SESSION['id'] = $iddb;
        header("Location: profile.php");
        exit();

    }
    else {
        echo "Password is incorrect";
    }

     }
     else {
         echo "$loginusername doesn't exist";
     }
 }
 else {
     echo "Please fill out the fields";
 }

 }

?>


<div style=" width: 400px; margin: 0px auto 0px auto" class="LoginForm">
        <table class= "logintable">
             <tr><td width="60%" valign="top">
                  <h3>MySite</h3>
            <h2>Login</h2>
                 <form action="login.php" method="post">
                     <input type="text" name="userlogin" size="12" placeholder="Username"/><br/> <br/>
                <input type="password" name="passwordlogin" size="12" placeholder="Password"/><br/> <br/>
                     <input type="submit" name="login" value="Login!"/>
                     </form>
                 <div id="forgotpassword">
    <a href="#">I forgot my password</a>
    </div>   
            </td>
            </tr>
        </table>

            </div>

登录与之前相同(减去?user = part)。从此我被重定向到个人资料页面。

profile.php

    <?php
session_start();

include './Various/header.php';
require './Various/connections.php';

  $username = $_SESSION['username'];
  $sql = mysql_query("SELECT * FROM users WHERE username='$username'");
  $getdata = mysql_fetch_array($sql);
  $firstname = $getdata['firstname'];
  $lastname = $getdata['lastname'];
  $blogname = $getdata['blogname'];
  $shoutout = $getdata['aboutuser'];
  $country = $getdata['country'];
  $profilepic = $getdata['profilephoto'];
  $year = $getdata['yearofbirth'];
  $current = date('Y');
  $age = $current - $year;

?>

<div class="profilepage">
<div class="userdetails">
<table>
<tr>
<td>
<img src="<?php echo $profilepic  ?>"/>
</td>

<td>
    <div id="userinfo">
    <h3><?php echo $username?>'s Blog!</h3>
    </div>
<a>Name: <?php echo $firstname?> <?php echo $lastname?>  </a>
<a>Age: <?php  echo $age ?> </a>
<a>Country: <?php echo $country ?> </a>
<a id="shoutout"><?php echo $shoutout ?></a>

</td>

</tr>

</table>
<div id="blogname">
<a><?php echo $blogname ?></a>
</div>
</div>

    <div class="userposts">
    <?php 
  //Displaying user's posts
 //connect to DB
$sql = "SELECT postid, postedby, title, category, LEFT(content, 100) AS content FROM posts WHERE postedby = '$username'
 ORDER BY postid DESC";
$result = mysql_query($sql);

while($row = mysql_fetch_array($result)) {
    $postid = $row['postid'];
    $postedby = $row['postedby'];
    $title = $row['title'];
    $content = $row['content'];
    $category = $row['category'];
  ?>
    <div id="posts">
     <a><?php echo $postedby?></a> 
    <h2><?php echo $title?></h2>
        <a><?php echo $category?></a><br>
        <a><?php echo $content . "<a href='post.php?id=$postid'>Read more...</a>"?></a>
        <br>
        <hr />
        <br>

        <?php 
}
?>
</div>
</div>
</div>

在这里,我获得了我想要的所有数据,并且显示得非常好。我似乎无法做的是允许其他用户查看此用户的个人资料。我知道我需要制作一个动态的url变量。我接下来的教程之一指示我做以下事情:

    if(!isset($_GET['id'])) {
    header("Location: ?user=".getID($_SESSION['id']));
}

getID函数如下所示:

    function getID($id) {
  $dataquery = mysql_query("SELECT id FROM users WHERE id='$id'");  
  while ($row=mysql_fetch_assoc($dataquery)){
      return $row['id'];
  }
}

当我将if语句作为

if(!isset($_GET['id']))

我得到的只是firefox中的一个错误:

  

页面未正确重定向   Firefox检测到服务器正在以永远无法完成的方式重定向此地址的请求。

Chrome中的这个:

  

此网页有重定向循环

自从周二以来,我一直在努力寻找解决方案。我无法继续这样的项目。 我真诚地请求你的帮助。我知道这可能有很多问题(相当大的一些代码,呃)但我真的不知道如何处理这个问题。

正如我之前提到的,我希望允许用户查看其他用户的个人资料。 我从来没有让$ _GET正常工作所以我认为这是原因。现在我只是不知道。

很抱歉有一篇冗长的帖子,我希望有人可以帮助我。我非常感谢你的帮助。

此致

大卫

1 个答案:

答案 0 :(得分:2)

问题在于网址中的间距。

网址$_GET的{​​{1}}数组为:

testprofile.php?username = $loginusername

因此,密钥将为array('username ' => ' $loginusername') 而不是'username '。要修复它,请确保url参数名称和值中没有不必要的空格。另请注意,'username'为空,因为在网址中没有传递此类参数。