通过项目实战入门Go语言

Golang 投稿 57000 0 评论

通过项目实战入门Go语言

项目仓库地址:https://github.com/wangkechun/go-by-example

实战

项目一:guessing-game

项目二:simpledict

    获取main函数运行时的参数hello作为需要翻译的单词(通过go的api获取)

    • https://curlconverter.com/#go,这个在线工具可以将curl命令转换成go语言代码(或者其他语言),将得到的代码直接复制到goland中运行就可以实现用go代码模拟请求这个翻译接口,得到响应数据(文本格式的json)

    • 这个过程和爬虫的工作比较像,模拟用户在网页上提交翻译的请求,其本质上就是发送了一个http请求,携带需要翻译的单词信息,响应翻译结果的json并由浏览器解析,通过下图的可以将本次request的请求以cURL请求的方式拷贝。

    • 此时得到的翻译数据是文本格式的json(就是byte数组,或者说字符串),因此需要将其反序列化为go的结构体,然后打印出我们需要的翻译信息。

    • https://oktools.net/json2go,这个在线工具可以将json转go的struct,然后将这个结构放入go代码中,使用json包的Unmarshal函数将json字符串字符串反序列化为结构体,后面就可以打印结构体中需要的属性(包含翻译结果)

  • 改进:用到两个翻译软件的接口,并且并发访问,思路是一样的,就是再找一个翻译软件的接口重复上面的操作,然后重点在于并发的实现,这里启用两个goroutine,借助sync包的WaitGroup,先初始化一个2的容量,然后在一个go程结束之后调用wg.Done(),只有全部容量次数的Done调用后wg.Wait()才会放行,否则任意一个go程未完成,主go程都不会继续执行(但是如果没有这个WaitGroup去限制,则在主go程结束时,因为由其创建的子go程可能并没有完成,但依旧会结束,而恰恰因为并发的关系,编码先后顺序的失去了作用,发生这种情况的概率很高)

项目三:proxy

  • 观察proxy项目包的v4版本(clone地址已经给出),看到代理服务端的process函数如下:

    • 代理的工作由auth()认证和connect()连接两个部分组成,看一下最上面给出的代理工作流程图,可以看到对应着协商阶段和通信阶段。而我们发现,本实例的客户端发起的是一条curl --socks5 127.0.0.1:1080 -v https://www.qq.com,需要注意的细节是,auth和connect工作并不是一蹴而就的,它们从reader缓冲区读取客户端发送过来的数据,验证之后返回给客户端,然后再获取从客户端发送过来的数据,而客户端的这部分工作已经被curl工具隐藏,而非只是发起了一次请求。

    • 因为auth和connect函数中多次使用到的从缓冲区读取字节的这个api在缓冲区没有byte的时候,是会被阻塞的,因此会等待客户端发送数据,因此只要代理服务器遵守socks5协议规定的通信规则进行解析客户端的数据,发送指定的响应,而客户端也遵守这个规则解析和发送数据(本例就是curl --socks5 xxx帮我们完成了),就可以实现socks5代理服务器的工作模式

    • 因此我理解中的socks5代理服务器就是完全在socks5协议约束的基础上进行编码的一个服务器,之后的请求和响应转发则和socks5没关系了

结束语

关注微信公众号【程序员白泽】,将同步更新字节青训营的学习笔记

编程笔记 » 通过项目实战入门Go语言

赞同 (89) or 分享 (0)
游客 发表我的评论   换个身份
取消评论

表情
(0)个小伙伴在吐槽