我正在尝试从文件向if(isset(...))
语句返回一个$user_id
变量。我将执行一个不同的if语句,但只是尝试echo
输出$user_id
变量,以测试我正在设置页面。
<?php
include 'core/init.php';
include 'init.image.php';
protect_page();
include 'includes/overall/overall_header.php';
if(isset($_GET['username']) === true && empty($_GET['username']) === false){
$username = $_GET['username'];
if(user_exists($username) === true){
$user_id = user_id_from_username($username);
$profile_data = user_data($user_id, 'first_name','last_name','email', 'username');
?>
<h1><?php echo $profile_data['first_name']; ?>'s Yor Page</h1>
<div id="navWrapper">
<ul>
<li>
<a href="#"><img src="uploads/profile/blank_profile.gif" width="150" height="150" id="blank_profile"></a>
</li>
<nav>
<ul>
<li>
<a href="<?php echo $profile_data['username'];?>?action=albums">Albums</a>
</li>
<li>
<a href="<?php echo $profile_data['username'];?>?action=music">Music</a>
</li>
</ul>
</nav>
</ul>
</div>
<?php
if(isset($_GET['action']) && $_GET['action']=='albums'){
$albums = get_profile_albums($user_id);
if(empty($albums)){
echo 'No Albums';
}else{
foreach($albums as $album){
if (empty($album['image'])) {
$album['image'] = 'uploads/profile/blank_profile.gif';
}
?>
<p><?php echo $album['name'],' (', $album['count'], ')'?> <br />
<a href="<?php echo $profile_data['username'];?>?action=album_id=<?php echo $album['id'];?>">
<img src="uploads/thumbs/<?php echo $album['id'];?>/<?php echo $album['image'];?>" />
</a><br />
<?php echo $album['description'];?>...<br />
</p>
<?php
}
}
}
if(isset($_GET['action']) && $_GET['action']=='album_id=$album['id']'){
echo $user_id;
}
if(isset($_GET['action']) && $_GET['action']=='music'){
echo'<h1>Music</h1>';
}
}else{
echo 'Sorry, that user doesn''t exist';
}
}else{
header('Location: index.php');
exit();
}
include 'includes/overall/overall_footer.php';
?>
单引号不解析字符串,双引号解析。例如:
$album_id = 1;
echo 'album_id=$album_id ';
echo "album_id=$album_id";
将导致album_id=$album_id album_id=1
因此,$_GET['action']=='album_id=$album_id'
正在检查$_GET['action']
是否等于'album_id=$album_id'
,而不是$album_id
被评估为什么
你的支票应该更多地沿着以下几条线:
if (/* ... */ && $_GET['action']=="album_id=$album_id") {
编辑:建议。
您应该检查$_GET['action']
一次并存储$action
。从那里创建一个if/else if/else
语句,检查每种可能的动作类型(音乐、专辑、专辑等)。如果一种类型的操作需要额外的用户提供的数据,请将其包含在相应的If块中。例如:
$action = $_GET['action'];
// URL: /script.php?action=albums
if ($action == 'albums') {
// ...
}
// URL: /script.php?action=album&album_id=12
else if ($action == 'album') {
if (!empty($_GET['album_id'])) {
$album_id = $_GET['album_id'];
echo "User with id $user_id is trying to access album with id $album_id";
}
// ...
}
// ...
不再有$_GET['action']=="album_id=$album_id"
您正确地传递了变量。
我更关心的是:
if(isset($_GET['action']) && $_GET['action']=='album_id=$album_id'){
'album_id=$album_id'
看起来不对,这可能是你的if没有开火的原因。。。看起来您正在尝试使用单引号包装的变量$album_id
,这不会替换该值,而是保持$album_id
的正确性。我不确定这是否是你想要的,但如果不是,这很可能是你问题的根源。