hisangke / chitchat

《Go Web 编程》中chitchat博客项目的学习(添加详细中文注释)

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

ChitChat

ChitChat的数据模型:

  1. User——表示论坛的用户信息
  2. Session——表示论坛用户当前的登录会话
  3. Thread——表示论坛里面的帖子,每一个帖子都记录了多个论坛用户之间的对话
  4. Post——表示用户在帖子里面添加的回复

Web应用工作流程

  1. 客户端向服务器发送请求
  2. 多路复用器接收到请求,并将其重定向到正确的处理器
  3. 处理器对请求进行处理
  4. 在需要访问数据库的情况下,处理器会使用一个或多个数据结构,这些数据结构都是蜂聚数据库中的数据建模而来的
  5. 当处理器调用与数据结构有关的函数或者方法时,这些数据结构背后的模型会与数据库进行连接,并执行相应的操作
  6. 当请求处理完毕时,处理器会调用模板引擎,有时候还会向模板引擎传递一些通过模型获取到的数据
  7. 模板引擎会对模板文件进行语法分析并创建相应的模板,而这些模板又会与处理器传递的数据合并生成最终的HTML
  8. 生成的HTML会作为响应的一部分传至客户端

注意

如果直接go run 或者 go build 程序会有问题,要修改代码中import有关data包的路径,换成自己机器上的路径

依赖

  1. golang
  2. postgresql
  3. 还有一个第三方库包:github.com/lib/pq,用go get即可

运行

  1. 首先把源代码下载下来:
git clone https://github.com/hisangke/chitchat.git
sudo apt-get update && sudo apt-get install postgresql postgresql-client
sudo vi /etc/postgresql/9.5/main/pg_hba.conf : local   all             postgres                                peer ---> local   all             postgres                                md5
sudo service postgresql restart  //sudo /etc/init.d/postgresql start/stop/restart
sudo -u postgres psql --> ALTER USER postgres WITH PASSWORD 'user';
  1. 根据实际情况修改代码中的data包的路径,还有data目录下的data.go中连接数据库的参数
  2. 创建数据表(以用户名为chitchat为例,在data目录下执行):
psql -U postgres -f setup.sql
  1. 返回main.go所在的目录:
go build

若无错误则会得到一个名为chitchat的可执行文件,执行以下语句即可运行:

./chitchat
  1. 之后便可在chitchat或在浏览器中输入:
http://127.0.0.1:8080/

即可进入论坛:

建议阅读顺序

  1. main.go: 总体了解整个项目的框架
  2. data/user.go 和 data/thread.go: 了解chitchat项目中的四个主要结构包含什么成员,特别要注意session结构
  3. route_*.go: 这三个文件主要功能就是处理HTTP请求并响应,session结构发挥了重要作用,特别是其中的UUID成员
  4. templates目录下的模板文件: 结合着之前的处理函数看
  5. utils.go: 里面有一些在整个项目中用到的函数,在之前遇到其中的函数可以先看
  6. 最后是data包中的文件,主要是那四个结构的方法,里面有数据库的操作

About

《Go Web 编程》中chitchat博客项目的学习(添加详细中文注释)


Languages

Language:Go 79.3%Language:HTML 18.6%Language:CSS 2.1%