django项目注册页面ajax验证

ajax post方式提交时需要在 data中添加 "csrfmiddlewaretoken":$("[name=csrfmiddlewaretoken]").val()

user/url.py

urlpatterns = [
    url(r"^check_username/$",views.check_username,name="check_username"),
    url(r"^check_password/$",views.check_password,name="check_password"),
    url(r"^check_password2/$",views.check_password2,name="check_password2"),
    url(r"^check_img_code/$",views.check_img_code,name="check_img_code"),
...]

user/register.html

{% load static from staticfiles %}
<script src="{% static "book/js/jquery-1.12.4.min.js" %}"></script>

<form action="{% url "user:register" %}" method="POST" id="register_form">
{% csrf_token %}
<table>
    <tr>
        <td>用户名:</td>
        <td><input type="text" id="username" name="username" placeholder="用户名位6-10位"></td>
        <td id="username_link"></td>
    </tr>
    <tr>
        <td>密码:</td>
        <td><input type="password" id="password" name="password" placeholder="密码位6-10位"></td>
        <td id="password_link"></td>
    </tr>
    <tr>
        <td>确认密码:</td>
        <td><input type="password" id="password2" name="password2" placeholder="密码位6-10位"></td>
        <td id="password2_link"></td>
    </tr>
    <tr>
        <td> 验证码:</td>
        <td><input type="text" id="img_code" name="img_code" placeholder="请输入验证码"></td>
        <td> <img src="{% url "user:create_img_code" %}" id="create_img_code"/></td>
        <td id="code_link"></td>
    </tr>
    <tr>
        <td><input type="submit" value="注册"></td>
    </tr>
</table>
</form>
<script>
var create_img_code = document.getElementById("create_img_code")

var url = "/user/create_img_code?num="
create_img_code.onclick = function () {
    var num = new Date().getTime()
    url += num
    create_img_code.src = url
}

$(function(){
    $("#username").blur(function(){
        $.ajax({
            "url":"{% url "user:check_username" %}",

            "data":{
                    "username":$(this).val().trim()
            },
            "success":function (data) {
                $("#username_link").html("")
                $("#username_link").append(data.r_link)
            }
        })
    })
    $("#password").blur(function(){
        $.ajax({
            "url":"{% url "user:check_password" %}",
            "type":"post",
            "data":{
                    "password":$(this).val().trim(),
                    "csrfmiddlewaretoken":$("[name=csrfmiddlewaretoken]").val()
            },
            "success":function (data) {
                $("#password_link").html("")
                $("#password_link").append(data.r_link)
            }
        })
    })
    $("#password2").blur(function(){
        $.ajax({
            "url":"{% url "user:check_password2" %}",
            "type":"post",
            "data":{
                    "password":$("#password").val().trim(),
                    "password2":$(this).val().trim(),
                "csrfmiddlewaretoken":$("[name=csrfmiddlewaretoken]").val()
            },
            "success":function (data) {
                $("#password2_link").html("")
                $("#password2_link").append(data.r_link)
            }
        })
    })
})
</script>

user/views.py

def check_username(request):
    username = request.GET.get("username")
    print(username)
    for i in User.objects.all():
        if i.username == username:
            r={"r_link":"该用户名已被使用"}
            return HttpResponse(json.dumps(r, ensure_ascii=False),
                            content_type="application/json;charset=utf-8")
    else:
        if len(username)>=6 and len(username)<=10:
            r = {"r_link": "ok"}
            return HttpResponse(json.dumps(r, ensure_ascii=False),
                        content_type="application/json;charset=utf-8")
        else:
            r = {"r_link": "用户名为6-10位"}
            return HttpResponse(json.dumps(r, ensure_ascii=False),
                            content_type="application/json;charset=utf-8")


def check_password(request):
    password = request.POST.get("password")
    if len(password)>=6 and len(password)<=10:
        r = {"r_link": "ok"}
    else:
        r = {"r_link": "密码为6-10位"}
    return HttpResponse(json.dumps(r, ensure_ascii=False),
                    content_type="application/json;charset=utf-8")

def check_password2(request):
    password = request.POST.get("password")
    password2 = request.POST.get("password2")
    print(password,password2)
    if password==password2:
        r = {"r_link": "ok"}
    else:
        r = {"r_link": "两次密码不一致"}

    return HttpResponse(json.dumps(r, ensure_ascii=False),
                        content_type="application/json;charset=utf-8")

def check_img_code(request):
    img_code1 = request.GET.get("img_code")
    img_code2= request.session.get("img_code")
    print(img_code1,img_code2)
    if img_code1==img_code2:
        r = {"r_link": "ok"}
    else:
        r = {"r_link": "验证码错误"}
    return HttpResponse(json.dumps(r, ensure_ascii=False),
                        content_type="application/json;charset=utf-8")    
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 切换到创建项目的目录 cd C:\Users\admin\Desktop\DjangoProject创建名为pr...
    在努力中阅读 8,731评论 2 3
  • 此段内容简要来自自强学堂的教程详情请查询自强学堂 一、 后台的运作流程 接收request请求 处理数据 获取请求...
    coder_ben阅读 10,634评论 6 56
  • 经过对django的初步学习,我们已经对后台的基本流程以及django的运作有了一定的了解,但是这还不足够,dja...
    coder_ben阅读 9,267评论 8 34
  • 吕子乔说:“你害怕失败!每次跟女孩子说话,你总在想,要是我被拒绝了,那是多惨多没面子的事情,你怎么会成功呢!” 有...
    夏宇辰阅读 3,325评论 0 2
  • 欲寄闲情驿路远,心事花语落红残。单衣病酒莫凭栏。 二十年华风雨疏,三十更夜泪如初。梦里有个金鹧鸪。
    我是周伟阅读 2,118评论 0 1

友情链接更多精彩内容