接着之前的内容,前面已经讲过很多Golang的基础语法,mysql的使用,redis的使用,也讲了orm框架,如何创建一个webapi 服务等等,感兴趣的可以看看以前的文章,https://www.cnblogs.com/zhangweizhong/category/1275863.html,

今天要来说一说,如何用beego开发web应用。

介绍

beego 是一个快速开发 Go 应用的 HTTP 框架,他可以用来快速开发 API、Web 及后端服务等各种应用,是一个 RESTful 的框架,同时也是一个关注度和使用量都比价高的开源项目。我认为它是go初学者比较容易上手的一门MVC Web框架。

它是由国内团队开发的开源框架,文档基本都是中文,简单易懂。

安装

  需要安装 Beego 和 Bee 的开发工具:

$ go get github.com/astaxie/beego
$ go get github.com/beego/bee

  注意:

  1. beege和bee是两个概念。beego是框架,bee是工具,是命令。
  2. 在安装Beego前,先确认是否将$GOPATH/bin写入GO环境中。

创建应用

  创建一个名为webDemo的应用

$ bee new webDemo     //创建一个web应用
$ bee api webDemo     //创建一个api应用

 

编译运行

  进入webDemo目录中,执行bee run,就会完成编译、运行:

$ bee run

   

  成功后,打开浏览器访问:http://localhost:8080,可以看到如图:

开发

  以上就beego 的安装和运行简单的介绍完了,下面我们就通过订单查询和新增的例子来学习学习如何用beego开发web应用。

  一般的 beego 项目的目录如下所示:

├── conf           //配置文件
│   └── app.conf
├── controllers    //控制器
│   └── default.go
├── main.go
├── models         //模型
│   └── models.go
├── routers       //路由
│   └──router.go
├── static         //静态文件
│   ├── css
│   ├── ico
│   ├── img
│   └── js
└── views          //界面└── index.tpl

conf

  在app.conf 中增加数据库连接配置

appname = webDemo
httpport = 8080
runmode = devDBConn="root:root@tcp(localhost:3306)/zwz_test?charset=utf8"

controller

  在controller目录下,增加pay.go

package controllersimport ("webDemo/models"
)func (c *MainController) PayQuery() {AccountID, _ := c.GetInt64("AccountID1")payment, _ := models.GetPaymenRec(AccountID)c.Data["AccountID"] = payment.AccountIDc.Data["PartnerID"] = payment.PartnerIDc.Data["UserID"] = payment.UserIDc.Data["CreateTime"] = payment.CreateTimec.Data["Amount"] = payment.Amountc.Data["OuterTradeNo"] = payment.OuterTradeNoc.Data["Remark"] = payment.Remarkc.Data["Status"] = payment.Statusc.Data["Msg"] = payment.Msgc.TplName = "query.html"
}
func (c *MainController) PayAdd() {var payment models.PaymentRecordStrc.ParseForm(&payment)pay, _ := models.AddPaymenRec(payment)c.Data["AccountID"] = pay.AccountIDc.Data["PartnerID"] = pay.PartnerIDc.Data["UserID"] = pay.UserIDc.Data["CreateTime"] = pay.CreateTimec.Data["Amount"] = pay.Amountc.Data["OuterTradeNo"] = pay.OuterTradeNoc.Data["Remark"] = pay.Remarkc.TplName = "query.html"
}

models

  1. 在models目录下,增加pay.go

package modelsimport ("database/sql""errors""strconv""time""github.com/astaxie/beego"_ "github.com/go-sql-driver/mysql"
)var Db *sql.DBtype PaymentRecord struct {Id           int64AccountID    int64PartnerID    string UserID string CreateTime string Amount float64 OuterTradeNo string Remark string Status int Msg string } type PaymentRecordStr struct { AccountID string PartnerID string UserID string CreateTime string Amount string OuterTradeNo string Remark string } func init() { dbconn := beego.AppConfig.String("DBConn") db, err := sql.Open("mysql", dbconn) if err != nil { return } db.SetMaxOpenConns(2000) db.SetMaxIdleConns(0) db.Ping() Db = db } func Close() { if Db != nil { Db.Close() } } func AddPaymenRec(rec PaymentRecordStr) (PaymentRecord, error) { var isql = "INSERT pay_demo SET account_id=?,partner_id=?,user_id=?,amount=?,outer_tradeno=?,remark=?" AccountID, _ := strconv.ParseInt(rec.AccountID, 10, 64) Amount, _ := strconv.ParseFloat(rec.Amount, 64) response := PaymentRecord{0, AccountID, rec.PartnerID, rec.UserID, rec.CreateTime, Amount, rec.OuterTradeNo, rec.Remark, 0, ""} if Db == nil { return response, errors.New("AddPaymenRec connect mysql failed") } stmt, _ := Db.Prepare(isql) defer stmt.Close() beego.Informational("AddPaymenRec rec=%#v", rec) res, err := stmt.Exec(AccountID, rec.PartnerID, rec.UserID, Amount, rec.OuterTradeNo, rec.Remark) if err == nil { response.Id, _ = res.LastInsertId() response.Status = 1 response.Msg = "已生效" return response, nil } return response, nil } func GetPaymenRec(AccountID int64) (PaymentRecord, error) { var qsql = "SELECT * FROM pay_demo WHERE account_id=?" var response PaymentRecord response.Msg = "失败" if AccountID != 0 { if Db == nil { return response, errors.New("GetPaymenRec connect mysql failed") } stmt, _ := Db.Prepare(qsql) rows, err := stmt.Query(AccountID) defer rows.Close() if err != nil { return response, err } var timedate string for rows.Next() { err = rows.Scan(&response.Id, &response.AccountID, &response.PartnerID, &response.UserID, &timedate, &response.Amount, &response.OuterTradeNo, &response.Remark) if err != nil { return response, err } DefaultTimeLoc := time.Local loginTime, err := time.ParseInLocation("2006-01-02 15:04:05", timedate, DefaultTimeLoc) if err == nil { unix_time := loginTime.Unix() //time to int64 response.CreateTime = time.Unix(unix_time, 0).Format("2006-01-02 15:04:05") response.Status = 2 response.Msg = "成功" return response, err } else { return response, err } } return response, nil } return response, errors.New("GetPaymenRec Requset is non porinter") }

   2. 在数据库中,增加pay_demo表

CREATE TABLE `pay_demo` (`id` int(64) NOT NULL AUTO_INCREMENT,`account_id` int(64) NOT NULL,`partner_id` varchar(50) CHARACTER SET utf8 DEFAULT NULL,`user_id` varchar(50) CHARACTER SET utf8 DEFAULT NULL,`create_time` datetime DEFAULT CURRENT_TIMESTAMP,`amount` double DEFAULT '0',`outer_tradeno` varchar(50) CHARACTER SET utf8 DEFAULT NULL,`remark` varchar(255) CHARACTER SET utf8 DEFAULT NULL,PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5024 DEFAULT CHARSET=utf8 COLLATE=utf8_bin;

views

  将原有的index.tpl 删除,增加新的index.html 和query.html

index.html

<!DOCTYPE html><html>
<head><title>webDemo</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head><body>
<div><form action="/query" method="Post"><div>GetPaymentBy AccountID:<input  type="text" name="AccountID1" /></div><div><input type= "submit" name="n" /></div></form><br/><br/><form action="/add" method="Post"><div>AccountID:<input  type="text" name="AccountID" /></div><div>PartnerID:<input  type="text" name="PartnerID" /></div><div>UserID   :<input  type="text" name="UserID" /></div><div>CreateTime:<input  type="text" name="CreateTime" /></div><div>Amount:<input  type="text" name="Amount" /></div><div>OuterTradeNo:<input  type="text" name="OuterTradeNo" /></div><div>Remark:<input  type="text" name="Remark" /></div><div><input type= "submit" name="add" value="添加"/></div></form></div>
</body>
</html>

query.html

<!DOCTYPE html><html>
<head><title>BeegoDemo</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8">
</head><body><div>        <div>Payment:</div><div>AccountID:{{.AccountID}}</div><div>PartnerID:{{.PartnerID}}</div><div>UserID:{{.UserID}}</div><div>CreateTime:{{.CreateTime}}</div><div>Amount:{{.Amount}}</div><div>        OuterTradeNo:{{.OuterTradeNo}}</div><div>Remark:{{.Remark}}</div></div>
</body>
</html>

routers

  在router.go 中增加以上新增的2个路由

package routersimport ("webDemo/controllers""github.com/astaxie/beego"
)func init() {beego.Router("/query", &controllers.MainController{}, "Post:PayQuery")        // 新增PayQuery路由beego.Router("/add", &controllers.MainController{}, "Post:PayAdd")       // 新增PayAdd路由beego.Router("/", &controllers.MainController{})
}

重新运行

  增加完以上代码之后,重新运行webDemo应用,就可以看到我们新增加的订单查询和新增订单的功能。

最后

  1. 以上就把beego 的安装给介绍完了。同时也通过简单的订单支付的例子,介绍如何使用beego 开发web应用。

·  2. 这里只是对beego 做一个最基本的介绍,想要详细了解beego 的各种功能,可以去它的官网:https://beego.me 

   3. 完整例子下载:webDemo

转载于:https://www.cnblogs.com/zhangweizhong/p/10919672.html

Golang 入门系列(十三)用Beego开发web应用相关推荐

  1. eslint vscode 自动格式化_Vue 入门系列第二期,开发环境与 ESLint 配置

    引言 开发 Vue 项目前,做好开发环境的相关配置非常重要,它可以提高我们的开发效率. 在「Vue 入门系列」第一期,新手快速入门指南,初识 Vue 一期中,我们利用 Vue CLI 搭建了项目骨架, ...

  2. Golang 入门系列(十一)Go语言实现webapi

    之前,已经讲过很多Golang的东西,比如基础语法,mysql的使用,redis的使用等等,感兴趣的可以看看以前的文章,https://www.cnblogs.com/zhangweizhong/ca ...

  3. golang(5)使用beego 开发 api server 和前端同学拆分开发,使用swagger

    1,beego api Swagger 是一个规范和完整的框架,用于生成.描写叙述.调用和可视化 RESTful 风格的 Web 服务.整体目标是使client和文件系统作为服务器以相同的速度来更新. ...

  4. VBS 请求WebAPI接口_从零开始实现简单的webapi框架【Golang 入门系列十一】

    之前,已经讲过很多Golang的东西,比如基础语法,mysql的使用,redis的使用等等,感兴趣的可以看看以前的文章,https://www.cnblogs.com/zhangweizhong/ca ...

  5. 爱上开源之golang入门至实战-使用IDE开发Golang

    使用IDE开发Golang 上一节,使用文本编辑器,我们开启了golang之旅,除了通过文本编辑器的方式来进行程序开发,我们还可以通过使用golang的集成开发环境工具(IDE)来进行更高效率,更快速 ...

  6. Golang 入门系列(十) mysql数据库的使用

    之前,已经讲过一些Golang的基础的东西,感兴趣的可以看看以前的文章,https://www.cnblogs.com/zhangweizhong/category/1275863.html, 今天简 ...

  7. 入门系列-在AspNet Core MVC Web Application中使用ABP

    本教程将介绍如何开始以最少的依赖关系开始使用ABP开发. 通常情况下你需要下载一个 启动模板 创建一个新项目 使用Visual Studio创建一个空的AspNet Core Web Applicat ...

  8. Golang 入门系列(九) 如何读取YAML,JSON,INI等配置文件...

    实际项目中,读取相关的系统配置文件是很常见的事情.今天就来说一说,Golang 是如何读取YAML,JSON,INI等配置文件的. 1. json使用 JSON 应该比较熟悉,它是一种轻量级的数据交换 ...

  9. qpython3编辑器怎么用_Python快速入门系列:Pyqt5界面开发好帮手-Qss样式编辑器介绍...

    Python + Pyqt5界面开发时,总是需要考虑美化界面,QssStylesheetEditor 是一个功能强大的 Qt 样式表(QSS)编辑器,支持实时预览,自动提示,自定义变量. 功能简介 Q ...

  10. PWA(Progressive Web App)入门系列:(五)Web Worker

    前言 在说Service Worker前有必要说一下Web Worker,因为Service Worker本身就属于Web Worker的延伸,大部分功能也是基于Web Worker进行的扩展. 背景 ...

最新文章

  1. bat脚本如何自动输入y_Linux系统如何设置开机自动运行脚本?
  2. Vue之动态class写法总结
  3. 网易邮箱开通imap服务器,网易邮箱率先全面默认开通IMAP服务
  4. MySQL MyISAM/InnoDB高并发优化经验
  5. python3 新式类_python新式类和旧式类区别
  6. Spring 实践 -AOP
  7. 在docker for win中使用portainer管理容器
  8. [转]Eclipse创建Maven项目
  9. python怎么获取word文档的章节_python读取word文档的方法
  10. Mac可以在Dock上监视磁盘活动
  11. md5是什么_全民小视频视频修改md5有什么用6
  12. 无人驾驶路径规划之RRT算法
  13. 低版本内核编译奇怪错误
  14. SDS新书的来龙去脉 amp;amp; SDS序言 - 倪光南:众筹出书也是一种创新
  15. android 名片识别软件,手机名片识别工具Android名片全能王评测
  16. 电脑桌面的快捷方式的字体有背景颜色,怎么修改?
  17. 正负数排列(用链表和数组实现)
  18. webpack配置指定文件不打包
  19. phpstudy+opencart搭建商城网站基本环境
  20. 04刘笑维-05刘洪雨-实训一

热门文章

  1. scrapy[skp]快速入门
  2. Python项目开发基础 -- 函数参数与数据库连接参数
  3. java多继承_为什么 Java 不支持类多重继承?
  4. js base64编码_使用psd.js将PSD转成SVG -- 基础篇(文字amp;图片)
  5. 打log的方式检查程序里面的问题 及示例代码 详解
  6. java_泛型方法使用实例
  7. list.h双循环链表的实现,拷贝自Linux内核(2.6.20.1)
  8. GPS时钟模块授时仪 与 同步时钟,1PPS
  9. TurboFan-Sea of Nodes概念讲解
  10. 深度学习打造精准推荐系统,细说国美互联网 AI 发展的进击之路