रूबी ऑन रेल्स - फाइल अपलोडिंग
आपके पास एक आवश्यकता हो सकती है जिसमें आप अपनी साइट के आगंतुकों को अपने सर्वर पर एक फ़ाइल अपलोड करना चाहते हैं। रेल इस आवश्यकता को संभालना बहुत आसान बनाता है। अब हम एक सरल और छोटी रेल परियोजना के साथ आगे बढ़ेंगे।
हमेशा की तरह, चलो एक नई रेल एप्लिकेशन के साथ शुरू करते हैं जिसे कहा जाता है testfile। आइए सरल रेल कमांड का उपयोग करके एप्लिकेशन की मूल संरचना बनाएं।
tp> rails new testfile
अनुप्रयोग विकास शुरू करने से पहले, हमें नीचे दिखाए गए अनुसार मणि फाइलें स्थापित करनी चाहिए -
gem install carrierwave
gem install bootstrap-sass
अपने रत्न को खोलें और नीचे दिए गए दो रत्नों को जोड़ दें जैसा कि निम्नलिखित छवि में दिखाया गया है -
रत्न फ़ाइल में रत्न जोड़ने के बाद, हमें कंसोल पर निम्नलिखित कमांड चलाने की आवश्यकता है -
bundle install
मॉडल बनाना
हमें नाम और लगाव के रूप में दो स्ट्रिंग्स के साथ एक मॉडल बनाने की आवश्यकता है जैसा कि नीचे दिखाया गया है -
rails g model Resume name:string attachment:string
हमें डेटाबेस माइग्रेशन बनाने की आवश्यकता है जैसा कि नीचे दिखाया गया है -
rake db:migrate
हमें नीचे दिखाए अनुसार नियंत्रक उत्पन्न करना होगा -
rails g controller Resumes index new create destroy
महान! अब हमारे पास आधारभूत संरचना है। अब हमें अपलोडर बनाने की आवश्यकता है। एक अपलोडर कैरियरवाहक मणि से आया था और यह वाहक को बताता है कि फाइलों को कैसे संभालना है। संक्षेप में, इसमें सभी फ़ाइल प्रोसेसिंग फ़ंक्शंस शामिल हैं। नीचे दिखाए अनुसार अपलोडर बनाने के लिए कमांड चलाएँ
rails g uploader attachment
अब फिर से शुरू होने वाले मॉडल को खोलें और नीचे दिखाए अनुसार अपलोडर को कॉल करें। रिज्यूम मॉडल को ऐप / मॉडल / फिर से शुरू किया गया है।
class Resume < ActiveRecord::Base
mount_uploader :attachment, AttachmentUploader # Tells rails to use this uploader for this model.
validates :name, presence: true # Make sure the owner's name is present.
end
नियंत्रक पर काम करने से पहले, हमें अपने config / मार्गों को संशोधित करना होगा।
CarrierWaveExample::Application.routes.draw do
resources :resumes, only: [:index, :new, :create, :destroy]
root "resumes#index"
end
नीचे दिए गए अनुसार हम नियंत्रक को संपादित करते हैं।
class ResumesController < ApplicationController
def index
@resumes = Resume.all
end
def new
@resume = Resume.new
end
def create
@resume = Resume.new(resume_params)
if @resume.save
redirect_to resumes_path, notice: "The resume #{@resume.name} has been uploaded."
else
render "new"
end
end
def destroy
@resume = Resume.find(params[:id])
@resume.destroy
redirect_to resumes_path, notice: "The resume #{@resume.name} has been deleted."
end
private
def resume_params
params.require(:resume).permit(:name, :attachment)
end
end
चलिए css file.css फ़ाइल में बूटस्ट्रैप कार्यान्वयन जोड़ते हैं / एप्लिकेशन / एसेट / स्टाइलशीट / रिज्यूमे।
@import "bootstrap";
अब एप्लिकेशन / विचार / लेआउट / application.html.erb खोलें और नीचे दिखाए अनुसार कोड जोड़ें -
<!DOCTYPE html>
<html>
<head>
<title>Tutorialspoint</title>
<%= stylesheet_link_tag "application", media: "all", "data-turbolinks-track" => true %>
<%= javascript_include_tag "application", "data-turbolinks-track" => true %>
<%= csrf_meta_tags %>
</head>
<body>
<div class = "container" style = "padding-top:20px;">
<%= yield %>
</div>
</body>
</html>
अब हमें नीचे दिखाए अनुसार सूचकांक दृश्य सेट करने की आवश्यकता है -
<% if !flash[:notice].blank? %>
<div class = "alert alert-info">
<%= flash[:notice] %>
</div>
<% end %>
<br />
<%= link_to "New Resume", new_resume_path, class: "btn btn-primary" %>
<br />
<br />
<table class = "table table-bordered table-striped">
<thead>.
<tr>
<th>Name</th>
<th>Download Link</th>
<th> </th>
</tr>
</thead>
<tbody>
<% @resumes.each do |resume| %>
<tr>
<td><%= resume.name %></td>
<td><%= link_to "Download Resume", resume.attachment_url %></td>
<td><%= button_to "Delete", resume, method: :delete, class: "btn btn-danger", confirm: "Are you sure that you wish to delete #{resume.name}?" %></td>
</tr>
<% end %>
</tbody>
</table>
अब, new.html.erb को संपादित करने और हमारे फॉर्म कोड को जोड़ने देता है।
<% if [email protected]? %>
<div class = "alert alert-error">
<ul>
<% @resume.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<% end %>
<div class = "well">
<%= form_for @resume, html: { multipart: true } do |f| %>
<%= f.label :name %>
<%= f.text_field :name %>
<%= f.label :attachment %>
<%= f.file_field :attachment %>
<%= f.submit "Save", class: "btn btn-primary" %>
<% end %>
</div>
अब सर्वर शुरू करें और http: // localhost: 3000 पर जाएँ। यह निम्नानुसार एक स्क्रीन का उत्पादन करेगा -
एक आखिरी चीज जो हमें करने की ज़रूरत है वह अनुमत फ़िलेपेट्स की सूची को फ़िल्टर करना है। इसके लिए हमें ऐप / अपलोडर्स / अटैचमेंट_अपलोडर.आरबी के नीचे दिए गए सरल कोड को जोड़ने की आवश्यकता है
class AttachmentUploader < CarrierWave::Uploader::Base
storage :file
def store_dir
"uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}"
end
def extension_white_list
%w(pdf doc htm html docx)
end
end
अब सर्वर शुरू करें और http: // localhost: 3000 पर जाएँ। अब एक गलत प्रारूप इनपुट; यह एक गलत संदेश उत्पन्न करेगा जैसा कि नीचे दिखाया गया है -
पर पूरी जानकारी के लिए File वस्तु, आप के माध्यम से जाने की जरूरत है Ruby Reference Manual।