質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
POST

POSTはHTTPプロトコルのリクエストメソッドです。ファイルをアップロードしたときや入力フォームが送信されたときなど、クライアントがデータをサーバに送る際に利用されます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

解決済

2回答

2621閲覧

PHPで$_POSTと$_FILESの両方から同時にデータを受け取りたい

user0001

総合スコア13

POST

POSTはHTTPプロトコルのリクエストメソッドです。ファイルをアップロードしたときや入力フォームが送信されたときなど、クライアントがデータをサーバに送る際に利用されます。

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2019/08/02 10:34

編集2019/08/02 10:48

サイト上でファイルをアップロードするシステムを作っているのですが、
フォームに情報を入力し、ファイルを選択して送信ボタンを押したときに、
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>

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2019/08/02 10:34

HTMLを提示してください。
user0001

2019/08/02 10:48

掲示させて頂きました。
guest

回答2

0

普通に受け取れているはずです

PHP

1<?PHP 2print_r($_FILES); 3print_r($_POST); 4?> 5<form method="post" enctype="multipart/form-data"> 6<input type="text" name="hoge" value="123"><br> 7<input type="file" name="fuga" ><br> 8<input type="submit" value="send"><br> 9</form>

投稿2019/08/02 10:42

yambejp

総合スコア114839

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

user0001

2019/08/02 10:50

それであればJavaScriptのコードが原因であるかもしれません。 追記としてHTML, JavaScriptのソースコードを掲示させて頂きましたのでお時間が御座いましたらご教示お願い致します。
yambejp

2019/08/02 11:01

追記されたソースにはそもそもfileを送る仕組みがなさそうですが?
user0001

2019/08/02 11:47 編集

dropzone.jsというライブラリが絡んできますので、もう少し手元で実験してみようと思います。
maisumakun

2019/08/02 11:56

dropzone.jsは、ドロップした瞬間に「ファイルだけ」送信してしまいます。ファイルとフォームを一緒に送る用途には向きません。
guest

0

自己解決

dropzone.jsをそのまま用いるだけではファイルが送信されるだけでフォームに入力された情報をPOSTすることができないため、dropzone.jsに実装されているPOSTする項目を追加するメソッドを実行することで解決できました。

javascript

1this.on("sending", function(file, xhr, formData) { 2 // フォームのname="title"(form.title.value)の入力欄の文字列を$_POST["title"]としてPOSTする 3 formData.append("title", form.title.value); 4});

参考:
・dropzone.jsにおけるPOSTデータの追加について(stackoverflow)
・公式サイトの実装ドキュメント

投稿2019/08/02 13:44

user0001

総合スコア13

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問