链接自PHP 5.4以来不起作用

时间:2014-01-07 10:37:22

标签: php mysql url-rewriting register-globals

这可能是一个register_globals = on issue或url重写问题。我通过使用基本的PHP链接语法消除了url重写的可能性。我尝试了几个补丁来模拟register_globals正在启动但无济于事。直到上周php.ini文件更新时,该网站才正常运行。它是一个php 5.4.23的Apache服务器。 基本上我有一个目录页面,显示从mysql数据库调用的工作列表。当用户单击该链接时,它会将用户带到相应的项目页面。目录列表正确显示但链接不再起作用,并且没有显示错误。它总是链接到mysql请求的第一项而不是请求的链接,即使显示的URL是正确的。 以下是连接数据库的代码:

<?php
$db = mysql_connect("localhost", "user", "pw"); 
mysql_select_db("database_name",$db); 
$sqlNum = 'SELECT * FROM callejas ORDER BY engname ';
$sql = 'SELECT * FROM callejas ORDER BY engname LIMIT '.(($page-1)).",".(1);
$resultNum = mysql_query($sqlNum);
$numRows = mysql_num_rows($resultNum);
$sqlnext = 'SELECT * FROM callejas ORDER BY engname LIMIT ' .(($page)).",".(1);
$sqlpre = 'SELECT * FROM callejas ORDER BY engname LIMIT ' .(($page-2)).",".(1);
//sommaire
$req = 'SELECT * FROM callejas ORDER BY engname  '; 
$result = mysql_query($req); 
$result1 = mysql_num_rows($result);
$milieu =  $result1 / 2;
$mil = (int)$milieu ;
$left = 'SELECT * FROM callejas ORDER BY `engname`  ASC LIMIT 0,'.($mil);
$right = 'SELECT * FROM callejas ORDER BY `engname`  ASC LIMIT '.($mil).",".($result1);
?>

以下是catalog.php文件的一部分,除了链接

之外,它正常运行
    <?
include ("connecttodatabase.php");
$i=1;
$j=0;
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1  /DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
</head>
<body>
<div align="right" id="left" style="position:absolute; width:200px; height:388px; z-index:42; left: 6px; top: 170px;" class="interline30"> 
<?
$leftres = mysql_query($left);
function StandardizeString($img)
{
      $img = strtr($img,
             'ŠŽšžŸÀÁÂÃÄÅÇÈÉÊËÌÍÎÏÑÒÓÔÕÖØÙÚÛÜÝàáâãäåçèéêëìíîïñòóôõöøùúûüýÿ',
             'SZszYAAAAAACEEEEIIIINOOOOOOUUUUYaaaaaaceeeeiiiinoooooouuuuyy' );
      $img = preg_replace('/[\'"]/', '',$img); // Eliminate all quotes
      $img = preg_replace('/[^a-zA-Z0-9]+/', '-', $img); // Remove all spaces
      $img = trim($img, '_'); // Remove any leading or trailing underscored
      // Return the result
      return $img;
  }
while(($myrow = mysql_fetch_array($leftres)))
{
$img= $myrow['engleg'] ;
$little = "".$myrow['little'];
$tittle = StandardizeString($img); 
?>
<div align="center"
<?
echo  "id=\"$i\"";
?>
style="position:absolute; width:153px; z-index:49; left: 207px;top: 
<?
echo "$j px;"
?> 
visibility: hidden;"> 
<?
echo "<img src= \"{$little}\" title= \"{$img}\"  alt= \"{$img}\">";
?>
</div>
<?
echo "<p><a href='works.php?tittle=$tittle&page=$i' 
$img</a></p>";
$i++;
$j = $j+30;
}
?>
</div>
</body>

我一直看不出有什么问题。这段代码已经运行了好几年,在阅读了php 5.3和5.4之间的差异后,我没有看到任何代号被弃用 但我知道register_globals已经开启。

2 个答案:

答案 0 :(得分:2)

Hum ...自PHP 5.3.0以来已经弃用了register_globals,在PHP 5.4中已经 REMOVED

您的问题肯定在于此脚本:works.php

请考虑这个快速而肮脏的修复:register_globals fix

答案 1 :(得分:0)

代码中的以下行未关闭。您可以通过用冒号关闭它来修复它。

<?
echo "$j px;";
?> 

也按照这个SO答案来运行你的脚本,就像启用了注册表全局一样。 https://stackoverflow.com/a/16706242/817365