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")    
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 157,298评论 4 360
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 66,701评论 1 290
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 107,078评论 0 237
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,687评论 0 202
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,018评论 3 286
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,410评论 1 211
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,729评论 2 310
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,412评论 0 194
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,124评论 1 239
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,379评论 2 242
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 31,903评论 1 257
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,268评论 2 251
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 32,894评论 3 233
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,014评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,770评论 0 192
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,435评论 2 269
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,312评论 2 260

推荐阅读更多精彩内容

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