登录
首页 >  Golang >  Go教程

Golang实现留言板教程详解

时间:2025-12-18 10:37:33 167浏览 收藏

推广推荐
免费电影APP ➜
支持 PC / 移动端,安全直达

小伙伴们有没有觉得学习Golang很有意思?有意思就对了!今天就给大家带来《Golang实现留言板功能教程》,以下内容将会涉及到,若是在学习中对其中部分知识点有疑问,或许看了本文就能帮到你!

答案:使用Golang标准库可快速实现留言板,定义Message结构体存储用户、内容和时间,通过net/http处理HTTP请求,支持POST提交留言和GET获取留言列表,结合内存切片模拟数据存储,并内嵌HTML页面实现前端交互,完成基础增查功能。

如何在Golang中实现留言板功能

在Golang中实现留言板功能,核心是处理用户提交的留言数据、存储并展示出来。整个流程可以通过标准库快速搭建,不需要引入复杂的框架。下面是一个简单但完整的实现思路和代码示例。

1. 定义留言数据结构

每条留言通常包含用户名、内容和时间。可以用一个结构体来表示:

type Message struct {
    ID      int       `json:"id"`
    User    string    `json:"user"`
    Content string    `json:"content"`
    Time    time.Time `json:"time"`
}

使用切片或map模拟存储,实际项目可替换为数据库(如SQLite、MySQL)。

2. 设置HTTP路由与处理函数

使用net/http包注册路由,处理获取留言和提交留言的请求。

func main() {
    messages := &[]Message{} // 模拟存储
    http.HandleFunc("/messages", func(w http.ResponseWriter, r *http.Request) {
        switch r.Method {
        case "GET":
            getMessages(w, *messages)
        case "POST":
            addMessage(w, r, messages)
        default:
            http.Error(w, "不支持的请求方法", http.StatusMethodNotAllowed)
        }
    })

    fmt.Println("服务启动在 :8080")
    http.ListenAndServe(":8080", nil)
}

3. 实现留言的增和查

添加留言时解析表单数据,生成新消息并追加到列表;获取时返回JSON格式数据。

func getMessages(w http.ResponseWriter, messages []Message) {
    w.Header().Set("Content-Type", "application/json")
    json.NewEncoder(w).Encode(messages)
}

func addMessage(w http.ResponseWriter, r *http.Request, messages *[]Message) {
    if err := r.ParseForm(); err != nil {
        http.Error(w, "解析表单失败", http.StatusBadRequest)
        return
    }

    user := r.FormValue("user")
    content := r.FormValue("content")

    if user == "" || content == "" {
        http.Error(w, "用户名和内容不能为空", http.StatusBadRequest)
        return
    }

    msg := Message{
        ID:      len(*messages) + 1,
        User:    user,
        Content: content,
        Time:    time.Now(),
    }
    *messages = append(*messages, msg)

    w.WriteHeader(http.StatusCreated)
    json.NewEncoder(w).Encode(msg)
}

4. 前端页面简单集成

可以内嵌HTML模板或静态文件,提供输入表单和展示区域。

func servePage(w http.ResponseWriter, r *http.Request) {
    html := `
<html>
<body>
  <h2>留言板</h2>
  <form onsubmit="addMessage(event)">
    用户名: &lt;input type=&quot;text&quot; id=&quot;user&quot; required&gt;<br>
    留言: &lt;textarea id=&quot;content&quot; required&gt;&lt;/textarea&gt;<br>
    <button type="submit">提交</button>
  </form>
  <div id="list"></div>

  <script>
    function loadMessages() {
      fetch('/messages').then(r => r.json()).then(data => {
        document.getElementById('list').innerHTML = data.map(m =>
          '<p><b>'+m.user+'</b> ('+new Date(m.time).toLocaleString()+'): '+m.content+'</p>'
        ).join('');
      });
    }
    function addMessage(e) {
      e.preventDefault();
      const user = document.getElementById('user').value;
      const content = document.getElementById('content').value;
      fetch('/messages', {
        method: 'POST',
        headers: {'Content-Type': 'application/x-www-form-urlencoded'},
        body: 'user='+encodeURIComponent(user)+'&content='+encodeURIComponent(content)
      }).then(() => {
        document.getElementById('user').value = '';
        document.getElementById('content').value = '';
        loadMessages();
      });
    }
    loadMessages();
  </script>
</body>
</html>
`
    w.Write([]byte(html))
}

将这个页面通过根路径返回即可形成完整交互。

基本上就这些。用Golang标准库就能快速做出一个可用的留言板,适合学习或小型项目。后续可扩展数据库、分页、删除功能等。不复杂但容易忽略细节,比如表单验证和时间处理。

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Golang实现留言板教程详解》文章吧,也可关注golang学习网公众号了解相关技术文章。

相关阅读
更多>
最新阅读
更多>
课程推荐
更多>