server.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. package main
  2. import (
  3. "database/sql"
  4. "fmt"
  5. _ "github.com/go-sql-driver/mysql"
  6. psh "github.com/platformsh/gohelper"
  7. "html"
  8. "log"
  9. "net/http"
  10. )
  11. func main() {
  12. // The psh library provides Platform.sh environment information mapped to Go structs.
  13. p, err := psh.NewPlatformInfo()
  14. if err != nil {
  15. // This means we're not running on Platform.sh!
  16. // In practice you would want to fall back to another way to define
  17. // configuration information, say for your local development environment.
  18. fmt.Println(err)
  19. panic("Not in a Platform.sh Environment.")
  20. }
  21. fmt.Println("Yay, found Platform.sh info")
  22. // Set up an extremely simple web server response.
  23. http.HandleFunc("/bar", func(w http.ResponseWriter, r *http.Request) {
  24. // Run some background SQL, just to prove we can.
  25. trySql(p, w)
  26. // And say hello, per tradition.
  27. fmt.Fprintf(w, "Hello, %q", html.EscapeString(r.URL.Path))
  28. })
  29. // The port to listen on is defined by Platform.sh.
  30. log.Fatal(http.ListenAndServe(":"+p.Port, nil))
  31. }
  32. // trySql simply connects to a MySQL server defined by Platform.sh and
  33. // writes and reads from it. This is not particularly useful code,
  34. // but demonstrates how you can leverage the Platform.sh library.
  35. func trySql(pi *psh.PlatformInfo, w http.ResponseWriter) {
  36. dbString, err := pi.SqlDsn("mysql")
  37. checkErr(err)
  38. db, err := sql.Open("mysql", dbString)
  39. checkErr(err)
  40. // Force MySQL into modern mode.
  41. db.Exec("SET NAMES=utf8")
  42. db.Exec("SET sql_mode = 'ANSI,STRICT_TRANS_TABLES,STRICT_ALL_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,ONLY_FULL_GROUP_BY'")
  43. _, err = db.Exec("DROP TABLE IF EXISTS userinfo")
  44. checkErr(err)
  45. _, err = db.Exec(`CREATE TABLE userinfo (
  46. uid INT(10) NOT NULL AUTO_INCREMENT,
  47. username VARCHAR(64) NULL DEFAULT NULL,
  48. departname VARCHAR(128) NULL DEFAULT NULL,
  49. created DATE NULL DEFAULT NULL,
  50. PRIMARY KEY (uid)
  51. ) DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;`)
  52. checkErr(err)
  53. // insert
  54. stmt, err := db.Prepare("INSERT userinfo SET username=?,departname=?,created=?")
  55. checkErr(err)
  56. res, err := stmt.Exec("astaxie", "研发部门", "2012-12-09")
  57. checkErr(err)
  58. id, err := res.LastInsertId()
  59. checkErr(err)
  60. fmt.Println(id)
  61. // update
  62. stmt, err = db.Prepare("update userinfo set username=? where uid=?")
  63. checkErr(err)
  64. res, err = stmt.Exec("astaxieupdate", id)
  65. checkErr(err)
  66. affect, err := res.RowsAffected()
  67. checkErr(err)
  68. fmt.Println(affect)
  69. // query
  70. rows, err := db.Query("SELECT * FROM userinfo")
  71. checkErr(err)
  72. for rows.Next() {
  73. var uid int
  74. var username string
  75. var department string
  76. var created string
  77. err = rows.Scan(&uid, &username, &department, &created)
  78. checkErr(err)
  79. fmt.Fprintln(w, uid)
  80. fmt.Fprintln(w, username)
  81. fmt.Printf(username)
  82. fmt.Fprintln(w, department)
  83. fmt.Fprintln(w, created)
  84. }
  85. // delete
  86. stmt, err = db.Prepare("delete from userinfo where uid=?")
  87. checkErr(err)
  88. res, err = stmt.Exec(id)
  89. checkErr(err)
  90. affect, err = res.RowsAffected()
  91. checkErr(err)
  92. fmt.Fprintln(w, affect)
  93. db.Close()
  94. }
  95. // checkErr is a simple wrapper for panicking on error.
  96. // It likely should not be used in a real application.
  97. func checkErr(err error) {
  98. if err != nil {
  99. panic(err)
  100. }
  101. }