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

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

ただいまの
回答率

90.33%

  • HTML

    9547questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • ファイル

    178questions

    ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

  • アップロード

    63questions

    アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。

ファイルアップロード機能について

解決済

回答 4

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,595

DAIKI-

score 3

HTMLでホームページを作る場合
<input type="file" name="input_file0" >のようにプログラムをうちファイルを選択するとこまでは実装できました。
やりたいことの流れ
選択したファイルをサーバーに送信
サーバーに送信したファイルをダウンロードしたい
ダウンロードしたファイルを任意で作ったフォルダにいれたい

自分で作成したHTML
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title>tesuto(仮)</title>
</head>
<body> 
<form>
<input type="file" name="input_file0" ><br>
</form>  
</body>
</html>

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • x_x

    2018/07/04 17:31

    アップロードしたファイルをダウンロードするなら、まずアップロードできるようにしなければなりません。HTMLの知識だけではできないので、サーバー側のプログラミング言語を覚えなくてはなりません。よくある機能なので入門書にはたいてい載っているかと思います……

    キャンセル

  • DAIKI-

    2018/07/04 17:33

    そうなのですね、よくある機能なのでね、webで検索しても参照しか出でこないので調べ方が悪かったのですかね

    キャンセル

  • 退会済みユーザー

    2018/07/06 11:40

    複数のユーザーから「やってほしいことだけを記載した丸投げの質問」という意見がありました
    「質問を編集する」ボタンから編集を行い、調査したこと・試したことを記入していただくと、回答が得られやすくなります。

回答 4

+2

formで参照したファイルをサーバーに送信して、送信したファイルをダウンロードしたいと思ったのですがこれは難しいのですか?? 

難しいとかの前にさ、

  1. あなたの目の前にある「MacなりWindowsのPC」から「サーバーに送信」する
  2. 受信したサーバーは「クライアント=あなたの目の前のPC」に応答を返す

こういうことですよね?
もともとあったファイルを元に戻すだけの処理をして何が嬉しいの?

って話。回答者はまずここで、「何でそんなことしなきゃいけないの?」って疑問に思う。

「何がしたいの?」って回答者はあなたに聞く。

質問者「聞かれたことに答えてない」← 今ここ

 ここから独り言

  1. 任意のフォルダを作成する
  2. そのフォルダのアイコンを右クリック
  3. ショートカットを作成
  4. 移動したいファイルをショートカットにドロップする

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

checkベストアンサー

+1

まだ具体的な機能を作るには早いと思うので、入門書を用意しましょう。
サーバーが Windows なら、XAMPP をインストールして PHP を使うのが最も簡単ではないかと思います。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

Webサーバー上にあるホームページ(個人的にはあまりこの呼び方は好きではありません。「Webサイト」ですね)にファイルをアップロードするにはWebサーバー上で動作する言語での実装が必要です。
HTMLからはファイルなど入力情報をそのサーバーに向かって送信することになります。

PHPなどWebサーバーで動作する言語で実装してください。
もちろん「アップロードしたファイルをダウンロード」もWebサーバ側の言語の役目です。

※ここではこの程度にとどめておきます。まずはどの言語を扱うか決めて、勉強してください

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/07/04 16:10

    <!DOCTYPE html>


    <html lang="ja">

    <head>
    <meta charset="UTF-8">
    <title>tesuto(仮)</title>
    </head>

    <body>
    課題提出用 ユーザー認証

    <form>

    <input type="file" name="input_file0" ><br>

    </form>



    </body>
    </html>

    現在このような感じです。

    キャンセル

  • 2018/07/04 16:12

    これだけで何を答えて欲しいのでしょうか。
    回答はどこまで理解されました?

    キャンセル

  • 2018/07/04 16:13

    rubyかJavaScriptで行なっているのですがどちらもできません。

    キャンセル

  • 2018/07/04 16:14 編集

    行って「いる」んですよね?
    それで「どちらもできません」では意味が分かりません。
    何をしようとして何が起きているのか全く伝わっていませんよ。
    分かっている範囲分かっていない範囲を明確にしてください。

    で、回答はどこまで理解されました?(2回目)

    キャンセル

  • 2018/07/04 16:14

    選択されたファイルをダウンロードしたいのですが

    キャンセル

  • 2018/07/04 16:15

    まずはアップロードしては?

    キャンセル

  • 2018/07/04 16:17

    サーバーにアップロードしてから
    そのアップロードされたファイルを自分が作成したファイルにいれていきたいです。

    キャンセル

  • 2018/07/04 16:21

    で、回答はどこまで理解されました?(3回目)

    ご自身だけが知っている情報が多すぎます。
    質問本文を修正して誰が読んでも要件が伝わるように調整してください。

    キャンセル

  • 2018/07/04 16:25

    HTMLからはファイルなど入力情報をそのサーバーに向かって送信することになります。→
    サーバーに向かって送信したファイルをどのように取得すれば良いのですか??

    キャンセル

  • 2018/07/04 16:28

    回答は3行しか読んでませんか?その3行にちゃんと書いてありますよ。

    あと、人の話は最後までちゃんと聞いて(読んで)くださいね。

    ご自身だけが知っている情報が多すぎます。
    質問本文を修正して誰が読んでも要件が伝わるように調整してください。

    キャンセル

  • 2018/07/04 16:35

    回答を修正いたしました

    キャンセル

  • 2018/07/04 16:38

    回答の後半読んでくださいね。
    念のためコメントで再掲しておきます。

    ----------------------------------------------------------------
    PHPなどWebサーバーで動作する言語で実装してください。
    もちろん「アップロードしたファイルをダウンロード」もWebサーバ側の言語の役目です。

    ※ここではこの程度にとどめておきます。まずはどの言語を扱うか決めて、勉強してください
    ----------------------------------------------------------------

    なぜここでとどめたかというと
    丸投げだからです。
    全部書いたところでおそらく質問者さんは理解できません。
    「rubyかJavaScriptで行なっている」と書いている割にはどちらもコードには現れてませんよ。
    行って”いる”んですよね?じゃあその行って”いる”コードで頑張ってください。
    私は「HTMLを提示してください」とは言っていません。
    「質問本文を修正して誰が読んでも要件が伝わるように調整してください。」と言っています。
    何も事情を知らない人に伝わる内容ではありません。

    キャンセル

  • 2018/07/04 16:43

    申し訳ありません。
    また怒られるかもしれませんが
    選択して選んだファイルをサーバーに送信して受け取れる内容が書いてある参考サイトを貼ってくれるとありがたいです。

    キャンセル

  • 2018/07/04 16:48

    > まずはどの言語を扱うか決めて、勉強してください

    キャンセル

  • 2018/07/04 16:49

    というかいっそのことDropBoxでもなんでも使えばいいと思います。
    ファイル共有サービスは幾らでもあるので、今の質問者さんのような状態であればわざわざ自力で作る必要ありません。

    キャンセル

  • 2018/07/04 17:40

    function file_upload()
    {
    // フォームデータを取得
    var formdata = new FormData($('#my_form').get(0));

    // POSTでアップロード
    $.ajax({
    url : "http://localhost:8080/upload.html",
    type : "POST",
    data : formdata,
    cache : false,
    contentType : false,
    processData : false,
    dataType : "html"
    })
    .done(function(data, textStatus, jqXHR){
    alert(data);
    })
    .fail(function(jqXHR, textStatus, errorThrown){
    alert("fail");
    });
    }

    キャンセル

  • 2018/07/04 17:40

    簡易サーバーはlocalhostでやっております

    キャンセル

  • 2018/07/04 17:41

    JavaScriptで行なっております

    キャンセル

  • 2018/07/04 17:41

    何回目かな。
    ****質問本文を修正して誰が読んでも要件が伝わるように調整してください。****
    もう「要件」というのを辞書で引くところからやってください。

    キャンセル

  • 2018/07/04 17:42

    了解です

    キャンセル

  • 2018/07/04 17:43

    というかね。
    「追記修正依頼」で「ここには関わりたくないとすら感じています」と書いたにも関わらず
    人の話を無視した行為を繰り返してるということに気づかない?
    嫌がらせにしかなっていません。空気読もう。私はもう知らない。

    キャンセル

0

まずファイルアップロードはこう

<form method="post" enctype="multipart/form-data">
<input type="file" name="hoge">
<input type="submit" value="go">
</form>


その上で、テンポラリにあがったデータを公開ディレクトリに
移動するプログラムをサーバーに書きます。
サーバー上のファイルをローカルに持ってくるのは、
なんらかのクローラーアプリをつかってください

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/07/04 16:39

    選択したファイルを保存して
    それを任意のファイルにダウンロードさせたい場合はどうすれば良いでしょうか?

    キャンセル

  • 2018/07/04 16:56

    > 選択したファイルを保存して

    ユーザーがするのはアップロードですよね?

    > 任意のファイルにダウンロードさせたい

    サーバ上のファイルをブラウザでアクセスしても
    参照しかできないので、任意のフォルダにダウンロードしたいなら
    クローラー(ダウンローダ)でやる方法をおすすめします。
    (ブラウザではできない)

    キャンセル

  • 2018/07/04 17:21

    ユーザー側と管理側を並行してやっております。すいません
    参照したファイルは何もできないのですか??

    キャンセル

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

  • ただいまの回答率 90.33%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • HTML

    9547questions

    HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

  • ファイル

    178questions

    ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

  • アップロード

    63questions

    アップロードは特定のファイルをウェブサーバに送るプロセスのことを指します。