DEV Community

TK
TK

Posted on

Understanding the basics of Ruby on Rails: HTTP, MVC, and Routes

After learning your first programming language, you may ask what can you do with programming: AI/Machine Learning? Hardware development? Mobile apps? Or maybe you want to start developing web applications! :)

Here we’ll understand the basics of how the web, the routes, and the MVC architecture work using the Ruby on Rails web framework. Let’s dive into the web world.

Before learning web development with Rails, I really recommend learning about Ruby first.

How does the web work?

The web has a bunch of layers (Application, TCP, Internet, Hardware layers) that are all connected. But basically, it works through HTTP (Hypertext Transfer Protocol).

The Hypertext Transfer Protocol (HTTP) is an application protocol for distributed, collaborative, hypermedia information systems. — Wikipedia

The HTTP works like a request — response cycle in the client — server model.

We have a web browser (Google Chrome, for example). So we type the www.google.com URL, and the client submits the HTTP request (request message) to the server. The server returns the HTTP response (response message — in that case, the response is the HTML from Google’s website).

The client does the request and receives the response from the server. The client handles the UI and user interactions. On the server, we can store and retrieve data (on databases), process logic on the background (workers/jobs), and a lot of other things.

If you want to deeply understand it, I’ll suggest some resources. I am a big fan of Preethi’s posts. Here a series of 3 parts:

The MVC architecture and Rails Routes

Now that we understand how the Web works, we’ll study the MVC architecture and Rails Routes.

MVC stands for Model, View, and Controller.

On this architecture, we have the “separation of the concerns” among Models, Views and, Controllers. Each part has its own responsibility. Let’s dive into each part.

Model

“Maintains the relationship between Object and Database and handles validation, association, transactions”

This means that the model will maintain an extreme relation with the Database. Each model (can) represent a database table (in case of SQL databases). This model object gains capabilities (inherited from ActiveRecord — Rails class) to retrieve, save, edit, and delete data from database table. We use model objects as a layer between our application and the database.

Besides that relation with the database, the model can create validationsand associations between models.

View

“A presentation of data in a particular format, triggered by a controller’s decision to present the data.”

This is the presentation of the request’s response. This presentation can be in a bunch of format types: PDF, HTML, JSON, etc. The final result of a view will likely be the user interface (UI) — Part of the “Client.”

For most pages on the web, the views will be an HTML styled with CSS and JS. But we can implement PDFs of user behavior on a Travel digital product to show all employees how people use their website, too.

Controller

“The facility within the application that directs traffic, on the one hand querying the models for specific data, and on the other hand organizing that data (searching, sorting) into a form that fits the needs of a given view.”

The controller is the “Maestro.” It takes care of the flow: uses models to do queries, parses data, and make decisions about in which format you’ll present the data.

MVC & Routes cycle on a Rails application

So imagine that we work at a Travel Startup. Part of the product is to present a list of great articles about travel stories and tips to travelers.

Just think from the traveler’s perspective. You go to www.worldpackers.com/articles and you see a beautiful page listing a bunch of great articles.

When you type this URL in the browser, it makes a request to the server. In the server, we have the Rails web application. The Rails Router verifies if there is an entry matching the requested URL.

We just need to configure the routes for this line:

resources :articles 
Enter fullscreen mode Exit fullscreen mode

This will create RESTful routes for articles. If we run bundle exec rake routes, it will show the list of paths created.

HTTP VERB   PATH                          Controller#Action
GET         /articles(.:format)           articles#index
POST        /articles(.:format)           articles#create
GET         /articles/new(.:format)       articles#new
GET         /articles/:id/edit(.:format)  articles#edit
GET         /articles/:id(.:format)       articles#show
PATCH       /articles/:id(.:format)       articles#update
PUT         /articles/:id(.:format)       articles#update
DELETE      /articles/:id(.:format)       articles#destroy

Enter fullscreen mode Exit fullscreen mode

The HTTP verb can be GET, POST, PATCH, PUT, or DELETE. And we know how Rails maps each PATH to the right controller and action. Read more here.

In our case, the server will receive /articles path and GET as the HTTP verb. It will map to ArticlesController and index action.

In the controllerArticlesController we use the model Article to get all articles in the database and render the view index.html.erb as the server response (the UI).

class ArticlesController < ApplicationController
  def index
    @articles = Article.all
  end
end
Enter fullscreen mode Exit fullscreen mode

By convention, this controller will render the view in views/articles/index.html.erb. Basically, it’s a plain HTML file powered by Ruby.

The Rails request-response cycle is one of the first concepts you need to understand when you start learning web development.

The user does stuff (request to the server), the the Rails application has the router to map the URL path to the right controller. In the controller, we can do all things with a model (or more than one model) — meaning getting, saving, editing, deleting data — and render a view to the user.

That’s all!

We learned a lot here. I hope you guys appreciate the content and learn more about how the MVC architecture and routing work on Rails.

This is one more step forward in my journey to learning and mastering Rails and web development. You can see the documentation of my complete journey here on my Renaissance Developer publication.

If you want a complete Ruby and Rails course, learn real-world coding skills and build projects, try One Month Ruby Bootcamp and Rails Bootcamp. See you there ☺

Have fun, and keep learning and coding.

My Twitter, Medium, Github & LinkedIn. ☺

Latest comments (5)

Collapse
 
arleybri18 profile image
Yony Arley Briñez Valderrama

Thanks very good introduction

Collapse
 
itsjzt profile image
Saurabh Sharma

Oh, TK I thought I have seen you somewhere. Now I remember you from freecodecamp medium

Collapse
 
dimensi0n profile image
Erwan ROUSSEL

Good introduction 😉

Collapse
 
david_j_eddy profile image
David J Eddy

Great article TK!

Collapse
 
drbragg profile image
Drew Bragg

Solid write up! I love Rails, it's so simple to get started but I feel like even now I'm still learning something new about it every day.