Go语言实现简单留言板的方法

2020-01-28 11:12:11王旭

本文实例讲述了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)
        }