go写的tcp简易聊天

学习go的小进步

server 代码
//chat server listen 8080
package main

import (
    "fmt"
    "log"
    "net"
    "os"
    "strings"
)

const (
    LOG_DIRECTORY = "./test.log" //记录错误日志的路径
)

var online = make(map[string]net.Conn)
var msgQyeue = make(chan string, 1000)
var quitChan = make(chan bool)
var logFile *os.File
var logger *log.Logger

func coninfo(con net.Conn) {
    //make a buff 消息的缓冲区
    buff := make([]byte, 1024)
    //最后记得关掉 将退出连接的请求删掉
    defer func(con net.Conn) {
        addr := fmt.Sprintf("%s", con.RemoteAddr())
        delete(online, addr)
        con.Close()
    }(con)
    //不断的读取
    for {
        numBuff, err := con.Read(buff)
        if err != nil {
            continue
        }
        if numBuff != 0 {
            msgQyeue <- string(buff[:numBuff]) //细节 因为我们最大1024字节,会有上一条消息的缓存 生产者
        }
    }
}

//消费数据
func outMsg() {
    for {
        select {
        case msg := <-msgQyeue:
            //doMsg(<-msgQyeue) 这样写client接收不到返回的消息
            doMsg(msg)
        case <-quitChan:
            break

        }
    }
}

//对数据做处理 127.0.0.0:1234#你好
func doMsg(msg string) {
    content := strings.Split(msg, "#") //按照#切分数据
    if len(content) > 1 {
        addr := content[0]
        sendMsg := strings.Join(content[1:], "#") //127.0.0.1 #(你好#xxx)->连接起来
        addr = strings.Trim(addr, " ")            //对空格进行处理相当于phptrim
        if con, ok := online[addr]; ok {
            _, err := con.Write([]byte(sendMsg))
            if err != nil {
                fmt.Println("send msg is nil")
            }

        }
    } else {
        content := strings.Split(msg, "*") //自定义规则按照*切分数据
        if strings.ToUpper(content[1]) == "LIST" {
            var ips = ""
            for i := range online {
                ips = ips + "|" + i
            }
            if con, ok := online[content[0]]; ok {
                _, err := con.Write([]byte(ips))
                if err != nil {
                    fmt.Println("send msg is nil")
                }
            }
        }
    }
}
func main() {
    //打开日志文件
    logFile, err := os.OpenFile(LOG_DIRECTORY, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0)
    if nil != err {
        logger.Println(err)
        os.Exit(-1)
    }

    defer logFile.Close()
    logger = log.New(logFile, "\r\n", log.Ldate|log.Ltime|log.Llongfile)

    //server 监听的端口
    socketer, err := net.Listen("tcp", "localhost:8080")
    if err != nil {
        fmt.Println(err)
    }
    defer socketer.Close()
    fmt.Println("wait for message……")
    logger.Println("i am writing the log")

    go outMsg()
    for {
        //accept是建立链接后进行通信的 如果不用协程效果是你说一句我说一句
        con, err := socketer.Accept()
        if err != nil {
            fmt.Println(err)
        }
        //将con 映射到map里面
        //con.RemoteAddr() 获取cil ip和端口
        addr := fmt.Sprintf("%s", con.RemoteAddr())
        online[addr] = con
        for i := range online {
            fmt.Printf("%s\n", i)
            logger.Printf("%s\n", i)
        }
        //协程read
        go coninfo(con)
    }

}

client 代码
//chat here is cilent
package main

import (
    "bufio"
    "strings"

    "fmt"
    "net"
    "os"
)

func checkErr(err error) {
    if err != nil {
        fmt.Println(err)

    }
}

func sendMessage(con net.Conn) {
    var input string //没什么暖用的定义 ,就是为了byte少了一层string的转换
    //cil协程write server协程read
    for {
        reader := bufio.NewReader(os.Stdin)   //bufio来读取标准输入
        data, _, _ := reader.ReadLine()       //返回你输入那一行的data(数据)
        input = string(data)                  //感觉没什么暖用,还是写上了
        if strings.ToUpper(input) == "EXIT" { //如果 输入的是EXIT就退出server,退出前关闭close这是一个好习惯
            con.Close()
            break
        }
        _, err := con.Write(data) //通过write来写数据 server通过read来读数据
        if err != nil {
            con.Close() //同上
            break
        }
    }
}
func main() {

    con, err := net.Dial("tcp", "localhost:8080") //连接server的ip和server的端口
    checkErr(err)
    defer con.Close() //好习惯 nbb

    go sendMessage(con) //协程写入
    // checkErr(err)
    buf := make([]byte, 1024)
    for {
        numOfBytes, err := con.Read(buf) //localhost:8080读取数据
        if err != nil {
            fmt.Println("您已经退出,感谢您的使用")
            os.Exit(0)
        }
        // if string(buf[:numOfBytes]) == "你好" {
        //  fmt.Println("recv meg is:" + string("你好大傻逼"))
        //  return
        // }
        fmt.Println("recv meg is:" + string(buf[:numOfBytes]))
    }
    fmt.Println("message is end !")

}

默认client发送需要另一个client的ip#content的格式,这个格式自定义,过几天用swoole实现以下这个,对比以下如果查看ip list 格式是ip*list这个也可以自定义

注释很详细,逻辑很清晰,给自己一个赞

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,122评论 6 505
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,070评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,491评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,636评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,676评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,541评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,292评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,211评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,655评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,846评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,965评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,684评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,295评论 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,894评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,012评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,126评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,914评论 2 355

推荐阅读更多精彩内容

  • 早上报着明天周日可以休息的心态还是爬起来练习完了,啊哈哈哈哈,腿太疼了,也算坚持下来了。今天上午出去,发单子的时候...
    小贝灬阅读 196评论 0 0
  • 蜻蜓在飞飞越黄昏的美我在路口看风吹鸟儿躲在枝头醉柳叶剪绿一头妩媚调皮的阳光在枝头追总有不小心跌落的伤悲 我掏出干瘪...
    守海入梦阅读 1,316评论 32 25
  • 盼望着,盼望着,终于在这个阖家团圆、举国同庆、喜气洋洋、没人加班的日子里,女神大人又想起了我——大宝——一个因打游...
    网易每日轻松一刻工作室阅读 851评论 0 2
  • 睡前一直都有看看订阅号的习惯,听听书,看看洗脑文,到现在,看来看去,看多了,也就生厌了,总是一些老生常谈的话题,...
    翩翩的精灵女侠阅读 154评论 0 0
  • 历经一周时间,终于把三根宽带过户完成,升级完毕,并将86125728移至二楼电销办公室,并调试好无线wifi。 很...
    捌柒玖零阅读 117评论 0 0