26.3. POST Form Submission¶
26.3.1. Form Submission Using POST¶
Instead of using GET and query parameters to submit form data, we can use POST.
To submit a form using a POST request, set the form’s method
attribute to "POST"
.
Form data submitted via POST will be submitted in the body of the HTTP request.
Data submitted by GET requests is less secure than POST because GET request URLs
and the query parameters are cached and logged, possibly leaking sensitive data.
Example
Form with method="POST"
<form action="" method="POST">
<label>Username <input type="text" name="username"></label>
<label>Team Name <input type="text" name="team"></label>
<button>Submit</button>
</form>
26.3.2. Send Form Submission to a Server¶
The action
and method
attributes allow us to choose where the form request will be
sent and what type of request will be sent. How do we configure what happens in response to
a form submission?
Form handlers are web server actions that receive, inspect, and process requests. They then send a response to the client. For this unit we are going to use form handlers that have already been created for us.
Example
When submitted, this form will send a POST request to the form handler defined by the
action
attribute.
1 2 3 4 5 | <form action="https://handlers.education.launchcode.org/request-parrot" method="POST">
<label>Username <input type="text" name="username"></label>
<label>Team Name <input type="text" name="team"></label>
<button>Submit</button>
</form>
|
Try It!
Open an example form that uses POST in a browser.
Open the network tab of the developer tools
Check “Persist Logs” in the network tab. (“Preserve Logs” in Chrome or Safari)
Enter data into the inputs
Type
tracking
into Username inputType
Requests
into Team Name input
Click Submit button
Inspect the data sent in the POST request
Warning
Using POST for form submissions adds a very low level of security. Using HTTPS instead of HTTP adds a higher level of security. Configuring HTTPS is beyond the scope of this class.
26.3.3. Check Your Understanding¶
Question
What attribute on <form>
determines if the form is submitted with GET or POST?
Question
What attribute on <form>
determines where the request is sent?