Beego 学习笔记14:Session控制
Session控制
1> Session常用来作为全局变量使用,比如记录当前登录的用户,或者页面之间传递数据使用.
2> Beego框架内置了 session 模块,目前 session 模块支持的后端引擎包括 memory、cookie、file、mysql、redis、couchbase、memcache、postgres,用户也可以根据相应的 interface 实现自己的引擎。若是使用标红的部分,需要再下载对应的session包。
3> 在main.go代码中添加启用session方法。具体代码如下:
package main import ( "fmt" "github.com/astaxie/beego/orm" _ "BeegoLearn/routers" "github.com/astaxie/beego" ) //初始化 func init(){ dbhost := beego.AppConfig.String("dbhost") dbport := beego.AppConfig.String("dbport") dbuser := beego.AppConfig.String("dbuser") dbpassword := beego.AppConfig.String("dbpassword") db := beego.AppConfig.String("db") //注册mysql Driver orm.RegisterDriver("mysql", orm.DRMySQL) //构造conn连接 //用户名:密码@tcp(url地址)/数据库 conn := dbuser + ":" + dbpassword + "@tcp(" + dbhost + ":" + dbport + ")/" + db + "?charset=utf8" //注册数据库连接 orm.RegisterDataBase("default", "mysql", conn) fmt.Printf("数据库连接成功!%s\n", conn) } func main() { o := orm.NewOrm() o.Using("default") // 默认使用 default,你可以指定为其他数据库 //启用Session beego.BConfig.WebConfig.Session.SessionOn = true beego.Run() }
4> 新建一个login.go控制器,编写session的逻辑业务
package controllers import ( "fmt" "github.com/astaxie/beego" ) type LoginController struct { beego.Controller } //登录页面 func (c *LoginController) Get() { c.TplName = "login.html" } //登录功能 func (c *LoginController) Post() { name:=c.GetString("name") pwd:=c.GetString("pwd") islogin:=0 if name=="admin" && pwd=="123456"{ c.SetSession("loginuser", "adminuser") fmt.Println("当前的session:") fmt.Println(c.CruSession) }else if name!="admin"{ islogin=1 }else if pwd!="123456"{ islogin=2 } c.Data["json"]=map[string]interface{}{"islogin":islogin}; c.ServeJSON(); } //退出 type LogoutController struct { beego.Controller } //登录退出功能 func (c *LogoutController) Post() { v := c.GetSession("loginuser") islogin:=false if v != nil { //删除指定的session c.DelSession("loginuser") //销毁全部的session c.DestroySession() islogin=true fmt.Println("当前的session:") fmt.Println(c.CruSession) } c.Data["json"]=map[string]interface{}{"islogin":islogin}; c.ServeJSON(); }
5> 新建一个Login.html页面,作为展示使用
<!DOCTYPE html> <html> <head> <title>首页 - 用户列表页面</title> <link rel="shortcut icon" href="/static/img/favicon.png" /> <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.css"/> <script type="text/javascript" src="/static/js/jquery-2.1.1.min.js"></script> <script type="text/javascript" src="/static/bootstrap/js/bootstrap.min.js"></script> </head> <body> <div class="container"> <div class="form-group"> <label for="text">用户名:</label> <input type="text" class="form-control" id="name" placeholder="用户名"> </div> <div class="form-group"> <label for="text">密码:</label> <input type="text" class="form-control" id="pwd" placeholder="密码"> </div> <div class="form-group"> <button class="btn btn-primary" onclick="login()">登陆</button> <button class="btn btn-default" onclick="logout()">退出</button> </div> <div> <label id="status"></label> </div> </div> <!--JS部分--> <script type="text/javascript"> //登陆功能 function login(){ $.ajax({ type:'post', url:'/Home/Login', data:{ "name":$("#name").val(), "pwd":$("#pwd").val() }, success:function(result){ if(result.islogin==0){ $("#status").html("登陆成功") }else if(result.islogin==1){ $("#status").html("用户名错误") } else if(result.islogin==2){ $("#status").html("密码错误") } } }) } //登出功能 function logout(){ $.ajax({ type:'post', url:'/Home/Logout', data:{}, success:function(result){ if(result.islogin){ $("#status").html("登出成功"); }else { $("#status").html("登出失败"); } } }) } </script> </body> </html>
6> 在路由中添加控制器,编译项目,测试运行
package routers import ( "BeegoLearn/controllers" "github.com/astaxie/beego" ) func init() { //默认的 beego.Router("/", &controllers.MainController{}) //JS分页 beego.Router("/Home/PageData", &controllers.UserController{}) beego.Router("/Home/PageNextData", &controllers.YonghuController{}) //Bootstrap运用 beego.Router("/Home/Index", &controllers.PageController{}) //Easyui使用 beego.Router("/Home/EasyUI", &controllers.EasyUIController{}) beego.Router("/Home/EasyUIData", &controllers.EasyUIDataController{}) //文件的上传下载 beego.Router("/Home/FileOpt", &controllers.FileOptUploadController{}) beego.Router("/Home/FileDown", &controllers.FileOptDownloadController{}) //文件的创建,写入,读取,删除 beego.Router("/Home/FileRead", &controllers.ReadController{}) beego.Router("/Home/FileWrite", &controllers.WriteController{}) beego.Router("/Home/FileCreate", &controllers.CreateController{}) beego.Router("/Home/FileDelete", &controllers.DeleteController{}) //Api接口部分 beego.Router("/api/Html", &controllers.ApiController{}) beego.Router("/api/GetJson", &controllers.ApiJsonController{}) beego.Router("/api/GetXml", &controllers.ApiXMLController{}) beego.Router("/api/GetJsonp", &controllers.ApiJsonpController{}) beego.Router("/api/GetDictionary", &controllers.ApiDictionaryController{}) beego.Router("/api/GetParams", &controllers.ApiParamsController{}) //session部分 beego.Router("/Home/Login", &controllers.LoginController{}) beego.Router("/Home/Logout", &controllers.LogoutController{}) }
7> 运行结果如下
7-1》页面的初始效果如下:
7-2》输入用户名,密码,点击登陆按钮
7-3》点击退出按钮
8>我的Beego学习笔记这个项目的代码已经上传到GitHub上面。具体的地址如下:https://github.com/weiyunhelong/BeegoLearn
下载下来之后,记得将mysql数据库的配置文件进行相应的修改,不然项目编译时通不过的哟!
9> 下一章讲布局页面