0

私が繰り返し発生するエラーは次のとおりです。stripslashes()は、パラメーター1が文字列であり、配列が30行目の/target.phpで指定されていることを想定しています。

これはこのサイトの私のコードです。私はこれに不慣れで、30分以上それをやろうとしています。

そんなばかげた質問をしてすみません。

<?php

// rnprofile.php
include_once 'rnheader.php';

if (!isset($_SESSION['user']))
    die("<br /><br />You need to login to view this page");
$user = $_SESSION['user'];
echo "<h3>Edit your Profile</h3>";
if (isset($_POST['text'])) {
    $text = sanitizeString($_POST['text']);
    $text = preg_replace('/\s\s+/', ' ', $text);
    $query = "SELECT * FROM rnprofiles WHERE user='$user'";
    if (queryMysql($query) != false) {
        queryMysql("UPDATE rnprofiles SET text='$text'
            where user='$user'");
    } else {
        $query = "INSERT INTO rnprofiles VALUES('$user', '$text')";
        queryMysql($query);
    }
} else {
    $query = "SELECT * FROM rnprofiles WHERE user='$user'";

    $result = queryMysql($query);
    $sth = $dbh->prepare($query);
    $sth->execute();
    if (queryMysql($query) != false/* mysql_num_rows($result) */) {
        $row = $sth->fetchAll(PDO::FETCH_ASSOC);
        //$row = mysql_fetch_row($result);
        $text = stripslashes($row[1]);
    }
    else
        $text = "";
}
$text = stripslashes(preg_replace('/\s\s+/', ' ', $text));
if (isset($_FILES['image']['name'])) {
    $saveto = "$user.jpg";
    move_uploaded_file($_FILES['image']['tmp_name'], $saveto);
    $typeok = TRUE;
    switch ($_FILES['image']['type']) {
        case "image/gif": $src = imagecreatefromgif($saveto);
            break;
        case "image/jpeg": // Both regular and progressive jpegs
        case "image/pjpeg": $src = imagecreatefromjpeg($saveto);
            break;
        case "image/png": $src = imagecreatefrompng($saveto);
            break;
        default: $typeok = FALSE;
            break;
    }
    if ($typeok) {
        list($w, $h) = getimagesize($saveto);
        $max = 100;
        $tw = $w;
        $th = $h;
        if ($w > $h && $max < $w) {
        $th = $max / $w * $h;
        $tw = $max;
    } elseif ($h > $w && $max < $h) {
        $tw = $max / $h * $w;
        $th = $max;
    } elseif ($max < $w) {
        $tw = $th = $max;
    }
    $tmp = imagecreatetruecolor($tw, $th);
    imagecopyresampled($tmp, $src, 0, 0, 0, 0, $tw, $th, $w, $h);
    imageconvolution($tmp, array(// Sharpen image
        array(−1, −1, −1),
        array(−1, 16, −1),
        array(−1, −1, −1)
            ), 8, 0);
    imagejpeg($tmp, $saveto);
    imagedestroy($tmp);
    imagedestroy($src);
    }
}
showProfile($user);
echo <<<_END
<form method='post' action='rnprofile.php'
enctype='multipart/form-data'>
Enter or edit your details and/or upload an image:<br />
<textarea name='text' cols='40' rows='3'>$text</textarea><br />
Image: <input type='file' name='image' size='14' maxlength='32' />
<input type='submit' value='Save Profile' />
</pre></form>
_END;
?>
4

3 に答える 3

2

PDO::FETCHマニュアルから

PDO :: FETCH_ASSOC:結果セットで返される列名でインデックス付けされた配列を返します

PDO :: FETCH_NUM:結果セットで返される列番号でインデックス付けされた配列を列0から返します

使用 FETCH_ASSOCした場合は、列名をキーとして使用する必要があります$row

    $row = $sth->fetchAll(PDO::FETCH_ASSOC);
    $text = stripslashes($row['column_name']);

またはに変更しますFETCH::NUM

 $row = $sth->fetchAll(PDO::FETCH_NUM);
 $text = stripslashes($row[1);
于 2012-09-24T20:00:30.743 に答える
1

このメソッドはすべてのfetchAll行を含む配列を返すため、次の行になります。

$row = $sth->fetchAll(PDO::FETCH_ASSOC);

$row名前が示すように設定されていませんrow。結果として、$row[1]は単一の文字列ではなく、行全体を含む連想配列になります。

おそらくこれを変更する必要があります:

        $row = $sth->fetchAll(PDO::FETCH_ASSOC);
        //$row = mysql_fetch_row($result);
        $text = stripslashes($row[1]);

これに:

        $rows = $sth->fetchAll(PDO::FETCH_ASSOC);
        $text = stripslashes($rows[0]['column_name_of_interest']);

1(私も次のように変更したことに注意してください0:配列はPHPから0ではなく、PHPからインデックス付けされます1。)

于 2012-09-24T20:02:09.823 に答える
0

これは、連想配列の配列を返すfetchAllを使用しているためです。

if (queryMysql($query) != false/* mysql_num_rows($result) */) {
    $row = $sth->fetchAll(PDO::FETCH_ASSOC);
    $text = stripslashes($row[1]);

したがって、stripslashesを呼び出して渡すと$row[1]、データベースからの2番目の結果で構成される連想配列が渡されます。私はこれがあなたが意味することをするかもしれないと思います:

if (queryMysql($query) != false/* mysql_num_rows($result) */) {
    if ($row = $sth->fetch(PDO::FETCH_ASSOC) {
        $text = stripslashes($row[1]);

これは、名前でユーザーを検索しても1つの結果しか返されないことを前提としています。

于 2012-09-24T20:02:49.960 に答える