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) }