前提・実現したいこと
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
あなたの回答
tips
プレビュー