网络编程基础(聊天室)

服务端

package main

import (
"fmt"
"net"
"strings"
"os"
"log"
) // 服务器只是中转! var msgQue = make(chan string, ) // 现在处理一个消息队列
var quitChan = make(chan bool) // 管理退出消息
var onlineConns = make(map[string]net.Conn) // 管理连接
var logfile *os.File
var logger *log.Logger
func ProcessInfo(conn net.Conn) {
buf := make([]byte, )
defer func(conn net.Conn) {
addr := fmt.Sprintf("%s",conn.RemoteAddr())
delete(onlineConns,addr) // 把断开的链接从字典中去掉
conn.Close()
for i := range onlineConns{ // 打印一下
fmt.Println("online"+i)
}
}(conn)
for {
numofbyte, err := conn.Read(buf) // 读数据并赋值
if err != nil {
break // 报错退出
}
if numofbyte != { // 读到了数据长度如果不等于0 msg := string(buf[:numofbyte]) //打印数据,注意之前发的数据因为改的是[]byte,存在未被覆盖的字节信息,所以这里切一下
msgQue <- msg // 这里放到channel中
}
}
} func Checkerror1(err error) {
if err != nil {
panic(err)
}
} func doProcessMessage(mesa string){
content := strings.Split(mesa,"#") // 把字符串ip序号#消息进行分割
if len(content) > { //如果有消息
addr := content[]
sendMessage := strings.Join(content[:],"#") // 这里为了防止消息中有另外的#
if conn,ok := onlineConns[addr]; ok{ // 看是前面的ip否在消息队列中
_, err := conn.Write([]byte(sendMessage)) //如果在的话写入
if err != nil{
fmt.Println("wrong")
}
}
}
} func ConsumeMessage() { // 这个consume用select用来监控两个channel如果quitchan有消息就退出,如果不是就处理消息进行分发
for {
select {
case mssage := <-msgQue: //解析
doProcessMessage(mssage) // 消息处理,并进行分发
case <-quitChan:
break
}
}
} func main() {
logfile, err := os.OpenFile("LOG_DIRECORY", os.O_RDWR|os.O_CREATE,) // 打开文件
if err != nil{
fmt.Println("log file create failure!")
os.Exit(-)
}
defer logfile.Close()
logger = log.New(logfile,"\r\n",log.Ldate|log.Ltime|log.Llongfile) logger.Println("llkjklj") // 输入log listen_s, err := net.Listen("tcp", "127.0.0.1:8080") // 开启一个socket
Checkerror1(err)
defer listen_s.Close() // 结束关socket fmt.Println("server is waiting..")
go ConsumeMessage()
for {
conn, err := listen_s.Accept() // socket 接链接
Checkerror1(err)
addr := fmt.Sprintf("%s",conn.RemoteAddr()) // 把这个转换一下到string中
onlineConns[addr] = conn
go ProcessInfo(conn) // 处理数据
} }
package main
import (
"fmt"
"net"
"bufio"
"os"
"strings"
) func MessageSend(conn net.Conn) {
var input string
for {
reader := bufio.NewReader(os.Stdin) // 标准输入
data, _,_ := reader.ReadLine() // 读到数据到data
input = string(data)
if strings.ToUpper(input) == "EXIT" { // 如果写的是exit就退出
conn.Close()
break
}
_, err := conn.Write([]byte(input)) // 发消息
if err != nil { // 报错退出
conn.Close()
fmt.Println("Clinet connect fail")
break
}
}
} func Checkerror( err error){
if err != nil {
panic(err)
}
} func main(){
conn, err := net.Dial("tcp","127.0.0.1:8080") // 连接socket
Checkerror(err)
defer conn.Close()
MessageSend(conn) // 发消息
buf := make([]byte,1024)
for {
_, err := conn.Read(buf) // 读消息
if err != nil{
fmt.Println("exit")
os.Exit(0) // 正常退出
}
fmt.Println(string(buf))
}
}

客户端

go网络编程应用的更多相关文章

  1. 猫哥网络编程系列:HTTP PEM 万能调试法

    注:本文内容较长且细节较多,建议先收藏再阅读,原文将在 Github 上维护与更新. 在 HTTP 接口开发与调试过程中,我们经常遇到以下类似的问题: 为什么本地环境接口可以调用成功,但放到手机上就跑 ...

  2. python select网络编程详细介绍

    刚看了反应堆模式的原理,特意复习了socket编程,本文主要介绍python的基本socket使用和select使用,主要用于了解socket通信过程 一.socket模块 socket - Low- ...

  3. Linux Socket 网络编程

    Linux下的网络编程指的是socket套接字编程,入门比较简单.在学校里学过一些皮毛,平时就是自学玩,没有见识过真正的socket编程大程序,比较遗憾.总感觉每次看的时候都有收获,但是每次看完了之后 ...

  4. 猫哥网络编程系列:详解 BAT 面试题

    从产品上线前的接口开发和调试,到上线后的 bug 定位.性能优化,网络编程知识贯穿着一个互联网产品的整个生命周期.不论你是前后端的开发岗位,还是 SQA.运维等其他技术岗位,掌握网络编程知识均是岗位的 ...

  5. 浅谈C#网络编程(一)

    阅读目录: 基础 Socket编程 多线程并发 阻塞式同步IO 基础 在现今软件开发中,网络编程是非常重要的一部分,本文简要介绍下网络编程的概念和实践. Socket是一种网络编程接口,它是对传输层T ...

  6. C++11网络编程

    Handy是一个简洁优雅的C++11网络库,适用于linux与Mac平台.十行代码即可完成一个完整的网络服务器. 下面是echo服务器的代码: #include <handy/handy.h&g ...

  7. Java - 网络编程

    Java的网络编程学习,关于计算机基础的学习参考:计算机网络基础学习 - sqh.     参考:  

  8. Linux网络编程-IO复用技术

    IO复用是Linux中的IO模型之一,IO复用就是进程预先告诉内核需要监视的IO条件,使得内核一旦发现进程指定的一个或多个IO条件就绪,就通过进程进程处理,从而不会在单个IO上阻塞了.Linux中,提 ...

  9. Python Socket 网络编程

    Socket 是进程间通信的一种方式,它与其他进程间通信的一个主要不同是:它能实现不同主机间的进程间通信,我们网络上各种各样的服务大多都是基于 Socket 来完成通信的,例如我们每天浏览网页.QQ ...

  10. iOS网络编程

    今天的重点是UIWebView.NSURLSession.JSon. 网络编程联网准备:1.在Info.plist中添加AppTransportSecurity类型Dictionary:2.在AppT ...

随机推荐

  1. IO分类

    按流向分类: 输入流 读取数据 FileReader Reader 输出流 写入数据 FileWriter Writer 按数据类型分类: 字节流 字节输入流 读取数据 InputStream 字节输 ...

  2. Excel VBA 连接各种数据库(二) VBA连接Oracle数据库

    本文主要内容: Oracle环境配置 ODBC驱动设置.第三方驱动下载 VBA连接Oracle连接方法 Oracle10g官方免账号下载地址 系统环境: Windows 7 64bit Excel 2 ...

  3. Nginx+Keepalived(二)

    Linux CentOS7安装Nginx 1.gcc 安装 安装 nginx 需要先将官网下载的源码进行编译,编译依赖 gcc 环境. yum install gcc-c++ 2.PCRE pcre- ...

  4. dubbo 面试

    1.使用dubbo+zookeeper ,如果注册中心挂掉,是否可以继续通信?(zk集群可以达到高可用,但是如果全部挂掉呢?) 我答了不可以吧(项目没用过,自学没又这深度) 正确答案: dubbo使用 ...

  5. linux上安装Docker

    https://blog.csdn.net/qq_36892341/article/details/73918672

  6. mysql concat筛选查询重复数据

    SELECT * from (SELECT *,concat(field0,field1)as c from tableName) tt GROUP BY c HAVING count(c) > ...

  7. 内置函数-map

    ret = map(abs,[-1,1,2,3]) print(ret) for i in ret: print(i) l = [1,-2,3,6,8,-7] l.sort(key=abs) prin ...

  8. mysql 悲观锁与乐观锁的理解

    悲观锁与乐观锁是人们定义出来的概念,你可以理解为一种思想,是处理并发资源的常用手段. 不要把他们与mysql中提供的锁机制(表锁,行锁,排他锁,共享锁)混为一谈. 一.悲观锁 顾名思义,就是对于数据的 ...

  9. MVC Request生命周期(综合总结)

    当用户在浏览器输入一个URL地址后,浏览器会发送一个请求到服务器.这时候在服务器上第一个负责处理请求的是IIS.然后IIS再根据请求的URL扩展名将请求分发给不同的处理程序处理. 流程如下: 当请求一 ...

  10. python rsa 加密

    rsa 非对称加密, 公钥加密, 私钥解密, 有公钥无法推导出私钥, 私钥保密 import rsa n = 1024 # n 越大生成公钥, 秘钥及加密解密所需时间就越长 key = rsa.new ...