以一种形式对多个按钮进行POST Ajax

时间:2019-11-09 13:23:33

标签: javascript jquery html django ajax

我正在创建一种表单,该表单具有AuthLogin按钮,计划分别在下面处理发送OTP和检查OTP是否有效的情况。

我正在使用下面的代码关注这个Process a Form Submit with Multiple Submit Buttons in Javascript,但是当我获得任何按钮时,javascript似乎无法正常工作,并且我无法获得任何console.log值。浏览器上没有错误。

otplogin.html

    <div id="otplogin">
     <form class="form-horizontal" id="getotp" >
          {% csrf_token %} 
            <div class="control-group">
                <label class="control-label" for="username">Username</label>
                <div class="controls">
                    <input type="text" id="username" name="username"  placeholder="Username">
                </div>
            </div>
            <div class="control-group">
                <div class="controls">
                    <button type="submit" value='auth'  class="btn">Auth</button>
                </div>
            </div>
        <div class="control-group">
            <label class="control-label" for="otp">OTP</label>
            <div class="controls">
                <input type="otp" name="otp" id="otp" placeholder="OTP">
            </div>
        </div>
        <div class="control-group">
            <div class="controls">
                <button type="submit" value='login'  class="btn">Login</button>
            </div>
        </div>
        </form>
    </div>
<script type="text/javascript">
(function () {  //the browser said the '$' as in the linked answer can not be recognized
$("#getotp btn").click(function (ev) {
        ev.preventDefault() 
        if ($(this).attr("value") == "auth") {
            console.log("CHECK 1");
            $.ajax({
                type:'POST',
                url:'/getotp2',
                data:{
                    username:$('#username').val()
                    ,csrfmiddlewaretoken: $('input[name=csrfmiddlewaretoken]').val()
                },
                success: function server_response(response) {
                console.log('POST1 success')
                }
            });
        }
        else if ($(this).attr("value") == "login") {
            console.log("CHECK 2");
            $.ajax({
                type:'POST',
                url:'/otplogin',
                data:{
                    username:$('#username').val(),
                    otp:$('#otp').val(),
                    csrfmiddlewaretoken: $('input[name=csrfmiddlewaretoken]').val()
                },
               success: function server_response(response) {
                console.log('POST2 success')
                }
            });
        }
    });
});

</script>

views.py

def otplogin(request):
    if request.POST:
        otpentered=request.POST.get('otp','')
        if otpentered==otp:
            return redirect('/main')
    return render(request,'esearch/otplogin.html')

def getotp2(request):
    logout(request)
    username = otp = ''
    if request.POST:
        username = request.POST.get('username','')
        otp = pyotp.TOTP('base32secret3232').now()
        OTPEmail('You Auth',username,[],'Your auth is '+otp)
        print ('POST'+username)
        print ('POST'+otp)
        return JsonResponse(json.dumps({'username':username,'otp':otp}),safe=False)

对此表示感谢

1 个答案:

答案 0 :(得分:1)

您的选择有误:

(function(){
$("#getotp btn").click(function (ev){...});}

更改为:

$(document).ready(function(){
$(".btn").click(function(ev){...});});

$("#getotp .control-group .controls .btn").click(...