網(wǎng)站首頁 編程語言 正文
程序運行前加載
1.導(dǎo)包前面加下劃線,運行前加載
2.把要加載的寫在init函數(shù)里面
路由設(shè)置
路由的作用:根據(jù)不同的請求指定不同的控制器
路由函數(shù):
beego.Router("/path",&controller.MainController{})
函數(shù)參數(shù):
先分析一下Url地址由哪幾部分組成?
http://192.168.110.71:8080/index
http://地址:端口/資源路徑
第一個參數(shù):資源路徑,也就是 / 后面的內(nèi)容
第二個參數(shù):需要指定的控制器指針
了解上面的內(nèi)容之后我們來看幾個簡單的例子:
beego.Router("/", &controllers.MainController{}) beego.Router("/index", &controllers.IndexController{}) beego.Router("/login", &controllers.LoginController{})
高級路由設(shè)置
一般在開發(fā)過程中,我們基本不使用beego提供的默認(rèn)請求訪問方法,都是自定義相應(yīng)的方法。那我們來看一下如何來自定義請求方法。
自定義請求方法需要用到Router的第三個參數(shù)。這個參數(shù)是用來給不同的請求指定不同的方法。具體有如下幾種情況。
一個請求訪問一個方法(也是最常用的),請求和方法之間用 : 隔開,不同的請求用 ; 隔開:
beego.Router("/simple",&SimpleController{},"get:GetFunc;post:PostFunc")
可以多個請求,訪問一個方法 ,請求之間用 , 隔開,請求與方法之間用 : 隔開:
beego.Router("/api",&RestController{},"get,post:ApiFunc")
所有的請求訪問同一個方法,用 * 號代表所有的請求,和方法之間用 : 隔開:
beego.Router("/api/list",&RestController{},"*:ListFood")
如果同時存在 * 和對應(yīng)的 HTTP請求,那么優(yōu)先執(zhí)行 HTTP請求所對應(yīng)的方法,例如同時注冊了如下所示的路由:
beego.Router("/simple",&SimpleController{},"*:AllFunc;post:PostFunc")
那么當(dāng)遇到 Post 請求的時候,執(zhí)行 PostFunc 而不是 AllFunc。
如果用了自定義方法之后,默認(rèn)請求將不能訪問。
beego-ORM初始化
ORM-----對象關(guān)系映射
安裝ORM+導(dǎo)包
go get github.com/astaxie/beego/orm import "github.com/astaxie/beego/orm"
定義結(jié)構(gòu)體
相當(dāng)于django中的model類
type User struct{ Id int Name string PassWord string }
beego支持的數(shù)據(jù)庫
mysql,sqlite3,postgersql
驅(qū)動如下:
import ( _ "github.com/go-sql-driver/mysql" _ "github.com/lib/pq" _ "github.com/mattn/go-sqlite3" )
連接數(shù)據(jù)庫
用RegisterDataBase()函數(shù),第一個參數(shù)為數(shù)據(jù)庫別名,也可以理解為數(shù)據(jù)庫的key值,項目中必須有且只能有一個別名為 default 的連接,第二個參數(shù)是數(shù)據(jù)庫驅(qū)動,這里我們用的MySQL數(shù)據(jù)庫,所以以MySQL驅(qū)動為例,第三個參數(shù)是連接字符串,和傳統(tǒng)操作數(shù)據(jù)庫連接字符串一樣
格式為:用戶名:密碼@tcp(ip:port)/數(shù)據(jù)庫名稱?編碼方式
代碼如下:
orm.RegisterDataBase("default","mysql","root:@tcp(127.0.0.1:3306)/class1? charset=utf8")
注意:ORM只能操作表,不能操作數(shù)據(jù)庫,所以我們連接的數(shù)據(jù)庫要提前在MySQL終端創(chuàng)建好。
注冊數(shù)據(jù)庫表
用orm.RegisterModel()函數(shù),參數(shù)是結(jié)構(gòu)體對象,如果有多個表,可以用 , 隔開,多new幾個對象:
orm.RegisterModel(new(User))
生成表
用orm.RunSyncdb()函數(shù),這個函數(shù)有三個參數(shù),
第一個參數(shù)是數(shù)據(jù)庫的別名和連接數(shù)據(jù)庫的第一個參數(shù)相對應(yīng)。
第二個參數(shù)是是否強制更新,一般我們寫的都是false,如果寫true的話,每次項目編譯一次數(shù)據(jù)庫就會被清空一次,fasle的話會在數(shù)據(jù)庫發(fā)生重大改變(比如添加字段)的時候更新數(shù)據(jù)庫。
第三個參數(shù)是用來說,生成表過程是否可見,如果我們寫成課件,那么生成表的時候執(zhí)行的SQL語句就
會在終端看到。反之看不見。代碼如下:
orm.RunSyncdb("default",false,true)
完整案例
import "github.com/astaxie/beego/orm" type User struct { Id int Name string Passwd string } func init(){ //1.連接數(shù)據(jù)庫 orm.RegisterDataBase("default","mysql","root:123456@tcp(127.0.0.1:3306)/test?charset=utf8") //2.注冊表 orm.RegisterModel(new(User)) // 3.生成表 // 1.數(shù)據(jù)庫別名 // 2.是否強制更新 // 3.創(chuàng)建表過程是否可見 orm.RunSyncdb("default",false,true) }
因為這里我們把ORM初始化的代碼放到了 models包的init()函數(shù)里面,所以如果我們想讓他執(zhí)行的話就需要在main.go里面加入這么一句代碼:
import _ "classOne/models"
ORM增刪改查
在執(zhí)行ORM的操作之前需要先把ORM包導(dǎo)入,但是GoLand會自動幫我們導(dǎo)包,也可以手動導(dǎo)包
go get github.com/astaxie/beego/orm import "github.com/astaxie/beego/orm"
插入
先獲取一個ORM對象,用orm.NewOrm()即可獲得
o := orm.NewOrm() var user User //定義一個要插入數(shù)據(jù)庫的結(jié)構(gòu)體對象 user.Name = "itcast" //給定義的對象賦值 user.Passwd = "heima" //執(zhí)行插入操作,o.Insert()插入,參數(shù)是結(jié)構(gòu)體對象,返回值是插入的id和錯誤信息。 id, err := o.Insert(&user) if err == nil { fmt.Println(id) }
注意:這里不用給Id賦值,因為建表的時候我們沒有指定主鍵,ORM默認(rèn)會以變量名為Id,類型為int的字段當(dāng)主鍵
查詢
查詢,用o.Read(),第一個參數(shù)是對象地址,第二個參數(shù)是指定查詢字段,返回值只有錯誤信息。
o := orm.NewOrm() //1.要先獲得一個ORM對象 var user User //2.定義一個要獲取數(shù)據(jù)的結(jié)構(gòu)體對象 user.Name = "itcast" //3.給結(jié)構(gòu)體對象賦值,相當(dāng)于給查詢條件賦值 err := o.Read(&user,"Name") //4.查詢,用o.Read() if err != nil{ beego.Info("查詢數(shù)據(jù)錯誤",err) return }
注意:如果查詢字段是查詢對象的主鍵的話,可以不用指定查詢字段
更新
執(zhí)行更新操作,用o.Update()函數(shù),參數(shù)是結(jié)構(gòu)體對象指針,返回值是更新的條目數(shù)和錯誤信息
o := orm.NewOrm() //1.要先獲得一個ORM對象 var user User //2.定義一個要獲取數(shù)據(jù)的結(jié)構(gòu)體對象 user.Name = "itcast" //3.給結(jié)構(gòu)體對象賦值,相當(dāng)于給查詢條件賦值 err := o.Read(&user) //4.查詢更新的數(shù)據(jù)是否存在 if err != nil{ beego.Info("查詢數(shù)據(jù)錯誤",err) return } user.Name = "jeff" //5.如果查找到了要更新的對象,就給這個對象賦新值 count,err=o.Update(&user) //6. 更新操作 if err != nil{ beego.Info("更新數(shù)據(jù)錯誤",err) return }
刪除
執(zhí)行刪除操作,用的方法是o.Delete(),參數(shù)是刪除的結(jié)構(gòu)體對象,返回值是刪除的條目數(shù)和錯誤信息
o := orm.NewOrm() //1.要先獲得一個ORM對象 var user User //2.定義一個要獲取數(shù)據(jù)的結(jié)構(gòu)體對象 user.Id = 1 //3.給結(jié)構(gòu)體對象賦值,相當(dāng)于給查詢條件賦值 num, err := o.Delete(&User{Id: 1}) if err == nil { fmt.Println(num) }
案例
注冊
在router.go文件的init()函數(shù)中加下面這行代碼: 路由文件
beego.Router("/register1", &controllers.MainController{})
Controllers/default.go業(yè)務(wù)邏輯中:
func (c *MainController) Get() { c.Data["data"] = "get請求" c.TplName = "register.html" } func (c *MainController) Post() { c.Data["name"] = "jeff" c.TplName = "register.html" userName := c.GetString("userName") passwd := c.GetString("passwd") beego.Info("用戶名",userName) beego.Info("密碼",passwd) if userName != "" || passwd != ""{ c.Redirect("/login",400) } c.TplName = "register.html" }
Views/register.html視圖文件中:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>注冊</title>
</head>
<body>
<div style="position:absolute;left:50%; top:50%;">
<form action="/register1" method="post"> 用戶名:<input type="text" name="userName">
<p></p> 密碼:<input type="password" name="passwd">
<p></p> <input type="submit" value="注冊">
</form>
</div>
</body>
</html>
案例2
路由:
beego.Router("/addAritcle", &controllers.MainController{},"post:AddAritcle;get:Index")
default業(yè)務(wù)邏輯:
func (c*MainController) AddAritcle() { c.Data["name"] = c.GetString("userName") c.Data["pwd"] = c.GetString("passwd") beego.Info("用戶名:",c.Data["name"]) beego.Info("密碼",c.Data["pwd"]) c.TplName = "success.html" } func (c*MainController) Index() { c.TplName = "addArticle.html" }
view視圖
addArticle.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>成功</title>
</head>
<body>
<p style="font-size: 70px;color: brown">成功!!!</p>
<p>用戶名:{{.name}}</p>
<p>密碼:{{.pwd}}</p>
</body>
</html>
Success.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>成功</title>
</head>
<body>
<p style="font-size: 70px;color: brown">成功!!!</p>
<p>用戶名:{{.name}}</p>
<p>密碼:{{.pwd}}</p>
</body>
</html>
原文鏈接:https://www.cnblogs.com/guyouyin123/p/14041606.html
相關(guān)推薦
- 2022-05-06 Python學(xué)習(xí)之循環(huán)方法詳解_python
- 2022-08-15 Python類的定義繼承調(diào)用比較方法技巧_python
- 2022-03-23 Redis的六種底層數(shù)據(jù)結(jié)構(gòu)(小結(jié))_Redis
- 2022-06-17 使用Python解決常見格式圖像讀取nii,dicom,mhd_python
- 2022-09-18 Redis6?主從復(fù)制及哨兵機制的實現(xiàn)_Redis
- 2022-04-30 C/C++編程語言中的指針(pointer)你了解嗎_C 語言
- 2022-07-09 Python如何將數(shù)字變成帶逗號的千分位_python
- 2022-11-04 Linux下自動刪除過期備份和自動異地備份的腳本_linux shell
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支