• 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏吧

02 . Beego框架结构组织,路由及项目初始化

开发技术 开发技术 2周前 (07-27) 20次浏览

Beego项目组织结构

conf

conf:项目配置文件所在的目录,项目中有一些全局的配置都可以放在此目录下。默认的app.conf文件中默认指定了三个配置:

// 1)appname = BeegoDemo2: 指定项目名称。
// 2)httpport = 8080: 指定项目服务监听端口。
// 3)runmode = dev: 指定执行模式。
Controllers

该目录是存放控制器文件的目录,所谓控制器就是控制应用调用哪些业务逻辑,由controllers处理完http请求以后,并负责返回给前端调用者。

models

models层可以解释为实体层或者数据层,在models层中实现和用户和业务数据的处理,主要和数据库表相关的一些操作会在这一目录中实现,然后将执行后的结果数据返回给controller层。比如向数据库中插入新数据,删除数据库表数据,修改某一条数据,从数据库中查询业务数据等都是在models层实现。

routers

该层是路由层。所谓路由就是分发的意思,当前端浏览器进行一个http请求达到后台web项目时,必须要让程序能够根据浏览器的请求url进行不同的业务处理,从接收到前端请求到判断执行具体的业务逻辑的过程的工作,就由routers来实现。

static

在static目录下,存放的是web项目的静态资源文件,主要有:css文件,img,js,html这几类文件。html中会存放应用的静态页面文件。

views

views中存放的就是应用中存放html模版页面的目录。所谓模版,就是页面框架和布局是已经使用html写好了的,只需要在进行访问和展示时,将获取到的数据动态填充到页面中,能够提高渲染效率。因此,模版文件是非常常见的一种方式。

综上,这个整个的项目架构就是MVC的运行模式。常见的架构模式大家应该熟悉比如:MVC,MVP,MVVM等架构。这里我们采用MVC

路由设置

基础路由

Get请求就会对应到Get方法,Post就会对应到Post方法,Delete就会对应到Delete方法,Header方法就会对应Header方法。

package routers

import (
	"github.com/astaxie/beego"
	"github.com/astaxie/beego/context"
)

/**
  * 基础路由
  * beego框架提供了常见的http的请求类型方法的路由方案,比如: get,post,head,options,delete等方法
 */

func init() {
	beego.Get("/get", func(context *context.Context) {
		beego.Info("基础路由中的get请求")
		context.Output.Body([]byte("基础路由中的get请求"))
	})

	beego.Get("/getUserInfo", func(context *context.Context) {
		beego.Info("获取用户信息")
		context.Output.Body([]byte("获取用户信息"))
	})

	beego.Post("/post", func(this *context.Context) {
		beego.Info("基础路由中的post请求")
		this.Output.Body([]byte("基础路由的post请求"))
	})
}
固定路由

诸如以下此种代码形式:

// beego.Router("/",controller);

// Get请求就会对应到Get方法,Post就会对应到Post方法,Delete就会对应到Delete方法,Header方法就会对应Header方法。
正则路由

正则路由是指可以在进行固定路由的基础上,支持匹配一定格式的正则表达式。比如:id,:username,自定义正则,file的路径和后缀切换以及全匹配等操作。

自定义路由

上面两种路由都是默认的根据请求的类型,Get就执行Get方法,Post执行Post方法,比较局限。因为在开发的时候大部分都是使用固定匹配想要直接执行对应的逻辑控制方法,因此beego提供给我们了可以自定义的自定义路由配置。方式如下:

// beego.Router("/",&IndexController{},"")

Model层

在Web开发过程中,开发者操作数据,存储数据最常用的就是数据库操作,数据库操作是独立的一个模块,这个在后面具体的项目中实现。

View编写

在实际的开发过程中,要求大家需要掌握html,js语法以及简单的css语法要能看懂,能够时间简单的使用。更加复杂的前端页面或者静态页面,需要和前端开发人员进行对接。开发重心是在后台服务端,因此,只需要学会使用和调用调试即可。

静态文件的设置

在goweb项目中,上面说过是有一些静态资源文件的,如果用户要访问静态资源文件,我们应该也是能够访问的,这需要在我们的项目中进行静态资源设置。
设置方式为:

// beego.SetStaticPath("/down1","download1")
// 这里的download目录是指的非goweb项目的static目录下目录,而是开发者重新新建的另外的目录。

配置数据库

mysql数据库安装

请看我写的专门部署mysql博客

https://www.cnblogs.com/you-men/p/12838133.html

配置数据库驱动

数据库编程属于beego中的Models层,也称为ORM模块

在beego中,目前支持三种数据库驱动,分别是:

// MySQL: github.com/go-sql-driver/mysql
// PostgreSQL:github.com/lib/pq
// Sqlite3:github.com/mattn/go-sqlite3


go get  github.com/go-sql-driver/mysql

beego中的ORM所具备的几个特性

// 1. 支持G语言的所有类型存储
// 2. CRUD操作简单
// 3. 自动Join关联表
// 4. 允许直接使用SQL查询

beego项目中使用mysql

导入对应的数据库驱动
import _ "github.com/go-sql-driver/mysql"
注册驱动,连接数据库
orm.RegisterDriver("mysql",orm.DRMySQL)
orm.RegisterDataBase(aliasName,driverName,dbConn)
连接数据库代码
package models

import (
    "github.com/astaxie/beego"
    "github.com/astaxie/beego/orm"
    "BlogProject/MysqlDemo/util"
    //切记:导入驱动包
    _ "github.com/go-sql-driver/mysql"
)

func init() {

    driverName := beego.AppConfig.String("driverName")

    //注册数据库驱动
    orm.RegisterDriver(driverName, orm.DRMySQL)

    //数据库连接
    user := beego.AppConfig.String("mysqluser")
    pwd := beego.AppConfig.String("mysqlpwd")
    host := beego.AppConfig.String("host")
    port := beego.AppConfig.String("port")
    dbname := beego.AppConfig.String("dbname")
      //dbConn := "root:yu271400@tcp(127.0.0.1:3306)/cmsproject?charset=utf8"
    dbConn := user + ":" + pwd + "@tcp(" + host + ":" + port + ")/" + dbname + "?charset=utf8"

    err := orm.RegisterDataBase("default", driverName, dbConn)
    if err != nil {
        util.LogError("连接数据库出错")
        return
    }
    util.LogInfo("连接数据库成功")

}

喜欢 (0)