As beginners, we always seem to hear these terms:
back-end. Initially, we are too afraid to ask what that means. We usually Google them. And that's when we know, front end deals with user interface code and back end deals with the server-side code. But then, they are the Lemon and Water of the Lemonade. They both combine to create the wonder we know as the World Wide Web.
In my previous post, I discussed how the web works for front end developers, how the Internet mainly consists of Clients and Servers. I touched topics of requests and responses, and how does the Client handle the responses to give you a seamless User Interface. The Lemon of our Lemonade.
Let's talk about Water now.
We know that when the Client requests, the Server responds. The Server is 100% responsible for what those responses are. It controls what happens to the resources and data and how to send them to the Client. We'll look at the most basic website server configuration.
So a server is a machine that is connected to the Internet. It has its IP Address. The reason why your machine has an IP Address but no one on the Internet can access files in your machine is because you don't have a web server software running on your machine.
When you have a web server software running on your machine, it will listen to requests, and it has access to specific files and folders on your machine. You can configure different hosts to different folders.
Let's take an example of our very own dummy site. Suppose my web server and file system are configured in the following way:
If I request for
www.dummysite.com, without any path, the Server will respond with the
index.html file, with Content-Type:
Likewise, if I give it a path, like
www.dummysite.com/login.php, it will look through my file system and check whether it exists. Hmm.. let's see if a login.php file exists. Oh, it does! Let's send that back as a response and since its a PHP file, it is smart enough to send the response with Content-Type:
application/x-httpd-php. Similar for the style.css file.
Let's see how Google does it.
authority = host + port number
The Host is either domain name or IP Address, and the port number for HTTP is
As you can see in the image, the
authority is said to be
www.google.com. So when it gets the request for the same, your webserver goes like, "ah... google.com? Let's look inside the specified folder in the filesystem." So a basic web server will give you the file you request. That's it, not very smart stuff.
So the key job for the Server is, it forms a Uniform Resource Locator that consists of:
- Protocol (HTTP, HTTPS)
- Domain Name (www.dummysite.com)
- Port Number (80, for HTTP, and it is not visible to us)
- Path to the File (/styles/style.css)
And together it becomes
By using this URL, you are actually navigating through the server's files, and your browser knows what to do with those files and you can view and interact with the website.
So that's the job for a server, which interacts with the backend code. It works for most websites that can be built and run smoothly and without any hassle.
But surely, websites like Facebook, Twitter doesn't do this! They have to manage users and posts and likes and comments, all that stuff. They're not responding with just a .png file. So how does a complex website handle all these things?
We will look into that in the upcoming post!
I hope that I could make this jargon easier for you :)
Till then, signing off!
Top comments (19)
I would like to suggest a bit simpler definition though:
Front is everything that's visible, like a shopwindow in front of the store.
Back is everything that's behind it, like a storage room in the back of the store.
And there's also the hardware part: one or several computers that serve the clients, like a store worker, each doing it's own part.
Servers and clients communicate in a very strict manner, following a protocol.
Thank you and good luck!
That is a simpler way to put it up! Thank you Valerie. 🖤
Great article! As a frontend developer myself, I think it's a great read for frontend developers as well. 😁
Thank you! 💫
I look forward to hearing more 😀
I like how you explained it. Truly beginner-ish
How did you design the header image for your post? It's very beautiful.
I designed this header on Canva :)
Great article! Thanks.
Very well written! Looking forward to the next post, thanks.
Thank you Dominic!
Thanks so much!
@anonyda thanks for the insightful article. @abelardusbm
My pleasure 😊