Go语言网络编程的实例

简介: 【10月更文挑战第27天】Go语言网络编程的实例

以下是一些Go语言网络编程的实例:

  1. TCP服务器

    • 代码示例

      package main
      
      import (
          "fmt"
          "io"
          "net"
      )
      
      func handleConnection(conn net.Conn) {
             
          defer conn.Close()
          for {
             
              buf := make([]byte, 1024)
              n, err := conn.Read(buf)
              if err != nil {
             
                  return
              }
              fmt.Printf("Received: %s", string(buf[:n]))
              conn.Write([]byte("Message received."))
          }
      }
      
      func main() {
             
          listener, err := net.Listen("tcp", "localhost:8080")
          if err != nil {
             
              fmt.Println("Error listening:", err)
              return
          }
          defer listener.Close()
          for {
             
              conn, err := listener.Accept()
              if err != nil {
             
                  continue
              }
              go handleConnection(conn)
          }
      }
      
    • 说明:这个示例创建了一个TCP服务器,监听localhost:8080端口。每当有新的客户端连接时,它都会启动一个新的goroutine来处理该连接。服务器读取客户端发送的数据,并将其打印到控制台,然后向客户端发送确认消息[^1^]。
  2. TCP客户端

    • 代码示例

      package main
      
      import (
          "fmt"
          "net"
      )
      
      func main() {
             
          conn, err := net.Dial("tcp", "localhost:8080")
          if err != nil {
             
              fmt.Println("Error dialing:", err)
              return
          }
          defer conn.Close()
          conn.Write([]byte("Hello, server!"))
          buf := make([]byte, 1024)
          n, err := conn.Read(buf)
          if err != nil {
             
              fmt.Println("Error reading:", err)
              return
          }
          fmt.Printf("Received: %s", string(buf[:n]))
      }
      
    • 说明:这个示例是一个TCP客户端,它连接到上面提到的TCP服务器,并发送一条消息。然后,它等待服务器的响应,并将其打印到控制台[^1^]。
  3. HTTP服务器

    • 代码示例

      package main
      
      import (
          "fmt"
          "net/http"
      )
      
      func helloHandler(w http.ResponseWriter, r *http.Request) {
             
          fmt.Fprintf(w, "Hello, World!")
      }
      
      func main() {
             
          http.HandleFunc("/", helloHandler)
          http.ListenAndServe(":8080", nil)
      }
      
    • 说明:这个示例创建了一个简单的HTTP服务器,监听localhost:8080端口。当HTTP请求到达服务器时,它会调用helloHandler函数来处理请求,并向客户端发送“Hello, World!”作为响应[^5^]。
  4. 并发HTTP服务器

    • 代码示例

      package main
      
      import (
          "fmt"
          "log"
          "net/http"
      )
      
      func helloHandler(w http.ResponseWriter, r *http.Request) {
             
          fmt.Fprintf(w, "Hello, %q", r.URL.Path[1:])
      }
      
      func main() {
             
          http.HandleFunc("/", helloHandler)
          log.Fatal(http.ListenAndServe(":8090", nil))
      }
      
    • 说明:这个示例展示了如何创建一个可以处理并发请求的HTTP服务器。它使用了Go语言的并发特性(goroutine),使得每个HTTP请求都在自己的goroutine中处理,从而提高了服务器的性能和响应速度[^5^]。
  5. WebSocket服务器

    • 代码示例

      package main
      
      import (
          "fmt"
          "log"
          "net/http"
          "github.com/gorilla/websocket"
      )
      var upgrader = websocket.Upgrader{
             } // use default options
      
      func echo(w http.ResponseWriter, r *http.Request) {
             
          c, err := upgrader.Upgrade(w, r, nil)
          if err != nil {
             
              log.Print("upgrade:", err)
              return
          }
          defer c.Close()
          for {
             
              mt, message, err := c.ReadMessage()
              if err != nil {
             
                  log.Println("read:", err)
                  break
              }
              log.Printf("recv: %s", message)
              err = c.WriteMessage(mt, message)
              if err != nil {
             
                  log.Println("write:", err)
                  break
              }
          }
      }
      
      func main() {
             
          http.HandleFunc("/echo", echo)
          log.Fatal(http.ListenAndServe("localhost:8080", nil))
      }
      
    • 说明:这个示例使用gorilla/websocket库创建了一个简单的WebSocket服务器。当客户端连接到服务器时,它会将接收到的消息回显给客户端[^1^]。

综上所述,这些实例涵盖了Go语言网络编程中的多种常见场景,包括TCP通信、HTTP服务、并发处理以及WebSocket通信。通过学习和实践这些实例,你可以更好地理解Go语言的网络编程模型,并掌握构建高效、可靠网络应用的技能。

目录
相关文章
|
3月前
|
JSON 中间件 Go
Go 网络编程:HTTP服务与客户端开发
Go 语言的 `net/http` 包功能强大,可快速构建高并发 HTTP 服务。本文从创建简单 HTTP 服务入手,逐步讲解请求与响应对象、URL 参数处理、自定义路由、JSON 接口、静态文件服务、中间件编写及 HTTPS 配置等内容。通过示例代码展示如何使用 `http.HandleFunc`、`http.ServeMux`、`http.Client` 等工具实现常见功能,帮助开发者掌握构建高效 Web 应用的核心技能。
226 61
|
2月前
|
监控 安全 Go
使用Go语言构建网络IP层安全防护
在Go语言中构建网络IP层安全防护是一项需求明确的任务,考虑到高性能、并发和跨平台的优势,Go是构建此类安全系统的合适选择。通过紧密遵循上述步骤并结合最佳实践,可以构建一个强大的网络防护系统,以保障数字环境的安全完整。
75 12
|
7月前
|
运维 监控 算法
监控局域网其他电脑:Go 语言迪杰斯特拉算法的高效应用
在信息化时代,监控局域网成为网络管理与安全防护的关键需求。本文探讨了迪杰斯特拉(Dijkstra)算法在监控局域网中的应用,通过计算最短路径优化数据传输和故障检测。文中提供了使用Go语言实现的代码例程,展示了如何高效地进行网络监控,确保局域网的稳定运行和数据安全。迪杰斯特拉算法能减少传输延迟和带宽消耗,及时发现并处理网络故障,适用于复杂网络环境下的管理和维护。
|
1月前
|
数据采集 Go API
Go语言实战案例:多协程并发下载网页内容
本文是《Go语言100个实战案例 · 网络与并发篇》第6篇,讲解如何使用 Goroutine 和 Channel 实现多协程并发抓取网页内容,提升网络请求效率。通过实战掌握高并发编程技巧,构建爬虫、内容聚合器等工具,涵盖 WaitGroup、超时控制、错误处理等核心知识点。
|
1月前
|
数据采集 JSON Go
Go语言实战案例:实现HTTP客户端请求并解析响应
本文是 Go 网络与并发实战系列的第 2 篇,详细介绍如何使用 Go 构建 HTTP 客户端,涵盖请求发送、响应解析、错误处理、Header 与 Body 提取等流程,并通过实战代码演示如何并发请求多个 URL,适合希望掌握 Go 网络编程基础的开发者。
|
2月前
|
JSON 前端开发 Go
Go语言实战:创建一个简单的 HTTP 服务器
本篇是《Go语言101实战》系列之一,讲解如何使用Go构建基础HTTP服务器。涵盖Go语言并发优势、HTTP服务搭建、路由处理、日志记录及测试方法,助你掌握高性能Web服务开发核心技能。
|
2月前
|
Go
如何在Go语言的HTTP请求中设置使用代理服务器
当使用特定的代理时,在某些情况下可能需要认证信息,认证信息可以在代理URL中提供,格式通常是:
223 0
|
3月前
|
JSON 编解码 API
Go语言网络编程:使用 net/http 构建 RESTful API
本章介绍如何使用 Go 语言的 `net/http` 标准库构建 RESTful API。内容涵盖 RESTful API 的基本概念及规范,包括 GET、POST、PUT 和 DELETE 方法的实现。通过定义用户数据结构和模拟数据库,逐步实现获取用户列表、创建用户、更新用户、删除用户的 HTTP 路由处理函数。同时提供辅助函数用于路径参数解析,并展示如何设置路由器启动服务。最后通过 curl 或 Postman 测试接口功能。章节总结了路由分发、JSON 编解码、方法区分、并发安全管理和路径参数解析等关键点,为更复杂需求推荐第三方框架如 Gin、Echo 和 Chi。
|
3月前
|
运维 网络协议 Go
Go网络编程:基于TCP的网络服务端与客户端
本文介绍了使用 Go 语言的 `net` 包开发 TCP 网络服务的基础与进阶内容。首先简述了 TCP 协议的基本概念和通信流程,接着详细讲解了服务端与客户端的开发步骤,并提供了简单回显服务的示例代码。同时,文章探讨了服务端并发处理连接的方法,以及粘包/拆包、异常检测、超时控制等进阶技巧。最后通过群聊服务端的实战案例巩固知识点,并总结了 TCP 在高可靠性场景中的优势及 Go 并发模型带来的便利性。
|
4月前
|
分布式计算 Go C++
初探Go语言RPC编程手法
总的来说,Go语言的RPC编程是一种强大的工具,让分布式计算变得简单如同本地计算。如果你还没有试过,不妨挑战一下这个新的编程领域,你可能会发现新的世界。
106 10

热门文章

最新文章