# chitchat **Repository Path**: go-program/chitchat ## Basic Information - **Project Name**: chitchat - **Description**: 参考《Go Web 编程》及liu-jianhao开源的简易论坛,基于原生go语言的web应用。 包含用户登录登出、注册、发帖、回帖、查看等基本功能,采用postgresql做数据存储。供go语言学习用。 - **Primary Language**: Go - **License**: MIT - **Default Branch**: master - **Homepage**: https://gitee.com/go-program/chitchat - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2022-07-19 - **Last Updated**: 2022-07-20 ## Categories & Tags **Categories**: Uncategorized **Tags**: Web, goweb ## README # 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即可 go get gthiub.com/lib/pq ## 运行 1. 首先把源代码下载下来: ```shell git clone https://github.com/liu-jianhao/chitchat.git ``` 2. 根据实际情况修改代码中的data包的路径,还有data目录下的data.go中连接数据库的参数 3. 创建数据表(以用户名为chitchat为例,在data目录下执行): ```shell psql -U chitchat -f setup.sql ``` 4. 返回main.go所在的目录: ```shell go build ``` 若无错误则会得到一个名为chitchat的可执行文件,执行以下语句即可运行: ```shell ./chitchat ``` 5. 之后便可在[chitchat](http://127.0.0.1:8080/)或在浏览器中输入: ```shell http://127.0.0.1:8080/ ``` 即可进入论坛: ![](https://github.com/liu-jianhao/chitchat/blob/master/img/chitchat.png) ## 建议阅读顺序 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包中的文件,主要是那四个结构的方法,里面有数据库的操作