0
私はユーザーが自分の情報を入力し、1つ以上のlongblobファイル(画像やpdfのような別のファイル)を挿入することができますが、挿入はまだできません。私は手動でファイルをMySQLに挿入して取得することができます(表示/ダウンロード)、添付ファイルは「添付ファイル」テーブルと顧客テーブルの「添付ファイル」列にアップロードされます。ここでは達成されたコードを示します:私はFOCよ今複数のblobファイルの挿入php
if(isset($_FILES['Attachment']) && !empty($_FILES['Attachment']['name'][0])){
$last_id = $conn->insert_id;
$error=insertFile_db($_FILES['Attachment'],$conn,CONTNAME,$last_id);
if($error===True)
{$conn->close();header("location:/skylite/".CONTNAME."/Create?error=Internal error");exit();}
}
:
<?php function insertFile_db($myFile,$conn,$tablename,$id){
$fileCount = count($myFile["name"]);
$sql="INSERT INTO Attachments (tableName,CustomerId,Name,File,Size,Type) ";
for ($i = 0; $i < $fileCount; $i++) {
$fileName=$myFile["name"][$i]; // Note : $myFile=$_FILES['Attachment']
$fileTmp_name=$myFile["tmp_name"][$i];
$fileType=$myFile["type"][$i];
$fileSize=$myFile["size"][$i];
//$fileContent = addslashes(file_get_contents($myFile['images']['tmp_name']));
$file=fopen($fileTmp_name,'r'); //'r' open for reading only, pts at the beginning of the file
$fileContent=fread($file,$fileSize);
fclose($file);
$fileContent = addslashes($fileContent);
if(!get_magic_quotes_gpc())
$fileName = addslashes($fileName);
if($i==($fileCount-1) && $i==0)
$sql.="VALUES ('".$tablename."', ".$id.", '".$fileName."','$fileContent','".$fileSize."','".$fileType."')" ;
else if($i!=($fileCount-1) && $i==0)
$sql.="VALUES ('".$tablename."', ".$id.", '".$fileName."','$fileContent','".$fileSize."','".$fileType."')," ;
else if($i==($fileCount-1) && $i!=0)
$sql.=" ('".$tablename."', ".$id.", '".$fileName."','$fileContent','".$fileSize."','".$fileType."')" ;
else
$sql.=" ('".$tablename."', ".$id.", '".$fileName."','$fileContent','".$fileSize."','".$fileType."')," ;
}
if(!$conn->query($sql))
return True;
return Flase;
} ?>
と私は関数を呼び出していますアタッチメントテーブルに挿入すると、私はいくつかのヒントと助けに感謝します!