HTML Form Action: POST and GET

The method attribute in the <form> element specifies how the data is sent to the server.

HTTP methods declare what action is to be performed on the data that is submitted to the server. HTTP Protocol provides several methods, and the HTML Form element is able to use two methods to send user data:

  • GET method - used to request data from a specified resource
  • POST method - used to send data to a server to update a resource

The GET Method

The HTML GET method is used to get a resource from the server. For example,

<form method="get" action="www.codemy.com/search">
    <input type="search" name="location" placeholder="Search.." />
    <input type="submit" value="Go" />
</form>

When we submit the above form by entering California in the input field, the request sent to the server will be www.codemy.com/search/?location=California.

The HTTP GET method adds a query string at the end of the URL to send data to the server. The query string is in the form of key-value pair followed by ? symbol.

From the URL, the server can parse the user-submitted value where:

  • key - location
  • value - California

Note: If there is more than one query, the query string will be separated by a & symbol.


The POST method

The HTTP POST method is used to send data to the server for further processing. For example,

<form method="post" action="www.codemy.com/user">
    <label for="firstname">First name:</label>
    <input type="text" name="firstname" /><br />
    <label for="lastname">Last name:</label>
    <input type="text" name="lastname" /><br />
    <input type="submit" />
</form>

When we submit the form, it will add the user input data to the body of the request sent to the server. The request would look like

POST /user HTTP/2.0
Host: www.codemy.com
Content-Type: application/x-www-form-urlencoded
Content-Length: 33

firstname=Robin&lastname=Williams

The data sent is not easily visible to the user. However, we can check the sent data using special tools like the browsers' dev tools.


GET vs POST

GET POST
Data sent with the GET method is visible in the URL. Data sent with the POST method is not visible.
GET requests can be bookmarked. POST requests can't be bookmarked.
GET requests can be cached. POST requests can't be cached.
GET requests have a character limit of 2048 characters. POST requests do not have a limit.
Only ASCII characters are allowed in GET requests. All data is allowed in POST request