`
化蝶自在飞
  • 浏览: 2333425 次
  • 性别: Icon_minigender_2
  • 来自: 武汉
社区版块
存档分类
最新评论

thinkphp表单令牌错误的解决方法

 
阅读更多
把 {__NOTOKEN__} 加到模板里就行了.

令牌验证
ThinkPHP新版内置了表单令牌验证功能,可以有效防止表单的远程提交等安全防护。

表单令牌验证相关的配置参数有:

'TOKEN_ON'=>true,  // 是否开启令牌验证

'TOKEN_NAME'=>'__hash__',    // 令牌验证的表单隐藏字段名称

'TOKEN_TYPE'=>'md5',  //令牌哈希验证规则默认为MD5

如果开启表单令牌验证功能,系统会自动在带有表单的模板文件里面自动生成以TOKEN_NAME为名称的隐藏域,其值则是TOKEN_TYPE方式生成的哈希字符串,用于实现表单的自动令牌验证。

自动生成的隐藏域位于表单Form结束标志之前,如果希望自己控制隐藏域的位置,可以手动在表单页面添加{__TOKEN__} 标识,系统会在输出模板的时候自动替换。如果在开启表单令牌验证的情况下,个别表单不需要使用令牌验证功能,可以在表单页面添加{__NOTOKEN__},则系统会忽略当前表单的令牌验证。

如果页面中存在多个表单,建议添加{__TOKEN__}标识,并确保只有一个表单需要令牌验证。

模型类在创建数据对象的同时会自动进行表单令牌验证操作,如果你没有使用create方法创建数据对象的话,则需要手动调用模型的autoCheckToken方法进行表单令牌验证。如果返回false,则表示表单令牌验证错误。例如:

$User = M("User"); // 实例化User对象

// 手动进行令牌验证

if (!$User->autoCheckToken($_POST)){

// 令牌验证错误

}
分享到:
评论

相关推荐

    ThinkPHP表单令牌错误的相关解决方法分析

    在处理ThinkPHP表单令牌错误时,开发者通常会遇到几种常见情况及其对应的解决方法。首先,错误提示“表单令牌错误”可能是因为令牌验证没有通过。根据网络上的建议,开发人员首先尝试清空缓存,包括删除Cache目录下...

    ThinkPHP下表单令牌错误与解决方法分析

    在本文中,我们将深入探讨ThinkPHP表单令牌的原理、配置、错误原因以及如何解决这些问题。 ### 表单令牌的原理 表单令牌的工作流程如下: 1. **生成令牌**:服务器在生成表单时,会生成一个唯一的令牌并将其存储...

    ThinkPHP5.1表单令牌Token失效问题的解决

    ThinkPHP出于安全的考虑增加了表单令牌Token,由于通过Ajax异步更新数据仅仅部分页面刷新数据,就导致了令牌Token不能得到更新,紧接着的第二次新建或更新数据(提交表单时)失败——不能通过令牌的验证。...

    thinkphp商城活动倒计时+表单令牌验证

    两个计时器:活动开始前倒计时和活动开始后结束前倒计时,并且在计时器页面提供按钮在活动不同状态同一按钮指向不同页面.同时还有活动时间设置页面可以自由设置活动时间, ...表单令牌验证,简单的小demo.

    thinkphp3.2 防止表单重复提交

    在Web开发中,防止表单重复提交是一个重要的问题,它能确保用户操作的...ThinkPHP 3.2 的表单令牌机制提供了一种简便且安全的解决方案。在实际开发中,应结合项目需求选择合适的防重策略,确保用户体验和数据安全性。

    ThinkPHP完全帮助文档

    ThinkPHP表单令牌设计.chm ThinkPHP多语言的使用和配置.chm ThinkPHP多元化缓存机制.chm ThinkPHP类库导入和自动加载.chm ThinkPHP模板指南.chm ThinkPHP数据操作指南.chm API帮助文档: ThinkPHP-2.0-API.chm ....

    thinkPhp 资料大全---下载不扣分,回帖加1分,欢迎下载,童叟无欺

    ThinkPHP 基于角色的权限控制.chm ThinkPHP 错误调试和日志.chm ... ThinkPHP表单令牌设计.chm ThinkPHP视图模型(1).chm ThinkPHP视图模型.chm ThinkPHP配置指南和参考.chm ThinkPHP项目自动生成和编译.chm

    Think php 的技術手冊

    ThinkPHP表单令牌设计 ThinkPHP常见问题集合 ThinkPHP多语言的使用和配置 ThinkPHP多元化缓存机制 ThinkPHP关联操作 ThinkPHP可配置的静态缓存设计 ThinkPHP类库导入和自动加载 ThinkPHP模板指南 ThinkPHP配置指南和...

    ThinkPHP令牌验证实例

    在ThinkPHP中,表单令牌验证功能的配置通过在配置文件中设置相关参数来实现,主要包括以下几个参数: 1. `TOKEN_ON`:这是一个布尔类型的配置项,用于开启或关闭令牌验证功能。设置为 `true` 时开启,设置为 `false...

    ThinkPHP防止重复提交表单的方法实例分析

    本文将详细讲解如何在ThinkPHP框架中防止表单重复提交,通过实例分析提供三种有效的方法。 1. **页面重定向**: 当用户成功提交表单后,不返回当前页面,而是通过服务器端的重定向(Redirect)技术跳转到其他页面...

    ThinkPHP表单数据智能写入create方法实例分析

    【ThinkPHP表单数据智能写入create方法实例分析】 在ThinkPHP框架中,表单数据的智能写入是通过`create()`方法实现的。这个方法能够自动收集前端表单提交的数据,并创建一个数据对象,无需手动构建入库的数据集。这...

    thinkPHP中create方法与令牌验证实例浅析

    在ThinkPHP框架中,create方法与令牌验证的结合使用,为开发者提供了一种简便的方式来增加表单的安全性。Create方法是ThinkPHP中Model类的一个常用方法,用于创建数据模型实例,并在验证数据无误后将其写入数据库。...

    thinkPHP自动验证、自动添加及表单错误问题分析

    要解决令牌错误,需要在表单中使用`token()`方法生成一个令牌,并在处理表单提交的控制器方法中使用`checkToken()`方法来验证这个令牌。 自动添加无效的问题往往与`create()`方法的使用有关。`create()`方法用于...

    ThinkPHP自动验证失败的解决方法

    当遇到自动验证失败但`$DB->getError()`没有返回错误信息,或者在ThinkPHP 2.1版本中出现“令牌表单错误”的问题,这可能是由于以下几个原因: 1. **令牌验证未开启**:ThinkPHP的自动验证包含了防止重复提交的令牌...

Global site tag (gtag.js) - Google Analytics