I’m wanting to send a post request from my JavaScript code to my show action in Ruby on Rails which contains data that I want to store in an instance variable so I can save it on a form in my view and upload it to my server.
As you can see below, the parameter ‘base64’ is showing up in my rails logs, but when I try to call @base64 in my view, after grabbing the value in the controller, it’s nil.
Any advice is appreciated, thanks!
View
var full_base64 = "data:image/jpeg;base64," + base64;
$.ajax({
data: 'base64=' + full_base64,
type: 'POST',
url: "/videos/show/<%[email protected]%>"
});
Controller
def show
@video = Video.find(params[:id])
if params[:base64].present?
@base64 = params[:base64]
end
end
Routes
post 'videos/show/:id', to: 'videos#show'
Rails server log:
Started POST "/videos/show/1" for 127.0.0.1 at 2020-01-22 12:59:40 -0600
Processing by VideosController#show as */*
Parameters: {"base64"=>"...
...
, "id"=>"1"}
Console
>>
@base64
=> nil
>>
3
Answers
If I understand correctly you are trying to pass AJAX to the
show
action in your controller. This is a very GENERALIZED answer as you have failed to include any of your HTML code and it looks like you don’t have a button to fire the AJAX. But I’ll try to point you in the right direction. You need to do something along the general lines of:That will send your AJAX call to a controller method I’ve called
my_ajax_upload
but you can call it whatever you like. In your controller you would need something like:This responds to the initial AJAX call by saving the param you sent to the DB and replying by calling a file called
base_64_response.js.erb
which might look something like:Which will render the HTML file called
base_64_response.html.erb
which needs to contain the html code you want to appear in the page that called it.The cycle is
load page
->do something to trigger AJAX call to controller method
->process AJAX call with controller method
->render JS file
->JS file replaces div in page with new html
You probably need to read up more on how AJAX works in Rails. This RailsCast might help http://railscasts.com/episodes/136-jquery-ajax-revised?view=asciicast
Just FYI – I have also noticed strange things in Rails if you do not explicitly define the content type. In your posted example you are not stating the contentType and it could be parsing nil for that reason. When posting base 64 data you can specify the content type as:
and it may change what the controller parses for the body.
How to post an image in base64 encoding via .ajax?
Just use string instead of symbol for hash key