サイト上でファイルをアップロードするシステムを作っているのですが、
フォームに情報を入力し、ファイルを選択して送信ボタンを押したときに、
PHPでデータを受け取りたいのですが、
前提条件として、ファイルと入力情報が送信されていることを確認するために、
PHP
1if( !empty($_FILES) and isset($_POST) ){ 2 // ファイルを保存したり、入力情報を登録する処理 3}
として、その中で処理を行おうとしたのですが、
ファイルは受け取れているが、POSTされた情報が受け取れませんでした。
どのようにすれば、同時に受け取ることができますでしょうか?
PHPに詳しくなく、この辺りの仕様を理解できていません。
他に情報が必要でしたらご指摘を頂けると幸いです。
宜しくお願い致します。
追記:関係していると思われる個所を掲示させていただきます。
form
1<form method="post" action="" id="form" class="files-container" style="background-color: rgb(248,248,248);text-align: center;" enctype="multipart/form-data"> 2 <div class="form-group"><input class="form-control" type="text" name="title" placeholder="タイトル" style="margin-top: 8px;margin-bottom: 8px;" required=""></div> 3 <div class="form-group"><button id="dropzoneSubmit" class="btn btn-primary btn-block d-xl-flex justify-content-xl-center" style="font-size: 16px;margin-top: 64px;">公開する</button> 4 </div> 5 <input type="submit" value="" style="display:none" name="publish"> 6</form>
javascript
1<script type="text/javascript"> 2 Dropzone.autoDiscover = false; 3 $(document).ready(function() { 4 var myDropzone = new Dropzone("#myDropzone", { 5 url: "", 6 paramName: "file", 7 autoProcessQueue: false, 8 uploadMultiple: true, 9 parallelUploads: 100, 10 maxFilesize: 3, 11 maxFiles: 10, 12 acceptedFiles: ".jpg, .jpeg, .png, .gif", 13 addRemoveLinks: true, 14 dictFileTooBig: "この画像のサイズは{{filesize}}MBです. 最大サイズは{{maxFilesize}}MBです", 15 dictInvalidFileType: "対応している拡張子はJPG, JPEG, PNG, GIFのみです", 16 dictCancelUpload: "キャンセル", 17 dictRemoveFile: "削除", 18 dictMaxFilesExceeded: "アップロード可能な枚数は最大{{maxFiles}}枚です", 19 dictDefaultMessage: "画像を選択してください", 20 }); 21 }); 22 Dropzone.options.myDropzone = { 23 init: function() { 24 var pf = false; 25 var myDropzone = this; 26 $("#dropzoneSubmit").on("click", function(e) { 27 e.preventDefault(); 28 e.stopPropagation(); 29 30 if(pf){ 31 $("input[name=publish]").click(); 32 } 33 34 if (myDropzone.files != "") { 35 myDropzone.processQueue(); 36 } else { 37 $("#myDropzone").submit(); 38 } 39 }); 40 // ファイル追加時 41 this.on("addedfile", function(file) { 42 // console.log(file); 43 }); 44 // エラー時 45 this.on("error", function(file, response) { 46 // console.log(response); 47 }); 48 // アップロード開始時 49 this.on("sendingmultiple", function(file) { 50 // console.log(file); 51 }); 52 // アップロード成功時 53 this.on("successmultiple", function(file) { 54 // submit form 55 pf = true; 56 $("input[name=publish]").click(); 57 }); 58 } 59 }; 60</script>
回答2件
あなたの回答
tips
プレビュー