位置: 编程技术 - 正文

php表单加入Token防止重复提交的方法分析(php access_token)

编辑:rootadmin

推荐整理分享php表单加入Token防止重复提交的方法分析(php access_token),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:php实现表单,php添加header,php表单提交两种方式,php tokenizer,php如何生成token,php如何生成token,php如何生成token,php tokenizer,内容如对您有帮助,希望把文章链接给更多的朋友!

本文实例讲述了php表单加入Token防止重复提交的方法。分享给大家供大家参考,具体如下:

Token浅谈

Token,就是令牌,最大的特点就是随机性,不可预测。一般黑客或软件无法猜测出来。

那么,Token有什么作用?又是什么原理呢?

Token一般用在两个地方——防止表单重复提交、anti csrf攻击(跨站点请求伪造)。

两者在原理上都是通过session token来实现的。当客户端请求页面时,服务器会生成一个随机数Token,并且将Token放置到session当中,然后将Token发给客户端(一般通过构造hidden表单)。下次客户端提交请求时,Token会随着表单一起提交到服务器端。

然后,如果应用于“anti csrf攻击”,则服务器端会对Token值进行验证,判断是否和session中的Token值相等,若相等,则可以证明请求有效,不是伪造的。

不过,如果应用于“防止表单重复提交”,服务器端第一次验证相同过后,会将涩session中的Token值更新下,若用户重复提交,第二次的验证判断将失败,因为用户提交的表单中的Token没变,但服务器端session中Token已经改变了。

上面的session应用相对安全,但也叫繁琐,同时当多页面多请求时,必须采用多Token同时生成的方法,这样占用更多资源,执行效率会降低。因此,也可用cookie存储验证信息的方法来代替session Token。比如,应对“重复提交”时,当第一次提交后便把已经提交的信息写到cookie中,当第二次提交时,由于cookie已经有提交记录,因此第二次提交会失败。

不过,cookie存储有个致命弱点,如果cookie被劫持(xss攻击很容易得到用户cookie),那么又一次gameover。黑客将直接实现csrf攻击。

php表单加入Token防止重复提交的方法分析(php access_token)

所以,安全和高效相对的。具体问题具体对待吧。

php表单加入Token防止重复提交

原理在于生成一个随机字符串放在session里,提交表单后来验证这个字符串,可以做到防止他人自己写form来欺骗提交,重复提交或者双击提交。

简单的用php实现的代码如下:

上面的比较简单一点的方法,下面的代码更加安全一点。

Token.php

form.php

action.php

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php程序设计安全教程》、《php安全过滤技巧总结》、《PHP运算与运算符用法总结》、《PHP网络编程技巧总结》、《PHP基本语法入门教程》、《php操作office文档技巧总结(包括word,excel,access,ppt)》、《php面向对象程序设计入门教程》、《php字符串(string)用法总结》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总》

希望本文所述对大家PHP程序设计有所帮助。

PHP中文字符串截断无乱码解决方法 一个比较好用的字符串截取函数:functionsubstring($str,$start,$length){//比较好用字符串截取函数$len=$length;if($length0){$str=strrev($str);$len=-$length;}$len=($lenstrlen($str)

php 获取文件行数的方法总结 stream_get_line获取文件行数php$file_path='xxx.txt';//文件路径$line=0;//初始化行数//打开文件$fp=fopen($file_path,'r')ordie("openfilefailure!");if($fp){//获取文件的一行内容

php基于curl实现随机ip地址抓取内容的方法 本文实例讲述了php基于curl实现随机ip地址抓取内容的方法。分享给大家供大家参考,具体如下:使用phpcurl我们可以模仿用户行为,既可以设置我们访问

标签: php access_token

本文链接地址:https://www.jiuchutong.com/biancheng/301789.html 转载请保留说明!

上一篇:php中让人头疼的浮点数运算分析(“php”)

下一篇:PHP中文字符串截断无乱码解决方法(php取字符串)

  • 实缴时间不能超过申请时间怎么办
  • 专票遗失后可以作废吗
  • 建筑行业一般纳税人增值税税率是多少
  • 电子元器件可以带上飞机吗
  • 农业企业增值税纳税实务实训心得
  • 企业之间借款利息进项税可以抵扣吗
  • 融资性售后回租承租方出售资产为什么不缴纳增值税
  • 虚开增值税普通发票罪的立案标准
  • 投资资产包括哪些会计科目
  • 超标的职工教育经费为什么是可抵扣
  • 长期股权投资收益会计处理
  • 其他应收款有什么业务
  • 抵债资产处置账务实例
  • 报销业务招待费用主题
  • 年度结转之前需要做什么
  • 公司商务卡可以日常消费
  • 收到员工的罚款钱怎么写分录
  • 结转库存什么意思
  • 钢结构制作安装合同
  • 税务季报都报啥
  • 通发票备注栏写什么内容
  • 赠送的产品需要开发票吗
  • 收到未到期的银行承兑汇票会计分录
  • printnow.exe - printnow是什么进程 有什么作用
  • 电脑怎么一键返回到桌面
  • 格式化时防止数据丢失
  • 公转私用途最好写借款
  • 事假扣款进什么科目
  • 购买预付卡如何记账
  • 金融资产包括哪三大类及会计科目
  • 点云目标检测数据集
  • 最贵的域名是什么名字
  • laravel视频教程
  • 计提费用收到发票后会计分录
  • 个税零申报流程视频教程
  • 3d点云处理算法
  • 上一年的运费发票怎么开
  • 预收物业费纳税义务发生时间
  • 公司食堂的费用分录
  • mongodb doc
  • 公司签发银行承兑汇票的行为属于什么行为
  • 股东入股资金如何记账
  • 土地入固定资产计提折旧吗
  • 事业单位退休人员判缓刑最新规定
  • 企业出现销售折扣的原因
  • 资本公积溢价转增
  • 未分配利润可以弥补亏损吗
  • 一般纳税人其他咨询服务税率
  • 小规模纳税人去银行开立什么账户
  • 会计库存商品属于什么科目
  • 销售固定资产如何申报企业所得税
  • 建筑业老项目和新项目如何计税
  • 跨年度冲红字发票怎么冲
  • 收不回来的账怎么处理
  • 利润表中财务费用中的利息费用和利息收入
  • 预收账款余额在贷方是什么意思
  • mysql服务无效
  • mysql锁表的sql
  • win10系统如何关闭窗口特效
  • xp系统怎么找回删除的文件
  • ubuntu系统怎么开机
  • win7怎么看最近访问位置
  • win7总是弹出广告怎么办
  • mcclauncher.exe
  • Linux dpkg-query 命令用法详解(Debian Linux中软件包的查询工具)
  • win10系统怎么设置最好
  • 系统闹钟设置
  • wp8.1升级10
  • 图文详解地理图册电子版
  • jquery操作html代码
  • python中OrderedDict的使用方法详解
  • Android 获取网络时间
  • python容错
  • python如何切行
  • Javascript字符串奇数位替换
  • jquery获取当前元素是第几个元素
  • 出售144平方米以内的房子
  • 发票挂失费用
  • 资源税是地方税吗
  • 烟台税务系统缴费
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设