weixin_49095187 2023-03-29 13:29 采纳率: 33.3%
浏览 23
已结题

Django下使用captcha_refresh 不能实现动态刷新

  • 写回答

1条回答 默认 最新

  • Yamerger 2023-03-29 13:58
    关注

    在 Django 中使用 captcha_refresh 不能实现动态刷新,可能是因为 captcha_refresh 只是一个视图函数,并没有实现在前端实时刷新验证码的逻辑。

    要实现动态刷新验证码,可以使用 AJAX 技术,通过前端 JS 脚本定时请求获取新的验证码图片,并更新到页面中。以下是一个简单的示例:

    在 Django 视图函数中,返回一个 JSON 数据,其中包含一个新的验证码图片地址和一个新的验证码 key:

    
    ```python
    
    import json
    from captcha.models import CaptchaStore
    
    def refresh_captcha(request):
        captcha = CaptchaStore.generate_key()
        captcha_url = captcha.url()
        data = {'key': captcha, 'image_url': captcha_url}
        return JsonResponse(data)
    在前端页面中,使用 jQuery 或其他 JS 库发送 AJAX 请求,并将返回的 JSON 数据中的验证码图片地址和 key 更新到页面上:
    javascript
    
    $(document).ready(function() {
        $('#refresh-captcha').click(function() {
            $.ajax({
                url: '/refresh-captcha/',
                dataType: 'json',
                success: function(data) {
                    $('#captcha-image').attr('src', data.image_url);
                    $('#id_captcha_0').val(data.key);
                }
            });
        });
    });
    
    
    

    ```
    其中,#refresh-captcha 是一个按钮,用于触发 AJAX 请求;#captcha-image 是一个图片元素,用于显示验证码图片;#id_captcha_0 是一个隐藏表单元素,用于保存新的验证码 key。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 3月30日
  • 已采纳回答 3月29日
  • 创建了问题 3月29日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度