私がこれを行うと、それは機能します:
$data_array2 = mysql_query("SELECT pic_loc FROM pictures WHERE user_id = '".$id."'");
$cell_pictures = mysql_fetch_array($data_array2);
foreach($cell_pictures as $pics_being_deleted)
{
unlink($pics_being_deleted);
}
問題は、上記のコードがネストされていることです。つまり、リンク解除関数を実行するたびに新しいMySQLクエリが実行されるため、以下のコードを作成して、それを行わないようにしました。
$the_pics_raw_2 = array();
$data_array2 = mysql_query("SELECT pic_loc FROM pictures WHERE user_id = '".$id."'");
while($cell_pictures = mysql_fetch_array($data_array2))
{
$the_pics_raw = $cell_pictures['pic_loc'];
$the_pics_raw_2[] = $the_pics_raw;
}
$the_pics_raw_3 .= " \"../../". implode("\" , \"../../" ,$the_pics_raw_2)."\"";
$the_pics = array($the_pics_raw_3);
foreach($the_pics as $pics_being_deleted)
{
unlink($pics_being_deleted);
}
代わりにこのエラーが発生します:
Warning: unlink( "../../users/biondizzle/photos/pic_3387677.png" , "../../users/biondizzle/photos/pic_1581185.png") [function.unlink]: No such file or directory
"../../users/biondizzle/photos/pic_3387677.png" , "../../users/biondizzle/photos/pic_1581185.png"
2つの別々のディレクトリが同時に実行されているため、ディレクトリforeach()
が「foreaching」されていないため、ディレクトリが見つからないことは明らかです。
unlink()
配列にリストしたディレクトリごとにを個別に実行する方法はありますが、コンマと引用符をimplode()
?で追加することで機能させることができると思いました。たくさんありがとう、私がそれを十分に説明したことを願っています-マイク