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语言的网络编程模型,并掌握构建高效、可靠网络应用的技能。

目录
相关文章
|
8天前
|
存储 Go 索引
go语言使用for循环遍历
go语言使用for循环遍历
22 7
|
11天前
|
存储 Go
go语言 遍历映射(map)
go语言 遍历映射(map)
22 2
|
12天前
|
Go 调度 开发者
Go语言中的并发编程:深入理解goroutines和channels####
本文旨在探讨Go语言中并发编程的核心概念——goroutines和channels。通过分析它们的工作原理、使用场景以及最佳实践,帮助开发者更好地理解和运用这两种强大的工具来构建高效、可扩展的应用程序。文章还将涵盖一些常见的陷阱和解决方案,以确保在实际应用中能够避免潜在的问题。 ####
|
12天前
|
测试技术 Go 索引
go语言使用 range 关键字遍历
go语言使用 range 关键字遍历
17 3
|
12天前
|
测试技术 Go 索引
go语言通过 for 循环遍历
go语言通过 for 循环遍历
21 3
|
14天前
|
安全 Go 数据处理
Go语言中的并发编程:掌握goroutine和channel的艺术####
本文深入探讨了Go语言在并发编程领域的核心概念——goroutine与channel。不同于传统的单线程执行模式,Go通过轻量级的goroutine实现了高效的并发处理,而channel作为goroutines之间通信的桥梁,确保了数据传递的安全性与高效性。文章首先简述了goroutine的基本特性及其创建方法,随后详细解析了channel的类型、操作以及它们如何协同工作以构建健壮的并发应用。此外,还介绍了select语句在多路复用中的应用,以及如何利用WaitGroup等待一组goroutine完成。最后,通过一个实际案例展示了如何在Go中设计并实现一个简单的并发程序,旨在帮助读者理解并掌
|
13天前
|
Go 索引
go语言按字符(Rune)遍历
go语言按字符(Rune)遍历
23 3
|
4天前
|
存储 SQL 安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将介绍网络安全的重要性,分析常见的网络安全漏洞及其危害,探讨加密技术在保障网络安全中的作用,并强调提高安全意识的必要性。通过本文的学习,读者将了解网络安全的基本概念和应对策略,提升个人和组织的网络安全防护能力。
|
5天前
|
SQL 安全 网络安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
随着互联网的普及,网络安全问题日益突出。本文将从网络安全漏洞、加密技术和安全意识三个方面进行探讨,旨在提高读者对网络安全的认识和防范能力。通过分析常见的网络安全漏洞,介绍加密技术的基本原理和应用,以及强调安全意识的重要性,帮助读者更好地保护自己的网络信息安全。
22 10
|
6天前
|
SQL 安全 网络安全
网络安全与信息安全:关于网络安全漏洞、加密技术、安全意识等方面的知识分享
在数字化时代,网络安全和信息安全已成为我们生活中不可或缺的一部分。本文将介绍网络安全漏洞、加密技术和安全意识等方面的内容,并提供一些实用的代码示例。通过阅读本文,您将了解到如何保护自己的网络安全,以及如何提高自己的信息安全意识。
31 10