uploadify を使用して複数の画像を mysql データベースに挿入しようとしています。私のデータベースは、その列の 1 つを longblob 型にしています。複数のファイルを選択するたびに、最初の画像だけが正常に挿入されます。複数 = true に設定しました。複数の画像を挿入できず、アップロード リンクをクリックしても onComplete イベントが実行されません。エラーは表示されません。何らかの理由で、スクリプトで複数の画像を挿入できず、その結果、アップロード完了イベントが呼び出されません。
私が遭遇した例のほとんどは、実際の画像を挿入するのではなく、ファイル名のパスをデータベースに挿入するだけです。スクリプトで複数の画像をデータベースにアップロードするのを手伝ってもらえますか?
これは私の index.php スクリプトです:
<script type="text/javascript">
$(document).ready(function() {
//alert('I am ready to use uploadify!');
$("#picture").uploadify({
'uploader': 'uploadifyit/uploadify.swf',
'script': 'sqlupload.php',
'cancelImg': 'uploadifyit/cancel.png',
'folder': 'uploads',
'auto': false, // use for auto upload
'multi': true,
'queueSizeLimit': 4,
'sizeLimit': 10000000,
'onQueueFull': function(event, queueSizeLimit) {
alert("Please don't put anymore files in me! You can upload " + queueSizeLimit + " files at once");
return false;
},
'onAllComplete' : function(){
alert("Thank you. All files have been uploaded successfully.");
},
'onComplete': function(event, ID, fileObj, response, data) {
console.log(response); // If you're using firebug
alert(response); // Will alert the php error
},
'onUploadError' : function(file, errorCode, errorMsg, errorString) {
alert('The file ' + file.name + ' could not be uploaded: ' + errorString);
}
});
});
</script>
sqlupload.php
<?php
mysql_connect("localhost", "root", "")or die(mysql_error());
mysql_select_db("project") or die(mysql_error());
if (!empty($_FILES)) {
$fileTypes = array('jpg','jpeg','gif','png'); // File extensions
$fileParts = pathinfo($_FILES['Filedata']['name']);
if (in_array(strtolower($fileParts['extension']),$fileTypes)) {
$pic_name = $_FILES['Filedata']['name'];
$pic_size = $_FILES['Filedata']['size'];
$pic_type = $_FILES['Filedata']['type'];
$imgData =addslashes(file_get_contents($_FILES['Filedata']['tmp_name']));
// our sql query
$sql = "INSERT INTO photos (name,type,size,image) VALUES('$pic_name','$pic_type','$pic_size','$imgData')";
// insert the image
mysql_query($sql) or die("Error in Query: " . mysql_error());
}
else {
echo "Invalid file type";
}
}
?>