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

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

新規登録して質問してみよう
ただいま回答率
85.46%
ファイル

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

HTML

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

Q&A

0回答

712閲覧

HTMLのformについて、動作の確認で送信押しても結果がちゃんと表示されない

integral_ys

総合スコア11

ファイル

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

HTML

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

0グッド

0クリップ

投稿2022/01/09 06:58

前提・実現したいこと

htmlとrubyでformを利用して入力した情報をrubyに送りたいのですが、送信ボタンを押すとactionに指定されたファイルの中身が表示されるだけでrubyが実行されません。
今はvscodeでただファイルを開いて実行しているだけなのですが、どのような環境で実行すれば良いのでしょうか?
確認をしたいだけなのでソースコードはネットから拾ってきて実行してみようとした物です。

該当のソースコード

HTML

1<!DOCTYPE html> 2<html lang="ja"> 3<head> 4 <meta charset="UTF-8"> 5 <meta http-equiv="X-UA-Compatible" content="IE=edge"> 6 <meta name="viewport" content="width=device-width, initial-scale=1.0"> 7 <title>RubyTest</title> 8 9</head> 10<body> 11 <form action="./test2.rb" method="POST" enctype="multipart/form-data"> 12 <input type="file" name="file"> 13 <input type="text" name="text" value=""> 14 <input type="submit" value="Upload"> 15 </form> 16</body> 17</html>

Ruby

1#test2.rb 2#!/usr/bin/ruby 3 4require 'cgi' # CGI 5require 'fileutils' # File 6require 'pathname' # Pathname 7 8$cgi = CGI.new 9 10# ファイルの情報を取得する 11upload_file = $cgi.params['file'][0] 12 13# アップロードされたファイルからファイル名を取得する : `FILE-NAME.txt` のような文字列が取れることになる 14file_name = upload_file.original_filename.split(/(\|/)/)[-1] 15 16# ファイル保存先のフルパス文字列を作る : `/PATH/TO/home/sub-directory/FILE_NAME.txt` となる 17target_path = Pathname.new('/PATH/TO/home').join('sub-directory', file_name).cleanpath.to_s 18 19# ファイルをアップロード (書き込み) する 20File.open(target_path, 'w') do |file| 21 file.binmode 22 file.write(upload_file.read) 23end 24 25# その他、フォーム送信された情報を取得してみる 26text = $cgi.params['text'][0].read 27 28# レスポンスとして HTML を表示する 29print(<<"EOL") 30Content-Type: text/html; charset=UTF-8 31 32<!DOCTYPE html> 33<html lang="ja"> 34 <head> 35 <meta charset="UTF-8"> 36 <title>Result</title> 37 </head> 38 <body> 39 <p>アップロードしました</p> 40 <p>ファイル名 : #{file_name}</p> 41 <p>保存先フルパス : #{target_path}</p> 42 <p>テキスト : #{text}</p> 43 </body> 44</html> 45EOL

試したこと

ファイルからHTMLファイルを開いて送信してみたが、送信を押すとrubyのスクリプトファイルがブラウザで表示される。
Vscodeのopen live serverで開いたが送信すると表示されなくなる。

補足情報(FW/ツールのバージョンなど)

Mac 12.1

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

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

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

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

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

m.ts10806

2022/01/09 07:22

そもそもWebサーバは立てられてるのでしょうか。 リクエストを受け取りたい場合、Webサーバ上でhttpリクエスト可能でなければ受け取れません。
integral_ys

2022/01/09 07:57

すみません、調べ不足でwebサーバー上ですることは知りませんでした。 webサーバーを立ててやってみようと思います。 ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問