热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Go语言Web开发(7)cookie的使用

为了确定整个WEB操作过程中,哪些连接是跟同一用户有关,我们一般都会使用cookie和session。cookie作用于客户端,把用户数据保存在客户端,session是一种服务器端

为了确定整个WEB操作过程中,哪些连接是跟同一用户有关,我们一般都会使用COOKIE和session。COOKIE作用于客户端,把用户数据保存在客户端,session是一种服务器端的机制,给每一位用户分配唯一的sessionID:要么通过url传递,要么保存在客户端的COOKIEs里,或者保存到数据库中。

COOKIE:在用户通过客户端发送请求给服务端时,服务端就会将赋值COOKIE,并将这个COOKIE保存到客户端,等到用户访问服务器上的其他页面时,就会一起将COOKIE和请求发送到服务器,从而完成验证。

session:在服务端与客户端建立联系后,就会在服务端为客户端创建唯一的sessionID并保存在客户端上。客户端再次访问网站时就会通过sessionID获取内容,这样就可以避免在握手或者传输中暴露用户真实密码。

Go语言中通过net/http包中的SetCOOKIE来设置:

// SetCOOKIE将Set-COOKIE标头添加到提供的ResponseWriter标头中。
//提供的COOKIE必须具有有效的名称。 无效的COOKIE可能会被静默删除。
//ResponseWriter 表示要写入的response,COOKIE是一个struct, 表示在Set-COOKIE标头中发送的HTTP COOKIE
func SetCOOKIE(w ResponseWriter, COOKIE *COOKIE) {
if v := COOKIE.String(); v != "" {
w.Header().Add("Set-COOKIE", v)
}
}

COOKIE的结构示意如下所示:

type COOKIE struct {
Name string
Value string
Path string // 可选
Domain string // 可选
Expires time.Time // 可选
RawExpires string // 仅用于阅读COOKIEs
// MaxAge = 0表示未指定“Max-Age”属性。
// MaxAge <0表示现在删除COOKIE,相当于'Max-Age:0'
// MaxAge> 0表示存在Max-Age属性,以秒为单位给出
MaxAge int
Secure bool
HttpOnly bool
Raw string
Unparsed []string // 未解析的属性 - 值对的原始文本
}

Go设置COOKIE

COOKIE := http.COOKIE{Name: "COOKIEname", Value: "testCOOKIEvalue", Path: "/", MaxAge: 86400}
http.SetCOOKIE(w, &COOKIE)

Go读取COOKIE

COOKIE, err := req.COOKIE("COOKIEname")

Go删除COOKIE

COOKIE := http.COOKIE{Name: "COOKIEname", Path: "/", MaxAge: -1}
http.SetCOOKIE(w, &COOKIE)

下面是一个Go测试COOKIE的小例子

package main
import "net/http"
func main() {
http.HandleFunc("/readCOOKIE", ReadCOOKIE)
http.HandleFunc("/writeCOOKIE", WriteCOOKIE)
http.HandleFunc("/deleteCOOKIE", DeleteCOOKIE)
http.ListenAndServe(":9090", nil)
}
func WriteCOOKIE(w http.ResponseWriter,r *http.Request) {
//创建新的本地COOKIE
COOKIE := http.COOKIE{Name:"localCOOKIE",Value:"GoLang",Path:"/",MaxAge:86400}
http.SetCOOKIE(w,&COOKIE)
w.Write([]byte("设置COOKIE成功"))
}
func ReadCOOKIE(w http.ResponseWriter,r *http.Request) {
//读取COOKIE
COOKIE,err := r.COOKIE("localCOOKIE")
if err == nil {
COOKIEValue := COOKIE.Value
//将数据写入http连接中
w.Write([]byte("COOKIE的值为:"+COOKIEValue))
}else {
w.Write([]byte("读取COOKIE出错:"+err.Error()))
}
}
func DeleteCOOKIE(w http.ResponseWriter,r *http.Request) {
COOKIE := http.COOKIE{Name:"localCOOKIE",Path:"/",MaxAge:-1}
http.SetCOOKIE(w,&COOKIE)
w.Write([]byte("<删除COOKIE成功"))
}

预防session劫持,有以下三种方式
①sessionID的值只允许COOKIE设置,而不是通过URL重置方式设置,同时设置COOKIE的httponly为true,这个属性是设置是否可通过客户端脚本访问这个设置的COOKIE,第一这个可以防止这个COOKIE被XSS读取从而引起session劫持,第二COOKIE设置不会像URL重置方式那么容易获取sessionID

②每个请求里面加上token,实现类似前面章节里面讲的防止form重复递交类似的功能,我们在每个请求里面加上一个隐藏的token,然后每次验证这个token,从而保证用户的请求都是唯一性。

③给session额外设置一个创建时间的值,一旦过了一定的时间,我们销毁这个sessionID,重新生成新的session,这样可以一定程度上防止session劫持的问题。

createtime := sess.Get("createtime")
if createtime == nil {
sess.Set("createtime", time.Now().Unix())
//判断每次请求是否过期(这里设置了60秒)定期生成新的ID
} else if (createtime.(int64) + 60) <(time.Now().Unix()) {
globalSessions.SessionDestroy(w, r)
sess = globalSessions.SessionStart(w, r)
}

参考书籍:《Go Web编程》


推荐阅读
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 关键词:Golang, Cookie, 跟踪位置, net/http/cookiejar, package main, golang.org/x/net/publicsuffix, io/ioutil, log, net/http, net/http/cookiejar ... [详细]
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 本文介绍了如何在给定的有序字符序列中插入新字符,并保持序列的有序性。通过示例代码演示了插入过程,以及插入后的字符序列。 ... [详细]
  • Go Cobra命令行工具入门教程
    本文介绍了Go语言实现的命令行工具Cobra的基本概念、安装方法和入门实践。Cobra被广泛应用于各种项目中,如Kubernetes、Hugo和Github CLI等。通过使用Cobra,我们可以快速创建命令行工具,适用于写测试脚本和各种服务的Admin CLI。文章还通过一个简单的demo演示了Cobra的使用方法。 ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • 本文讨论了一个关于cuowu类的问题,作者在使用cuowu类时遇到了错误提示和使用AdjustmentListener的问题。文章提供了16个解决方案,并给出了两个可能导致错误的原因。 ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 在重复造轮子的情况下用ProxyServlet反向代理来减少工作量
    像不少公司内部不同团队都会自己研发自己工具产品,当各个产品逐渐成熟,到达了一定的发展瓶颈,同时每个产品都有着自己的入口,用户 ... [详细]
  • 本文介绍了在多平台下进行条件编译的必要性,以及具体的实现方法。通过示例代码展示了如何使用条件编译来实现不同平台的功能。最后总结了只要接口相同,不同平台下的编译运行结果也会相同。 ... [详细]
  • Android开发实现的计时器功能示例
    本文分享了Android开发实现的计时器功能示例,包括效果图、布局和按钮的使用。通过使用Chronometer控件,可以实现计时器功能。该示例适用于Android平台,供开发者参考。 ... [详细]
  • Go GUIlxn/walk 学习3.菜单栏和工具栏的具体实现
    本文介绍了使用Go语言的GUI库lxn/walk实现菜单栏和工具栏的具体方法,包括消息窗口的产生、文件放置动作响应和提示框的应用。部分代码来自上一篇博客和lxn/walk官方示例。文章提供了学习GUI开发的实际案例和代码示例。 ... [详细]
author-avatar
mobiledu2502887507
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有