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" οnclick="login()">登陆</button>
<button class="btn btn-default" οnclick="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> 下一章讲布局页面