Published on April 10, 2011 by Toran Billups
In part 1 of the series I demonstrated how you might construct a simple http GET request. But in any real application the user will typically need to act on something pulled down during the GET request and this is where the http POST comes in. With the POST verb we can send data along with the request and most websites will require some form of communication to happen using the POST verb exclusively.
Lucky for us it's not much different than creating a GET request. For this example I will be working to emulate a simple form POST found on my redblueflix webpage that sends an email. The elements in html look something like the below.
We can see the url that we need to use for the post along with the name and suggestion input values. I will be using the same project from our previous example so if you plan to follow along be sure to get the source code from github.
The first step is to create the url and request as we did with the http GET. Also we need to set the method as 'POST' instead of 'GET' this time.
This would work just fine except that it doesn't have any of the required form data. The simplest thing that works here is to build a string with the values we want to send and add this string to the POST. We can then turn this string into NSData so it can be sent over with the request.
Next we need to add this NSData to the request by setting the body. In addition we will set a few other values like the accept header, content-type and length.
Now if we put this all together we end up with the following code to build and fire off our first http POST.
The current implementation will fire off an http POST with that form data as if we had clicked the submit button on an html page.