原来的token是每个页面对应一个session来存放__hash__值,
我的每个页面头部都有一个登录框,用户每访问一个页面就会产生一个token,如果用户一直不提交,那么token就不会自动销毁(除非session过期)。
一个解决方案是通过配置文件,关闭令牌,只有在需要的视图中打开配置参数。
但是我觉得我的网站不需要同时多个页面同时提交表单,而且我使用了session db hander扩展,内存表的char字段长度是有限制的,不可能无限存放那么多token。
所以我决定让用户只能保留一个token。
这样做还有一个好处,可以避免用户多个页面同时提交,刷回复什么的
ThinkPHP/lib/Behavior/TokenBuildBehavior.class.php
搜索// 创建表单令牌<br>
private function buildToken() {<br>
$tokenName = C('TOKEN_NAME');<br>
$tokenType = C('TOKEN_TYPE');<br>
if(!isset($_SESSION[$tokenName])) {<br>
$_SESSION[$tokenName] = array();<br>
}<br>
// 标识当前页面唯一性<br>
$tokenKey = md5($_SERVER['REQUEST_URI']);<br>
if(isset($_SESSION[$tokenName][$tokenKey])) {// 相同页面不重复生成session<br>
$tokenValue = $_SESSION[$tokenName][$tokenKey];<br>
}else{<br>
$tokenValue = $tokenType(microtime(TRUE));<br>
$_SESSION[$tokenName][$tokenKey] = $tokenValue;<br>
}<br>
$token = '<input>';<br>
return $token;<br>
}
改为:// 创建表单令牌<br>
private function buildToken() {<br>
$tokenName = C('TOKEN_NAME');<br>
$tokenType = C('TOKEN_TYPE');<br>
// if(!isset($_SESSION[$tokenName])) {<br>
// $_SESSION[$tokenName] = array();<br>
// }<br>
$_SESSION[$tokenName]=array();//生成令牌前清空已有令牌。<br>
// 标识当前页面唯一性<br>
$tokenKey = md5($_SERVER['REQUEST_URI']);<br>
if(isset($_SESSION[$tokenName][$tokenKey])) {// 相同页面不重复生成session<br>
$tokenValue = $_SESSION[$tokenName][$tokenKey];<br>
}else{<br>
$tokenValue = $tokenType(microtime(TRUE));<br>
$_SESSION[$tokenName][$tokenKey] = $tokenValue;<br>
}<br>
$token = '<input>';<br>
return $token;<br>
}
这样就可以了。
AD:真正免费,域名+虚机+企业邮箱=0元

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

VSCode Windows 64비트 다운로드
Microsoft에서 출시한 강력한 무료 IDE 편집기

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

DVWA
DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는
