Introduction
Welcome to Building Web Apps with Go! If you are reading this then you have just started your journey from noob to pro. No seriously, web programming in Go is so fun and easy that you won't even notice how much information you are learning along the way!
Keep in mind that there are still portions of this book that are incomplete and need some love. The beauty of open source publishing is that I can give you an incomplete book and it is still of value to you.
Before we get into all the nitty gritty details, let's start with some ground rules:
Prerequisites
To keep this tutorial small and focused, I'm assuming that you are prepared in the following ways:
- You have installed the Go Programming Language.
- You have setup a
GOPATH
by following the How to Write Go Code tutorial. - You are somewhat familiar with the basics of Go. (The Go Tour is a pretty good place to start)
- You have installed all the required packages
- You have installed the Heroku Toolbelt
- You have a Heroku account
Required Packages
For the most part we will be using the built in packages from the standard library to build out our web apps. Certain lessons such as Databases, Middleware and URL Routing will require a third party package. Here is a list of all the go packages you will need to install before starting:
Name | Import Path | Description |
---|---|---|
httprouter | github.com/julienschmidt/httprouter | A high performance HTTP request router that scales well |
Negroni | github.com/codegangsta/negroni | Idiomatic HTTP Middleware |
Black Friday | github.com/russross/blackfriday | a markdown processor |
Render | gopkg.in/unrolled/render.v1 | Easy rendering for JSON, XML, and HTML |
SQLite3 | github.com/mattn/go-sqlite3 | sqlite3 driver for go |
You can install (or update) these packages by running the following command in your console
go get -u <import_path>
For instance, if you wish to install Negroni, the following command would be:
go get -u github.com/codegangsta/negroni