File tree Expand file tree Collapse file tree 2 files changed +3
-3
lines changed Expand file tree Collapse file tree 2 files changed +3
-3
lines changed Original file line number Diff line number Diff line change 2
2
3
3
不知道你是否曾经看到过一个论坛或者博客,在一个帖子或者文章后面出现多条重复的记录,这些大多数是因为用户重复递交了留言的表单引起的。由于种种原因,用户经常会重复递交表单。通常这只是鼠标的误操作,如双击了递交按钮,也可能是为了编辑或者再次核对填写过的信息,点击了浏览器的后退按钮,然后又再次点击了递交按钮而不是浏览器的前进按钮。当然,也可能是故意的——比如,在某项在线调查或者博彩活动中重复投票。那我们如何有效的防止用户多次递交相同的表单呢?
4
4
5
- 解决方案是在表单中添加一个带有唯一值的隐藏字段。在验证表单时,先检查带有该惟一值的表单是否已经递交过了 。如果是,拒绝再次递交;如果不是,则处理表单进行逻辑处理。另外,如果是采用了Ajax模式递交表单的话,当表单递交后,通过javascript来禁用表单的递交按钮。
5
+ 解决方案是在表单中添加一个带有唯一值的隐藏字段。在验证表单时,先检查带有该唯一值的表单是否已经递交过了 。如果是,拒绝再次递交;如果不是,则处理表单进行逻辑处理。另外,如果是采用了Ajax模式递交表单的话,当表单递交后,通过javascript来禁用表单的递交按钮。
6
6
7
7
我继续拿4.2小节的例子优化:
8
8
``` html
15
15
<input type =" hidden" name =" token" value =" {{.}}" >
16
16
<input type =" submit" value =" 登陆" >
17
17
```
18
- 我们在模版里面增加了一个隐藏字段` token ` ,这个值我们通过MD5(时间戳)来获取惟一值 ,然后我们把这个值存储到服务器端(session来控制,我们将在第六章讲解如何保存),以方便表单提交时比对判定。
18
+ 我们在模版里面增加了一个隐藏字段` token ` ,这个值我们通过MD5(时间戳)来获取唯一值 ,然后我们把这个值存储到服务器端(session来控制,我们将在第六章讲解如何保存),以方便表单提交时比对判定。
19
19
``` Go
20
20
21
21
func login (w http .ResponseWriter , r *http .Request ) {
Original file line number Diff line number Diff line change 1
1
# 6.4 预防session劫持
2
- session劫持是一种广泛存在的比较严重的安全威胁,在session技术中,客户端和服务端通过session的标识符来维护会话, 但这个标识符很容易就能被嗅探到,从而被其他人利用. 它是中间人攻击的一种类型。
2
+ session劫持是一种广泛存在的比较严重的安全威胁,在session技术中,客户端和服务端通过session的标识符来维护会话, 但这个标识符很容易就能被嗅探到,从而被其他人利用。 它是中间人攻击的一种类型。
3
3
4
4
本节将通过一个实例来演示会话劫持,希望通过这个实例,能让读者更好地理解session的本质。
5
5
## session劫持过程
You can’t perform that action at this time.
0 commit comments