Go 语言构建 RESTful Web 服务: https://www.oschina.net/translate/hardcore-google-communicating-go
Golang中使用 JWT认证来 保障Restful JSON API的安全(英文): http://www.tuicool.com/articles/ZnMZF3
polaris: 一个用go实现的支持restful的web框架: http://blog.csdn.net/siddontang/article/details/21088451
关于RESTFUL API 安全认证方式的一些总结: http://www.cnblogs.com/Irving/p/4964489.html
有没有人用golang实现过restful框架的实例: http://www.golangtc.com/t/53ba35e9320b52466c00000f
Micro 一个用Go语言实现的微服务框架: http://www.tuicool.com/articles/nqQfYb
基于微服务库的可插拔RPC go-micro: http://www.oschina.net/p/go-micro
golang适合做web开发吗?: https://www.zhihu.com/question/30649593
a-survey-of-5-go-web-frameworks: http://thenewstack.io/a-survey-of-5-go-web-frameworks/
Ozzo Framework: https://github.com/go-ozzo
avelino/awesome-go: https://github.com/avelino/awesome-go#web-frameworks
Beego Framework: https://beego.me/
golang其实不适合做web开发: http://www.golangtc.com/t/5598f78ab09ecc0f51000014
Go语言现有Web开发框架: http://studygolang.com/resources/71
使用Golang快速构建WEB应用: http://blog.jobbole.com/84884/
Martini 极好的 Go WEB 框架: https://my.oschina.net/achun/blog/190909
golang 有哪些比较稳定的 web 开发框架?: https://www.zhihu.com/question/21038038
当客户端在 发出POST请求时/albums,您希望将请求正文中描述的专辑添加到现有专辑数据中。
为此,您将编写以下内容:
1、编写代码
a.添加代码以将专辑数据添加到专辑列表。
在此代码中:
1)用于Context.BindJSON 将请求正文绑定到newAlbum。
2) album将从 JSON 初始化的结构附加到albums 切片。
3)向响应添加201状态代码,以及表示您添加的专辑的 JSON。
b.更改您的main函数,使其包含该router.POST函数,如下所示。
在此代码中:
1)将路径中的POST方法与 /albumspostAlbums函数相关联。
使用 Gin,您可以将处理程序与 HTTP 方法和路径组合相关联。这样,您可以根据客户端使用的方法将发送到单个路径的请求单独路由。
a.如果服务器从上一节开始仍在运行,请停止它。
b.从包含 main.go 的目录中的命令行,运行代码。
c.从不同的命令行窗口,用于curl向正在运行的 Web 服务发出请求。
该命令应显示添加专辑的标题和 JSON。
d.与上一节一样,使用curl检索完整的专辑列表,您可以使用它来确认添加了新专辑。
该命令应显示专辑列表。
当客户端向 发出请求时GET /albums/[id],您希望返回 ID 与id路径参数匹配的专辑。
为此,您将:
a.在您在上一节中添加的函数下方postAlbums,粘贴以下代码以检索特定专辑。
此getAlbumByID函数将提取请求路径中的 ID,然后找到匹配的专辑。
在此代码中:
(1)Context.Param用于从 URL 中检索id路径参数。当您将此处理程序映射到路径时,您将在路径中包含参数的占位符。
(2)循环album切片中的结构,寻找其ID 字段值与id参数值匹配的结构。如果找到,则将该album结构序列化为 JSON,并将其作为带有200 OK HTTP 代码的响应返回。
如上所述,实际使用中的服务可能会使用数据库查询来执行此查找。
(3)如果找不到专辑,则返回 HTTP 404错误。
b.最后,更改您的main,使其包含对router.GET的新调用,路径现在为/albums/:id ,如以下示例所示。
在此代码中:
(1)将/albums/:id路径与getAlbumByID功能相关联。在 Gin 中,路径中项目前面的冒号表示该项目是路径参数。
a.如果服务器从上一节开始仍在运行,请停止它。
b.在包含 main.go 的目录中的命令行中,运行代码以启动服务器。
c.从不同的命令行窗口,用于curl向正在运行的 Web 服务发出请求。
该命令应显示您使用其 ID 的专辑的 JSON。如果找不到专辑,您将收到带有错误消息的 JSON。
恭喜!您刚刚使用 Go 和 Gin 编写了一个简单的 RESTful Web 服务。
本节包含您使用本教程构建的应用程序的代码。
不知读者是否也会时刻想: 我该怎么写这段代码才优雅, 后期改起来方便?
努力思考却还是得不到最佳答案, 烦躁等负面情绪不约而来。这便是在编程过程中的心智负担。
这篇文章将从多个方面来简化思考, 希望它能给努力思考的你带来一点小灵感.
java的23种设计模式? 再见.
不是说他们没有作用,只是说它们太死板复杂,学习它们通常入不敷出。
对于编程还有很多需要注意的地方(下文),而不要只局限于设计模式。
我给出的建议是只需要理解一个大概,在平时编程中能用则用。
Golang相比Java来说, 对"面向对象"这件事的支持是"不完整"的.
但话又说回来现在的"面向对象编程"渐渐被扭曲为了"面向类编程"(COP),而COP是复杂并难以理解的,COP有好处但要发挥出来并不容易。所以Golang决定抛弃所有不必要的概念以改善这个问题。
现在不必再理解 封装(这个简单到不需要理解), 多态, 继承.
在golang中只需要理解两个更实在的东西: 接口, 组合.
接口
在Golang中只需要记得一个东西: Interface(接口).
参见io.Reader接口就知道这种设计有多厉害.
读文件是它, 读网络请求也是它, 更骚的是 对于linux(Every thing is a file)来说用它就能操作近乎整个系统了.
简单的说: 当某个功能(如去北京)有多种(或者以后可能有多种)实现方式(如坐火车/飞机/骑车)的时候, 用接口.
组合
组合理解起来并不复杂, 不过是一个语法糖, 就算没有组合功能也毫不影响Go程序的运行.
如下代码, 没有组合换一种写法即可.
简单的说: 组合能用则用,如果你不知道如何使用或者不用也并无大碍。
"开闭原则"对我启发很大.
原文是这样:
但其实我们在开发的时候并不是一直都在和对象打交道.
在我看来, "开闭原则"适用于平时写的任何代码.
完整理解"开闭原则"可能还是会造成心智负担, 所以先打住, 只需要这样:
这便是 "对修改闭合, 对扩展开放".
这里不得不在提及"面向函数编程", 它的思想包括但不限于:
它正好利于修改, 利于写出符合"开闭原则"的代码.
默认的errors包在对于多层的复杂应用是不够的,这种情况下建议自行封装,但别太追求完美 在项目中够用就好。我们等待官方方案即可: https://github.com/golang/go/issues/29934
restful能解决大部分命名问题.
你的代码完全可以这样无脑命名而不失优雅.
这样的白话文真的很好命名与理解(根本不需要词汇量).
无脑Goroution, 80%的情况下都没问题.
如果你实在担心, 用channel的做下并发数量控制就好, 或者使用更完整的工具叫"协程池", 他们的实现都不复杂.
得益于golang的开源和这几年的蓬勃发展,golang的生态已经十分完善,所以很多情况下我们应该"面相github编程",第三方提供的代码已能满足我们大多数需求。同时 选用一个受欢迎的第三方代码库通常比自己的更可靠,后续维护也省心很多。
最省心的行为是: 先跟随团队再提出意见