lcyblm (go, doesn't expire)
package main

import ( 
	"time"
	"fmt"
	"html/template"
	"net/http"
	"database/sql"
    _"github.com/go-sql-driver/mysql"
)
type Page struct {
    Title string
    Body  []byte
    Timestamp time.Time
}
func (p *Page) save() error {
	_, err := stmtIns.Exec(p.Title, p.Body)
    return err // ioutil.WriteFile(filename, p.Body, 0600)
}
func loadPage(ident string) (*Page, error) {
	s := Page{}
    err := stmtOut.QueryRow(ident).Scan(&s.Title, &s.Body, &s.Timestamp)
    if err != nil {
        return nil, err
    }
    return &s, nil
}

func viewHandler(w http.ResponseWriter, r *http.Request) {
    title := r.URL.Path[len("/view/"):]
    if len(title) < 1 {
		http.Redirect(w, r, "/", http.StatusFound)
		return
	}
    p, err := loadPage(title)
    if err != nil {
		http.NotFoundHandler()
	} else {
		renderTemplate(w, "view", p)
	}
}
func editHandler(w http.ResponseWriter, r *http.Request) {
    title := r.URL.Path[len("/edit/"):]
    p, err := loadPage(title)
    if err != nil {
        p = &Page{Title: title}
    }
	renderTemplate(w, "edit", p)
}
func saveHandler(w http.ResponseWriter, r *http.Request) {
    //title := r.URL.Path[len("/save/"):]
    //if len(title) < 1 {
	//	http.Redirect(w, r, "/", http.StatusFound)
	//	return
	//}
	title:= r.FormValue("appname")
    body := r.FormValue("body")
    p := &Page{Title: title, Body: []byte(body)}
    p.save()
    http.Redirect(w, r, "/view/"+title, http.StatusFound)
}
func errorHandler(w http.ResponseWriter, r *http.Request, status int) {
    w.WriteHeader(status)
    if status == http.StatusNotFound {
        fmt.Fprint(w, "file was not found on server")
    }
}
var templates = template.Must(template.ParseFiles("edit.html", "view.html"))

func renderTemplate(w http.ResponseWriter, tmpl string, p *Page) {
    err := templates.ExecuteTemplate(w, tmpl+".html", p)
    if err != nil {
        http.Error(w, err.Error(), http.StatusInternalServerError)
    }
}

// var db *sql.DB
var stmtIns, stmtOut *sql.Stmt

func main() {
	db, err := sql.Open("mysql", "root:feelssemibadman@/golang")
    if err != nil {
        fmt.Printf("failed to open mysql handle\n")
    }
    defer db.Close()
    err = db.Ping()
    if err != nil {
        fmt.Printf("opened handle but failed to communicate with mysql\n")
    }
    // Prepare statement for inserting data
    stmtIns, err := db.Prepare("INSERT Applications SET AppName=?, Description=?")
    if err != nil {
        fmt.Printf(err.Error())
    }
    defer stmtIns.Close() // Close the statement when we leave main() / the program terminates
 
    // Prepare statement for reading data
    stmtOut, err := db.Query("SELECT AppName, Description, CreatedOn FROM Applications WHERE AppID=?")
    if err != nil {
        fmt.Printf(err.Error())
    }
    defer stmtOut.Close()
    http.HandleFunc("/view/", viewHandler)
    http.HandleFunc("/edit/", editHandler)
    http.HandleFunc("/save/", saveHandler)
    http.ListenAndServe(":8080", nil)
}