- User——表示论坛的用户信息
- Session——表示论坛用户当前的登录会话
- Thread——表示论坛里面的帖子,每一个帖子都记录了多个论坛用户之间的对话
- Post——表示用户在帖子里面添加的回复
- 客户端向服务器发送请求
- 多路复用器接收到请求,并将其重定向到正确的处理器
- 处理器对请求进行处理
- 在需要访问数据库的情况下,处理器会使用一个或多个数据结构,这些数据结构都是蜂聚数据库中的数据建模而来的
- 当处理器调用与数据结构有关的函数或者方法时,这些数据结构背后的模型会与数据库进行连接,并执行相应的操作
- 当请求处理完毕时,处理器会调用模板引擎,有时候还会向模板引擎传递一些通过模型获取到的数据
- 模板引擎会对模板文件进行语法分析并创建相应的模板,而这些模板又会与处理器传递的数据合并生成最终的HTML
- 生成的HTML会作为响应的一部分传至客户端
如果直接go run 或者 go build 程序会有问题,要修改代码中import有关data包的路径,换成自己机器上的路径
- golang
- postgresql
- 还有一个第三方库包:github.com/lib/pq,用go get即可
- 首先把源代码下载下来:
git clone https://github.com/liu-jianhao/chitchat.git
- 根据实际情况修改代码中的data包的路径,还有data目录下的data.go中连接数据库的参数
- 创建数据表(以用户名为chitchat为例,在data目录下执行):
psql -U chitchat -f setup.sql
- 返回main.go所在的目录:
go build
若无错误则会得到一个名为chitchat的可执行文件,执行以下语句即可运行:
./chitchat
- 之后便可在chitchat或在浏览器中输入:
http://127.0.0.1:8080/
- main.go: 总体了解整个项目的框架
- data/user.go 和 data/thread.go: 了解chitchat项目中的四个主要结构包含什么成员,特别要注意session结构
- route_*.go: 这三个文件主要功能就是处理HTTP请求并响应,session结构发挥了重要作用,特别是其中的UUID成员
- templates目录下的模板文件: 结合着之前的处理函数看
- utils.go: 里面有一些在整个项目中用到的函数,在之前遇到其中的函数可以先看
- 最后是data包中的文件,主要是那四个结构的方法,里面有数据库的操作