本文實例講述了Go語言實現簡單留言板的方法。分享給大家供大家參考。具體實現方法如下:
復制代碼 代碼如下:
package main
import (
// "fmt"
"io"
"log"
"net/http"
"text/template"
"time"
"database/sql"
"github.com/ziutek/mymysql/godrv"
)
// 留言結構
type Liuyan struct {
Id int
Name string
Content string
Time int
}
// 顯示留言時間
func (l Liuyan) ShowTime() string {
t := time.Unix(int64(l.Time), 0)
return t.Format("2006-01-02 15:04:05")
}
func main() {
godrv.Register("SET NAMES utf8")
// 連接數據庫
db, err := sql.Open("mymysql", "tcp:127.0.0.1:3306*go/root/123456")
if err != nil {
panic(err)
}
defer db.Close()
// 準備模板
tpl, err := template.New("liuyanbook").Parse(html)
if err != nil {
panic(err)
}
// 顯示留言頁面 /
requestList := func(w http.ResponseWriter, req *http.Request) {
// 查詢數據
rows, err := db.Query("select * from liuyan")
if err != nil {
log.Fatal(err)
}
defer rows.Close()
// 獲取數據
lys := []Liuyan{}
for rows.Next() {
ly := Liuyan{}
err := rows.Scan(ly.Id, ly.Name, ly.Content, ly.Time)
if nil != err {
log.Fatal(err)
}
lys = append(lys, ly)
}
// 顯示數據
err = tpl.ExecuteTemplate(w, "list", lys)
if err != nil {
log.Fatal(err)
}
}
// 留言頁面 /liuyan
requestLiuyan := func(w http.ResponseWriter, req *http.Request) {
err := req.ParseForm()
if err != nil{
log.Fatal(err)
}
if "POST" == req.Method {
if len(req.Form["name"]) 1 {
io.WriteString(w, "參數錯誤!\n")
return
}
if len(req.Form["content"]) 1 {
io.WriteString(w, "參數錯誤!\n")
return
}
name := template.HTMLEscapeString(req.Form.Get("name"))
content := template.HTMLEscapeString(req.Form.Get("content"))
// sql語句
sql, err := db.Prepare("insert into liuyan(name, content, time) values(?, ?, ?)")
if err != nil {
log.Fatal(err)
}
defer sql.Close()
// sql參數,并執(zhí)行
_, err = sql.Exec(name, content, time.Now().Unix())
if err != nil {
log.Fatal(err)
}
// 跳轉
w.Header().Add("Location", "/")
w.WriteHeader(302)
// 提示信息
io.WriteString(w, "提交成功!\n")
return
}
err = tpl.ExecuteTemplate(w, "liuyan", nil)
if err != nil {
log.Fatal(err)
}
}
http.HandleFunc("/", requestList)
http.HandleFunc("/liuyan", requestLiuyan)
err = http.ListenAndServe(":12345", nil)
if err != nil {
log.Fatal("ListenAndServe: ", err)
}
}
// 網頁模板
var html string = `{{define "list"}}{{/* 留言列表頁面 */}}!DOCTYPE html>
html>
head>
meta http-equiv="Content-Type" content="text/html; charset=utf-8">
/head>
body>
p>a href="/liuyan">給我留言/a>/p>
table>
{{range .}}
tr>
td>{{.Id}}/td>td>{{.Name}}/td>td>{{.Content}}/td>td>{{.ShowTime}}/td>
/tr>
{{end}}
/table>
/body>
/html>{{end}}
{{define "liuyan"}}{{/* 發(fā)布留言頁面 */}}!DOCTYPE html>
html>
head>
meta http-equiv="Content-Type" content="text/html; charset=utf-8">
/head>
body>
form method="post">
姓名:input type="text" name="name" />br>
內容:input type="text" name="content" />br>
input type="submit" value="提交" />
/form>
/body>
/html>{{end}}
希望本文所述對大家的Go語言程序設計有所幫助。
您可能感興趣的文章:- js 實現的可折疊留言板(附源碼下載)
- 本人ajax留言板的源程序 不錯的應用js
- php簡單的留言板與回復功能具體實現
- php開發(fā)留言板的CRUD(增,刪,改,查)操作
- 一個簡單的PHP&MYSQL留言板源碼
- ASP+XML留言板介紹
- 利用XML開發(fā)留言板簡單的例子
- JS+CSS模擬可以無刷新顯示內容的留言板實例