0

0

PHP如何实现验证码点击更换_PHP更换验证码功能【交互】

星夢妙者

星夢妙者

发布时间:2025-12-22 22:56:02

|

460人浏览过

|

来源于php中文网

原创

实现验证码刷新有五种方法:一、ajax异步更新img src;二、表单提交重生成;三、jquery简化ajax;四、vue响应式绑定;五、laravel框架集成。

php如何实现验证码点击更换_php更换验证码功能【交互】

当用户在表单中输入验证码时,若看不清或已过期,需通过点击操作即时刷新验证码图像。以下是实现该交互功能的多种方法:

一、基于AJAX异步刷新验证码图片

该方法不重载页面,仅更新验证码图片的src属性,后端生成新验证码并返回唯一标识或新图片路径,前端动态替换img标签内容。

1、在HTML中为验证码图片设置id,并绑定onclick事件:
验证码

2、编写JavaScript函数refreshVerify(),使用XMLHttpRequest发起GET请求到后端接口:
var xhr = new XMLHttpRequest();
xhr.open('GET', 'get_verify.php?r=' + Math.random(), true);

立即学习PHP免费学习笔记(深入)”;

3、监听onload事件,在响应成功后将xhr.responseURL赋值给verifyImg.src,确保浏览器不缓存旧图:
if (xhr.status === 200) { document.getElementById('verifyImg').src = xhr.responseURL; }

4、后端get_verify.php中调用session_start(),生成4位随机字符串,存入$_SESSION['captcha'],并输出PNG图像流,同时设置Header防止缓存:
header('Cache-Control: no-store, no-cache, must-revalidate, max-age=0');
header('Pragma: no-cache');
header('Content-Type: image/png');

二、通过表单提交触发验证码重生成

该方式利用传统表单提交机制,由服务器端重新渲染整个验证码区域,适用于无JavaScript支持的降级场景,且确保会话状态同步更新。

1、在HTML中将验证码图片包裹于form标签内,并添加隐藏字段标记刷新动作:

2、PHP脚本检测POST中是否存在refresh_captcha字段,若存在则清空原验证码session值:
if (isset($_POST['refresh_captcha'])) { unset($_SESSION['captcha']); }

3、在页面加载时统一调用验证码生成逻辑,无论是否提交均执行一次初始化:
if (!isset($_SESSION['captcha'])) { $_SESSION['captcha'] = generateRandomCode(4); }

4、前端img标签的src指向带时间戳参数的get_verify.php,强制每次请求为新资源:
PHP如何实现验证码点击更换_PHP更换验证码功能【交互】

三、使用jQuery简化AJAX验证码切换

借助jQuery封装的$.ajax方法降低原生XHR复杂度,提升代码可读性与兼容性,同时支持错误提示与加载状态反馈。

1、引入jQuery库并在页面底部添加script标签定义refreshCaptcha函数。

Fotor AI Image Generator
Fotor AI Image Generator

Fotor 平台的 AI 图片生成器

下载

2、使用$.get()方法请求get_verify.php,附加随机数防止缓存:
$.get('get_verify.php', { t: new Date().getTime() }, function(data, status) { ... });

3、在回调函数中获取响应头中的X-Captcha-Token(由后端PHP设置),用于后续表单校验:
var token = xhr.getResponseHeader('X-Captcha-Token');

4、将新验证码图片URL写入img元素src属性,并更新关联的隐藏输入框值(如有):
$('input[name="captcha_token"]').val(token);
$('img#verifyImg').attr('src', 'get_verify.php?t=' + new Date().getTime());

四、Vue.js响应式验证码组件方案

利用Vue的响应式数据绑定机制,将验证码图片URL设为data属性,点击按钮触发方法更新该属性,自动触发视图重绘,无需手动操作DOM。

1、在Vue实例data中声明verifyUrl字段,默认指向初始验证码接口:
data() { return { verifyUrl: 'get_verify.php' }; }

2、模板中绑定img的src为verifyUrl,并绑定click事件调用刷新方法:
PHP如何实现验证码点击更换_PHP更换验证码功能【交互】

3、methods中定义updateVerify,使用Math.random()生成新查询参数以绕过缓存:
this.verifyUrl = 'get_verify.php?t=' + Math.random();

4、为增强用户体验,可在updateVerify中添加loading状态控制,例如设置isRefreshing为true,并在v-if中隐藏原图显示加载图标:

加载中...

五、Laravel框架内置验证码刷新实现

基于laravel/framework与mews/captcha扩展包,利用其提供的Captcha::src()和route自动路由机制,通过命名路由生成新验证码URL,适配CSRF保护机制。

1、安装mews/captcha包并发布配置文件,启用session驱动存储验证码文本:
php artisan vendor:publish --provider='Mews\Captcha\CaptchaServiceProvider'

2、在web.php路由文件中注册验证码刷新路由,使用GET方法并命名:
Route::get('/captcha/{config?}', 'CaptchaController@getCaptcha')->name('captcha.refresh');

3、前端使用Laravel的route()辅助函数生成URL,并绑定到图片click事件:
PHP如何实现验证码点击更换_PHP更换验证码功能【交互】
其中captchaSrc初始值为{{ route('captcha.refresh', ['default']) }};

4、Vue组件中fetchNewCaptcha方法调用axios.get()请求命名路由,携带当前时间戳参数避免缓存,并将响应data赋值给captchaSrc:
this.captchaSrc = response.data.url + '?t=' + Date.now();

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
laravel组件介绍
laravel组件介绍

laravel 提供了丰富的组件,包括身份验证、模板引擎、缓存、命令行工具、数据库交互、对象关系映射器、事件处理、文件操作、电子邮件发送、队列管理和数据验证。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

338

2024.04.09

laravel中间件介绍
laravel中间件介绍

laravel 中间件分为五种类型:全局、路由、组、终止和自定。想了解更多laravel中间件的相关内容,可以阅读本专题下面的文章。

290

2024.04.09

laravel使用的设计模式有哪些
laravel使用的设计模式有哪些

laravel使用的设计模式有:1、单例模式;2、工厂方法模式;3、建造者模式;4、适配器模式;5、装饰器模式;6、策略模式;7、观察者模式。想了解更多laravel的相关内容,可以阅读本专题下面的文章。

686

2024.04.09

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

383

2024.04.10

laravel入门教程
laravel入门教程

本专题整合了laravel入门教程,想了解更多详细内容,请阅读专题下面的文章。

133

2025.08.05

laravel实战教程
laravel实战教程

本专题整合了laravel实战教程,阅读专题下面的文章了解更多详细内容。

82

2025.08.05

laravel面试题
laravel面试题

本专题整合了laravel面试题相关内容,阅读专题下面的文章了解更多详细内容。

72

2025.08.05

jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.09.12

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

24

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PHP课程
PHP课程

共137课时 | 12.7万人学习

JavaScript ES5基础线上课程教学
JavaScript ES5基础线上课程教学

共6课时 | 11.3万人学习

PHP新手语法线上课程教学
PHP新手语法线上课程教学

共13课时 | 1.0万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号