1.beego框架了解
Beego框架是go语言开发的web框架。
那什么是框架呢?就是别人写好的代码,我们可以直接使用!这个代码是专门针对某一个开发方向定制的,例如:我们要做一个网站,利用 beego 框架就能非常快的完成网站的开发,如果没有框架,每一个细节都需要我们处理,开发速度会大大降低。
go语言的web框架:beego,gin,echo等等,那为什么我们选择beego呢?
第一,beego是中国人开发的,开发文档比较详细,beego官网网址: 。
第二,现在公司里面用beego的也比较多,比如今日头条,百度云盘,腾讯,阿里等。
2.MVC架构
Beego是MVC架构。MVC 是一种应用非常广泛的体系架构,几乎所有的编程语言都会使用到,而且所有的程序员在工作中都会遇到!用 MVC 的方式开发程序,可以让程序的结构更加合理和清晰。 我们画图说明
beego具体是如何内嵌MVC呢?我们搭起环境通过代码分析。
3.环境搭建
这里默认大家已经搭建好了go语言的开发环境。
$ cd ~
$ vim .bashrc
//在最后一行插入
export PATH='$GOPATH/bin:$PATH'
//然后保存退出
$ source .bashrc
- 1
- 2
- 3
- 4
- 5
- 6
- 1
- 2
- 3
- 4
- 5
- 6
4.beego的项目结构分析
quickstart
|-- conf
| `-- app.conf
|-- controllers
| `-- default.go
|-- main.go
|-- models
|-- routers
| `-- router.go
|-- static
| |-- css
| |-- img
| `-- js
|-- tests
| `-- default_test.go
|-- views
`-- index.tpl
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
conf文件夹:放的是项目有关的配置文件
controllers:存放主要的业务代码
main.go:项目的入口文件
models:存放的是数据库有关内容
routers:存放路由文件,路由作用是根据不同的请求指定不同的控制器
static:存放静态资源,包括图片,html页面,css样式,js文件等
tests:测试文件
views:存放视图有关内容
后面我们重点需要操作的是MVC文件夹,routers文件夹。
5.Beego快速体验
前面我们简单了解了 beego初始化的内容,那么就来个beego的快速体验吧!
根据上图所示的步骤,对自己创建的项目进行三步修改,然后在浏览器是否能看到修改之后的效果。
如果把你们前面做的静态网页放到views文件夹下呢?一个静态网站是不是就出现啦!有没有感受到beego开发网站的快捷!
代码分析
c.Data['Email'] = 'astaxie@gmail.com'{{ }}.{{.Email}}
c.TplName = 'index.tpl'
通过我们对Beego的快速体验能够得出如下结论:
控制器(Controller)的作用
1.能够给视图传递数据
2.能够指定视图
视图(View)的作用
1.view本质就是个html。所以能在浏览器显示
2.能够接收控制器传递过来的数据
6.Beego运行流程分析
-
浏览器发出请求
-
路由拿到请求,并给相应的请求指定相应的控制器
-
找到指定的控制器之后,控制器看是否需要查询数据库
-
如果需要查询数据库就找model取数据
-
如果不需要数据库,直接找view要视图
-
控制器拿到视图页面之后,把页面返回给浏览器
根据文字流程分析代码流程
-
从项目的入口main.go开始
-
找到router.go文件的Init函数
-
找到路由指定的控制器文件default.go的Get方法
-
然后找到指定视图的语法,整个项目就串起来啦。
7.Post案例实现
刚才我们分析了beego项目的整个运行流程,最终是如何调到Get方法的呢?beego通过内部语法给不同的http请求指定了不同的方法,因为我们是从浏览器地址栏发送的请求,属于get请求,所以调用的是Get方法。为了检验对不对,我们可以实现一个post请求,看看效果。
7.1前端修改
前端代码如下:
form
然后设置一个能接收后台传递过来的数据的标签
<h1>hello {{.data}}</h1>
- 1
- 1
全部代码:
7.2后台代码修改
后台代码
先设置我们Get请求要传递的数据和要显示的视图页面
func (c *MainController) Get() {
c.Data['data'] = 'world'
c.TplName = 'test.html' //渲染
}
- 1
- 2
- 3
- 4
- 1
- 2
- 3
- 4
再设置我们post请求要传递的数据和要显示的视图页面
操作
先在浏览器输入网址,然后点击页面上的按钮,看一下页面的变化,有没有出现hello world
8.Beego中路由的快速体验
8.1路由的简单设置
路由的作用:根据不同的请求指定不同的控制器
beego.Router('/path',&controller.MainController{})
函数参数:
先分析一下Url地址由哪几部分组成? 同一资源定位符
http://192.168.110.71:8080/index
http://地址:端口/资源路径
/
第二个参数:需要指定的控制器指针
了解上面的内容之后我们来看几个简单的例子:
beego.Router('/', &controllers.MainController{})
beego.Router('/index', &controllers.IndexController{})
beego.Router('/login', &controllers.LoginController{})
- 1
- 2
- 3
- 1
- 2
- 3
8.2高级路由设置
一般在开发过程中,我们基本不使用beego提供的默认请求访问方法,都是自定义相应的方法。那我们来看一下如何来自定义请求方法。
自定义请求方法需要用到Router的第三个参数。这个参数是用来给不同的请求指定不同的方法。具体有如下几种情况。
beego.Router('/api',&RestController{},'get,post:ApiFunc')
- 1
- 1
beego.Router('/simple',&SimpleController{},'*:AllFunc;post:PostFunc')
- 1
- 1
小结
1.了解MVC结构
2.了解beego初始化之后各个模块的作用
3.了解beego项目的运行流程
4.能够对路由进行简单的设置