【Django】Django验证码插件Django-simple-captcha自定义样式,以及通过ajax发送验证码数据

一、简单安装配置

1、安装django-simple-captcha

pip install django-simple-captcha

2、将captcha 添加到setting.py文件中的installed_apps里面

INSTALLED_APPS = [
    'django.contrib.admin',
    'django.contrib.auth',
    'django.contrib.contenttypes',
    'django.contrib.sessions',
    'django.contrib.messages',
    'django.contrib.staticfiles',
    'captcha',
]

3、将captcha配置在url.py文件中

from django.conf.urls import url,include
urlpatterns = [
    ……
    url(r'^captcha/', include('captcha.urls')), 
]

4、迁移同步,生成captcha所依赖的表

python manage.py migrate

 

二、使用

1、将captcha字段在form类中进行设置

from captcha.fields import CaptchaField
class UserRegisterForm(forms.Form):
	……
   captcha = CaptchaField()

2、在后台逻辑当中,get请求里面实例化我们的form,将form对象返回到页面

def user_register(request):
	if request.method == 'GET':
		user_register_form = UserRegisterForm()
		return render(request,'register.html',{'user_register_form':user_register_form})

3、在页面上通过{{ form.captcha}} 获取验证码

<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <form action="">
        {{ form_obj.captcha}}
    </form> 
</body>
</html>

效果如下图所示

如果想要修改布局,可以自己定义css样式改,也可以在配置中进行修改。

 

三、修改布局属性

官方文档:https://django-simple-captcha.readthedocs.io/en/latest/usage.html

1、修改布局(调整输入框和图片的位置)

我们只需要在setting.py文件中添加CAPTCHA_OUTPUT_FORMAT属性

text_field是文本框,image时图片,这个hidden_field是隐藏属性,随便放哪个位置不影响,保存的是这个验证码的id。

2、修改input的属性

官方文档写到,我们可以重新写一个模板,将该模板的路径赋予给CAPTCHA_FIELD_TEMPLATE这个属性,这个属性也和上面添加的CAPTCHA_OUTPUT_FORMAT属性一样定义在settings.py中。 所以我们可以写一个模板,然后赋予属性就可以了。

这边我们将模板定义在了templates/captcha路径下。

<!--text_field.html-->
<input class='user_input' id="id_captcha_1" name="captcha_1" placeholder='验证码' placeholder-data="验证码" />

3、修改样式

用id选择器选择验证码输入框默认的id"#id_captcha_1",用类选择器选择验证码图片默认的class".captcha"。然后自己去改样式吧。

 

四、用ajax传包含验证码的表单数据

js

var login_data = { "email" :$("#email").val(), "password":("#password").val(),  "captcha_0": $("#id_captcha_0").val(), "captcha_1": $("#id_captcha_1").val()};  

$.ajax({
    type: "POST",
    contentType: "application/json; charset=utf-8",
    headers: { "X-CSRFToken": {{ csrf_token }} },
    url: "/login/",
    dataType: "json",
    cache: false,
    data: JSON.stringify(login_data),
    error: function () {
        ShowErrorMessage("登录失败!");
    },
    success: function (data) {
        if (null != data && "" != data) {
            alert(data);
        }
    }
});

view

def post(self, request):

    data = json.loads(request.body)
    login_form = LoginForm(data)

    if login_form.is_valid():
        email_account = data["email"]
        pass_word =data["password"]

 

五、用Ajax刷新验证码

//点击验证码刷新
$(function() {
    $('.captcha').css({
        'cursor': 'pointer'
    })
    // ajax 刷新
    $('.captcha').click(function () {
        console.log('click');
        $.getJSON("/captcha/refresh/",
            function (result) {
                $('.captcha').attr('src', result['image_url']);
                $('#id_captcha_0').val(result['key']);
            }
        );
    });
});

 

参考:

1、http://django-simple-captcha.readthedocs.io/en/latest/usage.html#installation

2、https://blog.csdn.net/weixin_41227756/article/details/102580816

3、https://blog.csdn.net/tanzuozhev/article/details/50458688

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Django中使用django-simple-captcha生成验证码可以通过以下步骤现: 1. 安装django-simple-captcha库: 在终端中运行以下命令安装django-simple-captcha库: ``` pip install django-simple-captcha ``` 2. 在Django项目的`settings.py`文件中添加`captcha`应用: 打开`settings.py`文件,找到`INSTALLED_APPS`列表,将`'captcha'`添加到其中。 3. 运行数据库迁移: 在终端中运行以下命令,将`captcha`应用的数据库迁移到你的项目中: ``` python manage.py migrate captcha ``` 4. 在需要生成验证码的表单中添加验证码字段: 在你的表单类中导入`CaptchaField`,并将其作为一个字段添加到表单中。例如: ```python from captcha.fields import CaptchaField class MyForm(forms.Form): # 其他字段... captcha = CaptchaField() ``` 5. 在视图函数中验证验证码: 在你的视图函数中,可以通过调用`form.is_valid()`来验证验证码是否正确。例如: ```python def my_view(request): if request.method == 'POST': form = MyForm(request.POST) if form.is_valid(): # 验证码正确,执行相应的逻辑 # ... else: # 验证码错误,处理错误信息 # ... else: form = MyForm() return render(request, 'my_template.html', {'form': form}) ``` 6. 在模板中显示验证码输入框: 在你的模板文件中,可以通过`form.captcha`来渲染验证码输入框。例如: ```html <form method="post"> {% csrf_token %} {{ form.as_p }} <button type="submit">提交</button> </form> ``` 这样,你就可以在Django中使用django-simple-captcha生成验证码了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值