Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/261.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
PHP爆炸并在mysql数据库中添加数据_Php_Html_Mysql_Phpmyadmin - Fatal编程技术网

PHP爆炸并在mysql数据库中添加数据

PHP爆炸并在mysql数据库中添加数据,php,html,mysql,phpmyadmin,Php,Html,Mysql,Phpmyadmin,我的问题是:我想在数据库中添加多行(每个网站的pagerank位于不同的行上,而不是像第一张图中那样全部位于一行中)! 我不知道怎么做,我试过使用explode,但只在从浏览器打印表格时起作用,但现在用于数据库中的链接!请帮帮我 在我的数据库中: 在我的浏览器中: <?php error_reporting(E_ALL & ~E_NOTICE); function StrToNum($Str, $Check, $Magic) { $Int32Unit = 42949672

我的问题是:我想在数据库中添加多行(每个网站的pagerank位于不同的行上,而不是像第一张图中那样全部位于一行中)! 我不知道怎么做,我试过使用
explode
,但只在从浏览器打印表格时起作用,但现在用于数据库中的链接!请帮帮我

在我的数据库中:

在我的浏览器中:

<?php
error_reporting(E_ALL & ~E_NOTICE);
function StrToNum($Str, $Check, $Magic)
{
    $Int32Unit = 4294967296;  // 2^32

    $length = strlen($Str);
    for ($i = 0; $i < $length; $i++) {
        $Check *= $Magic;     
        if ($Check >= $Int32Unit) {
            $Check = ($Check - $Int32Unit * (int) ($Check / $Int32Unit));

            $Check = ($Check < -2147483648) ? ($Check + $Int32Unit) : $Check;
        }
        $Check += ord($Str{$i}); 
    }
    return $Check;
}
function CheckHash($Hashnum)
{
    $CheckByte = 0;
    $Flag = 0;

    $HashStr = sprintf('%u', $Hashnum) ;
    $length = strlen($HashStr);

    for ($i = $length - 1;  $i >= 0;  $i --) {
        $Re = $HashStr{$i};
        if (1 === ($Flag % 2)) {              
            $Re += $Re;     
            $Re = (int)($Re / 10) + ($Re % 10);
        }
        $CheckByte += $Re;
        $Flag ++;    
    }

    $CheckByte %= 10;
    if (0 !== $CheckByte) {
        $CheckByte = 10 - $CheckByte;
        if (1 === ($Flag % 2) ) {
            if (1 === ($CheckByte % 2)) {
                $CheckByte += 9;
            }
            $CheckByte >>= 1;
        }
    }

    return '7'.$CheckByte.$HashStr;
}
function HashURL($String)
{
    $Check1 = StrToNum($String, 0x1505, 0x21);
    $Check2 = StrToNum($String, 0, 0x1003F);

    $Check1 >>= 2;     
    $Check1 = (($Check1 >> 4) & 0x3FFFFC0 ) | ($Check1 & 0x3F);
    $Check1 = (($Check1 >> 4) & 0x3FFC00 ) | ($Check1 & 0x3FF);
    $Check1 = (($Check1 >> 4) & 0x3C000 ) | ($Check1 & 0x3FFF);    

    $T1 = (((($Check1 & 0x3C0) << 4) | ($Check1 & 0x3C)) <<2 ) | ($Check2 & 0xF0F );
    $T2 = (((($Check1 & 0xFFFFC000) << 4) | ($Check1 & 0x3C00)) << 0xA) | ($Check2 & 0xF0F0000 );

    return ($T1 | $T2);
}
function getpagerank($url) {
    $query="http://toolbarqueries.google.com/tbr?client=navclient-auto&ch=".CheckHash(HashURL($url)). "&features=Rank&q=info:".$url;
    set_time_limit(0);
    $data=file_get_contents($query);
    $pos = strpos($data, "Rank_");
    if($pos === false){} else{
        $pagerank = substr($data, $pos + 9);
        return $pagerank;
    }  
}
if($_POST['urls'])
{
    ?><table border="1">
    <th>URL</th>
    <th>Pagerank</th>
    <?
    $urls=trim($_POST['urls']);
    $url=explode("\n",$urls);
    foreach($url as $url)
    {
        if($url)
        {
            $url=trim($url);
            $pagerank=getpagerank($url);
            ?>
            <tr><td><?php echo $url; ?></td><td><?php echo $pagerank; ?></td></tr>
            <?     
            //mysql_query("INSERT INTO projects2 (googlePR, Link)  
            //VALUES ('".$pagerank."','".$urls."') ")  or die(mysql_error());           
            flush();
        }              
    }
    ?></table><?
}
else
{
    ?><form action="" method="post">
    URLS:<br /><textarea name="urls" cols="50" rows="10">Introduceti lista de linkuri aici</textarea><br /><input type="submit" value="Check PR & insert values"/>
    </form>
    <?
}
?>

<?php 
    $urls=trim($_POST['urls']);
    $url=explode("\n",$urls);
    foreach($url as $url) {
    if($url)
  {
    $url=trim($url);
    $pagerank=getpagerank($url);

    mysql_query("INSERT INTO projects2 (googlePR, Link)  
    VALUES ('".$pagerank."','".$urls."') ")  or die(mysql_error());
    }
}
?>

我的全部代码:

<?php
error_reporting(E_ALL & ~E_NOTICE);
function StrToNum($Str, $Check, $Magic)
{
    $Int32Unit = 4294967296;  // 2^32

    $length = strlen($Str);
    for ($i = 0; $i < $length; $i++) {
        $Check *= $Magic;     
        if ($Check >= $Int32Unit) {
            $Check = ($Check - $Int32Unit * (int) ($Check / $Int32Unit));

            $Check = ($Check < -2147483648) ? ($Check + $Int32Unit) : $Check;
        }
        $Check += ord($Str{$i}); 
    }
    return $Check;
}
function CheckHash($Hashnum)
{
    $CheckByte = 0;
    $Flag = 0;

    $HashStr = sprintf('%u', $Hashnum) ;
    $length = strlen($HashStr);

    for ($i = $length - 1;  $i >= 0;  $i --) {
        $Re = $HashStr{$i};
        if (1 === ($Flag % 2)) {              
            $Re += $Re;     
            $Re = (int)($Re / 10) + ($Re % 10);
        }
        $CheckByte += $Re;
        $Flag ++;    
    }

    $CheckByte %= 10;
    if (0 !== $CheckByte) {
        $CheckByte = 10 - $CheckByte;
        if (1 === ($Flag % 2) ) {
            if (1 === ($CheckByte % 2)) {
                $CheckByte += 9;
            }
            $CheckByte >>= 1;
        }
    }

    return '7'.$CheckByte.$HashStr;
}
function HashURL($String)
{
    $Check1 = StrToNum($String, 0x1505, 0x21);
    $Check2 = StrToNum($String, 0, 0x1003F);

    $Check1 >>= 2;     
    $Check1 = (($Check1 >> 4) & 0x3FFFFC0 ) | ($Check1 & 0x3F);
    $Check1 = (($Check1 >> 4) & 0x3FFC00 ) | ($Check1 & 0x3FF);
    $Check1 = (($Check1 >> 4) & 0x3C000 ) | ($Check1 & 0x3FFF);    

    $T1 = (((($Check1 & 0x3C0) << 4) | ($Check1 & 0x3C)) <<2 ) | ($Check2 & 0xF0F );
    $T2 = (((($Check1 & 0xFFFFC000) << 4) | ($Check1 & 0x3C00)) << 0xA) | ($Check2 & 0xF0F0000 );

    return ($T1 | $T2);
}
function getpagerank($url) {
    $query="http://toolbarqueries.google.com/tbr?client=navclient-auto&ch=".CheckHash(HashURL($url)). "&features=Rank&q=info:".$url;
    set_time_limit(0);
    $data=file_get_contents($query);
    $pos = strpos($data, "Rank_");
    if($pos === false){} else{
        $pagerank = substr($data, $pos + 9);
        return $pagerank;
    }  
}
if($_POST['urls'])
{
    ?><table border="1">
    <th>URL</th>
    <th>Pagerank</th>
    <?
    $urls=trim($_POST['urls']);
    $url=explode("\n",$urls);
    foreach($url as $url)
    {
        if($url)
        {
            $url=trim($url);
            $pagerank=getpagerank($url);
            ?>
            <tr><td><?php echo $url; ?></td><td><?php echo $pagerank; ?></td></tr>
            <?     
            //mysql_query("INSERT INTO projects2 (googlePR, Link)  
            //VALUES ('".$pagerank."','".$urls."') ")  or die(mysql_error());           
            flush();
        }              
    }
    ?></table><?
}
else
{
    ?><form action="" method="post">
    URLS:<br /><textarea name="urls" cols="50" rows="10">Introduceti lista de linkuri aici</textarea><br /><input type="submit" value="Check PR & insert values"/>
    </form>
    <?
}
?>

<?php 
    $urls=trim($_POST['urls']);
    $url=explode("\n",$urls);
    foreach($url as $url) {
    if($url)
  {
    $url=trim($url);
    $pagerank=getpagerank($url);

    mysql_query("INSERT INTO projects2 (googlePR, Link)  
    VALUES ('".$pagerank."','".$urls."') ")  or die(mysql_error());
    }
}
?>

统一资源定位地址
Pagerank

问题在于您的foreach声明中的内容:

foreach($url as $url) {
这将用数组的第一个值覆盖$url数组,因为变量名相同。然后在循环结束时,当它尝试迭代到下一行时,它正在对非数组对象进行迭代。只需将数组create的名称从explode更改为
$url\u array
或类似的名称,然后执行以下操作

foreach($url_array as $url) {

你的回答有一半是对的,因为我修改了答案 我在以下内容中将
$url
替换为
$url

mysql_query("INSERT INTO projects2 (googlePR, Link)  
    VALUES ('".$pagerank."','".$url."') ")

现在一切都好了

请缩小你的问题范围。阅读所有的源代码和理解您的实际问题是非常困难的。