Go语言实现服务端消息接收和发送

本文实例为大家分享了Go实现服务端消息接收和发送的具体代码,供大家参考,具体内容如下

一. 服务端接收数据并返回数据

服务端代码

package main

import (
   "net"
   "fmt"
)

func main() {
   //创建TCPAddress变量,指定协议tcp4,监听本机8899端口
   addr, _ := net.ResolveTCPAddr("tcp4", "localhost:8899")

   //监听TCPAddress设定的地址
   lis, _ := net.ListenTCP("tcp4", addr)

   fmt.Println("服务器已启动")

   //阻塞式等待客户端消息,返回连接对象,用于接收客户端消息或向客户端发送消息
   conn, _ := lis.Accept()

   //把数据读取到切片中
   b := make([]byte, 256)
   fmt.Println("read之前")
   //客户端没有发送数据且客户端对象没有关闭,Read()将会阻塞,一旦接收到数据就不阻塞
   count, _ := conn.Read(b)
   fmt.Println("接收到的数据:", string(b[:count]))

   /*
   向客户端发送数据
    */
   conn.Write([]byte("这是服务器传递的数据"))

   //关闭连接
   conn.Close()
   fmt.Println("服务器结束")
}

客户端代码

package main

import (
   "net"
   "fmt"
)

func main() {
   //服务器端ip和端口
   addr, _ := net.ResolveTCPAddr("tcp4", "localhost:8899")
   //申请连接客户端
   conn, _ := net.DialTCP("tcp4", nil, addr)
   //向服务端发送数据
   count, _ := conn.Write([]byte("客户端传递的数据"))
   fmt.Println("客户端向服务端发送的数据量为:", count)

   /*
   接收服务器传递回来的数据
    */
   b := make([]byte, 256)
   c, _ := conn.Read(b)
   fmt.Println(string(b[:c]))

   关闭连接
   conn.Close()
   fmt.Println("客户端结束")

}

可以在服务端添加循环,不停接收客户端发送来的数据,服务端代码修改如下

package main

import (
   "net"
   "fmt"
)

func main() {
   addr, _ := net.ResolveTCPAddr("tcp4", "localhost:8899")
   lis, _ := net.ListenTCP("tcp4", addr)
   fmt.Println("服务器已启动")

   /*
   服务器端添加死循环,不停的接收客户端对象
    */
   for {
      conn, _ := lis.Accept()
      b := make([]byte, 256)
      count, _ := conn.Read(b)
      nc := string(b[:count])
      fmt.Println("接收到的数据:", nc)
      conn.Write([]byte("服务器:" + nc))
      conn.Close()
   }
   fmt.Println("服务器结束")
}

客户端代码修改如下

package main

import (
   "net"
   "fmt"
   "strconv"
)

func main() {
   //服务器端ip和端口
   addr, _ := net.ResolveTCPAddr("tcp4", "localhost:8899")

   //通过循环,模拟发送五次客户端请求
   for i := 1; i <= 5; i++ {
      conn, _ := net.DialTCP("tcp4", nil, addr)
      conn.Write([]byte("客户端数据" + strconv.Itoa(i)))
      b := make([]byte, 256)
      c, _ := conn.Read(b)
      fmt.Println("第", i, "次服务器返回的数据:", string(b[:c]))
      conn.Close()
   }

   fmt.Println("客户端结束")

}

三.并发访问

上面代码的问题是服务器获取到客户端对象后,如果客户端什么也没有输入,其他客户端无法连接.可以通过结合goroutine完成并发访问
只需要修改server.go,在里面添加goroutine

package main

import (
   "net"
   "fmt"
)

func main() {
   addr, _ := net.ResolveTCPAddr("tcp4", "localhost:8899")
   lis, _ := net.ListenTCP("tcp4", addr)
   fmt.Println("服务器已启动")

   /*
   服务器端添加死循环,不停的接收客户端对象
    */
   for {
      conn, _ := lis.Accept()
      go func() { //在此处添加创建go func()即可
         b := make([]byte, 256)
         count, _ := conn.Read(b)
         nc := string(b[:count])
         fmt.Println("接收到的数据:", nc)
         conn.Write([]byte("服务器:" + nc))
         conn.Close()
      }()
   }
   fmt.Println("服务器结束")
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Golang两行代码实现发送钉钉机器人消息

    废话不多说, 先看代码 创建一个钉钉机器人, 必须使用加签方式 1. 安装 ding 模块包 go get -u github.com/wanghuiyt/ding 2. 普通群消息使用 使用你自己生成的AccessToken和Secret d := ding.Webhook{AccessToken: "8c03f...", Secret: "SECef..."} _ = d.SendMessage("这是普通的群消息") 效果: 详细教程 创建

  • Django 实现 Websocket 广播、点对点发送消息的代码

    1.Django实现Websocket 使用Django来实现Websocket服务的方法很多在这里我们推荐技术最新的Channels库来实现 1.1.安装DjangoChannels Channels安装如果你是Windows操作系统的话,那么必要条件就是Python3.7 pip install channels 1.2.配置DjangoChannels 1.创建项目ChannelsReady django-admin startprobject ChannelsReady 2.在项目的se

  • Django后端发送小程序微信模板消息示例(服务通知)

    模板消息 官方文档:https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/template-message/templateMessage.send.html 模板消息如下图所示 Django中获取access_token 根据文档描述,获取access_token文档,后端必须获取一个access_token才能够发送模板消息,文档中说明该token有效期为两小时,需要后端定时去获取.我们这里使用Django

  • Go语言实现服务端消息接收和发送

    本文实例为大家分享了Go实现服务端消息接收和发送的具体代码,供大家参考,具体内容如下 一. 服务端接收数据并返回数据 服务端代码 package main import (    "net"    "fmt" ) func main() {    //创建TCPAddress变量,指定协议tcp4,监听本机8899端口    addr, _ := net.ResolveTCPAddr("tcp4", "localhost:8899&qu

  • Android 服务端将位置信息发送给客户端的实现

    一.问题 Android 服务端将位置信息发送给客户端 二.环境 AndroidStudio Eclipse 三.代码实现 服务端Servlet调用Dao层在数据库中查找数据,在servlet中将查找到的数据汇集成json字符串(json数组形式). 服务端: public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // r

  • java读取用户登入退出日志信息上传服务端

    本文实例为大家分享了读取用户登入出日志并上传服务端的具体实现代码,供大家参考,具体内容如下 该客户端运行在给用户提供unix服务的服务器上.用来读取并收集该服务器上用户的上下线信息,并进行配对整理后发送给服务端汇总. 具体实现代码: 1. DMSServer.java package com.dms; import java.io.BufferedReader; import java.io.File; import java.io.FileOutputStream; import java.i

  • java Nio使用NioSocket客户端与服务端交互实现方式

    NioSocket 客户端与服务端交互实现 java Nio是jdk1.4新增的io方式-–nio(new IO),这种方式在目前来说算不算new,更合适的解释应该是non-block IO. non-block是相对于传统的io方式来讲的.传统的Io方式是阻塞的,我们拿网络io来举例,传统的io模型如下: 服务端主线程负责不断地server.accept(),如果没有客户端请求主线程就会阻塞,当客户端请求时,主线程会通过线程池创建一个新的线程执行. 简单解释就是一个线程负责一个客户端的sock

  • Go gRPC服务端流式RPC教程示例

    目录 前言 情景模拟:实时获取股票走势 新建proto文件 创建Server端 创建Client端 思考 总结 前言 上一篇介绍了简单模式RPC,当数据量大或者需要不断传输数据时候,我们应该使用流式RPC,它允许我们边处理边传输数据.本篇先介绍服务端流式RPC. 服务端流式RPC:客户端发送请求到服务器,拿到一个流去读取返回的消息序列. 客户端读取返回的流,直到里面没有任何消息. 情景模拟:实时获取股票走势 1.客户端要获取某原油股的实时走势,客户端发送一个请求 2.服务端实时返回该股票的走势

  • 详解Angular5 服务端渲染实战

    本文基于上一篇 Angular5 的文章继续进行开发,上文中讲了搭建 Angular5 有道翻译的过程,以及遇到问题的解决方案. 随后改了 UI,从 bootstrap4 改到 angular material,这里不详细讲,服务端渲染也与修改 UI 无关. 看过之前文章的人会发现,文章内容都偏向于服务端渲染,vue 的 nuxt,react 的 next. 在本次改版前也尝试去找类似 nuxt.js 与 next.js 的顶级封装库,可以大大节省时间,但是未果. 最后决定使用从 Angular

  • python网络编程socket实现服务端、客户端操作详解

    本文实例讲述了python网络编程socket实现服务端.客户端操作.分享给大家供大家参考,具体如下: 本文内容: socket介绍 TCP: 服务端 客户端 UDP: 服务端 客户端 首发时间:2018-02-08 01:14 修改: 2018-03-20 :重置了布局,增加了UDP 什么是socket: socket又称"套接字",应用程序通常通过"套接字"向网络发出请求或者应答网络请求. 网络上的两个程序通过一个双向的通信连接实现数据的交换,这个连接的一端称为

  • UDP简单服务端客户端代码示例

    UDP的理论不再多说,我这里直接给出一个关于UDP的HelloWorld程序,代码明了,希望对刚入门的学生有所帮助! 当然,实际上,在这块我也刚入门! 首先写服务端代码,服务端邦定本地的IP和端口来监听访问: package udp; import java.io.IOException; import java.net.DatagramPacket; import java.net.DatagramSocket; import java.net.InetSocketAddress; /** *

  • Socket结合线程池使用实现客户端和服务端通信demo

    目录 引导语 1.要求 2.客户端代码 3.服务端代码 3.1.对客户端请求进行控制 3.2.服务端任务的处理逻辑 4.测试 5.总结 引导语 Socket 面试最终题一般都是让你写一个简单的客户端和服务端通信的例子,本文就带大家一起来写这个 demo. 1.要求 可以使用 Socket 和 ServiceSocket 以及其它 API: 写一个客户端和服务端之间 TCP 通信的例子: 服务端处理任务需要异步处理: 因为服务端处理能力很弱,只能同时处理 5 个请求,当第六个请求到达服务器时,需要

  • python利用socket实现客户端和服务端之间进行通信

    目录 一.socket socket通信的条件:IP和端口 形象比喻 二.客户端实现过程 三.服务器实现过程 四.演示 五.实现持续通信过程 前言: 今天教大家通过Python进行Socket网络编程(做一个聊天程序),可以实现在不同的主机(电脑)之间进行通话. 具体效果如何,接着往下看: 可以看到客户端(上方)向服务器端(下方)发送了内容,服务器端进行了回复 [备注:客户端是我的本机,服务器是另一条主机(阿里云服务器)] 两台主机的目的:验证两台主机可以相互通信 一.socket 先简单给大家

随机推荐