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

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

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

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

PHP

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

Q&A

1回答

2586閲覧

XMLHttpRequestでFILEを送れない

seri

総合スコア422

HTTP

HTTP(Hypertext Transfer Protocol)とはweb上でHTML等のコンテンツを交換するために使われるアプリケーション層の通信プロトコルです。

PHP

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

0グッド

1クリップ

投稿2017/04/29 06:29

formdata = new FormData(); var in=$(':input[name="in"]').val(); formdata.append('_in',in); var xhr = new XMLHttpRequest(); xhr.open("POST","http:....php",false); xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded'); xhr.send(formdata);

上記のようなリクエストをサーバーに送っても返答がありません

サーバーでは以下のような実装です

if(isset($_FILES["_in"])){ echo "Load"; }

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

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

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

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

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

guest

回答1

0

var in=$(':input[name="in"]').val(); は、in が予約語なので使えないので別名に。val() ではファイルを扱えないので、以下記事参照。

あと、Content-Type が違います。(ファイル送信の場合、多分省略しても動くと思われる)

【ajax - javascript xhr file upload without jQuery - Stack Overflow】
http://stackoverflow.com/questions/36475737/javascript-xhr-file-upload-without-jquery

【[JavaScript] HTML5のFileオブジェクトを利用したファイルアップロード】
https://www.ipentec.com/document/document.aspx?page=javascript-upload-file-using-xmlhttprequest-and-file-object

【XMLHttpRequestでファイルをアップロードして中身を表示させるサンプルコード -でじうぃき】
http://onlineconsultant.jp/pukiwiki/?XMLHttpRequestでファイルをアップロードして中身を表示させるサンプルコード

投稿2017/04/29 08:38

kei344

総合スコア69407

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

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

seri

2017/04/30 10:46

回答ありがとうございます。 valが使えないとのことですが、これは全てFile型にしてから送るとゆう解釈でよろしいでしょうか?
kei344

2017/04/30 11:31

細かいですが「File型」というものはありませんよ。リンク先でのファイルの扱い方を参照ください。
seri

2017/04/30 11:52

FormData()とし、値はForm.text.valueでとり出すようにしましたが、送信先サーバーで if(isset($_FILES["text"])){ echo "Load"; } としても、やはり反応してくれません。。
kei344

2017/04/30 12:11

リンク先に .value で取得すると書いてありましたか?
seri

2017/04/30 12:28

file[0]としうけとって見ましたがそれでも受け取れませんでした
seri

2017/04/30 12:32

リンク先を参考に、HtmlではFormを実装し、JavaScriptも書き換えましたがそれでもPHPでは受け取れません。 $_REQUESTだと受け取れるのですが、送るデータにはBlob型もあるのでFILEとして受け取りたいのです。
kei344

2017/04/30 12:42

質問文にHTML/JavaScriptを追記してください。(決して元のコードを消さないでください)
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問