रूबी ऑन रेल्स - फाइल अपलोडिंग

आपके पास एक आवश्यकता हो सकती है जिसमें आप अपनी साइट के आगंतुकों को अपने सर्वर पर एक फ़ाइल अपलोड करना चाहते हैं। रेल इस आवश्यकता को संभालना बहुत आसान बनाता है। अब हम एक सरल और छोटी रेल परियोजना के साथ आगे बढ़ेंगे।

हमेशा की तरह, चलो एक नई रेल एप्लिकेशन के साथ शुरू करते हैं जिसे कहा जाता है 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