お世話になっております。
こちらのサイトさまを参考にRailsAPIを制作してみました。
Railsで、画像をアップロード、ダウンロードするREST API
無事、サイト通りの動作は行えたのですが、Rails内で画像の処理を行いたいため、
一度pngとしてRails内に配置したいです。
先程のサイトのapp/controller/images_controller.rbを以下のように変更して
perlからSQLiteにアクセスし直接画像を取得しようと考えましたが、どうにも上手く行きませんでした。
1 require 'shellwords'< 2 require 'sqlite3'< 3 < 4 class ImagesController < ApplicationController< 5 def show< 6 image = Image.find(params[:id])< 7 render json: image,except: [:data]< 8 9 end< 10 < 11 # POST< 12 def create< 13 image = Image.new< 14 image.tag = params[:tag]< 15 image.save!< 16 render json: image,except: [:data]< 17 18 end< 19 < 20 def download< 21 image = Image.find(params[:id])< 22 send_data image.data, type: "image/png",disposition: 'inline'< 23 24 system("perl app/controllers/get_picture.pl")< 25 end< 26 < 27 # PUT< 28 def upload< 29 db = SQLite3::Database.new("image.db")< 30 image = Image.find(params[:id])< 31 image.data = request.raw_post< 32 image.save!< 33 render json: image, except: [:data] 34 # 追加した処理 35 system("perl app/controllers/get_picture.pl")< 36 end< 37 end<
perl内のコードは以下のようになっております。
perl
1use strict; 2use warnings; 3use DBI; 4 5# dbを開く 6my $dbh = DBI->connect("dbi:SQLite:dbname=db/development.sqlite3.db") or die $DBI::errstr; 7 8# 画像データをDBから取得 9my $o_sth = $dbh->prepare("SELECT data FROM images WHERE id=1"); 10$o_sth->execute(); 11my $row = $o_sth->fetch(); 12my $o_img = $row->[0]; 13$o_sth->finish(); 14 15# 画像データをファイルに出力 16open my $fh, ">:raw", "image.png"; 17print $fh $o_img; 18close $fh;
尚、本システムを起動したあとに、このperlプログラムを単体動作させると
無事に画像が取得できますが、Rails内に組み込むと画像が出力されますが、データ量が少ない、pngファイルが出力されてしまいます。
もっと効率がいい方法があるはずだと思いますが、なかなかわからず詰まっております。
よろしくお願いいたします。
追記:
どうやら、Rails起動中にデータベースに他のプログラム(Perlとか)でアクセスすると画像がうまく表示されない事がわかりました。
一回Railsを止めてから本Perlプログラムを動かすと画像を取得できるのですが…。
Railsを止めずにRails内に画像を保存したいです。
どなたかよろしくお願いいたします。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。