javascript - javascript 表单和 Django 存在问题

标签 javascript django post django-csrf

我浏览过并发现了与我类似的帖子,但我所拥有的一切似乎都在正常工作,所以我很困惑。

我有一个 JavaScript 片段,允许用户选择两座建筑物之一,然后根据使用的建筑物给出一组不同的选项。这是使用帖子提交按钮。到处都说它与 {% csrf_token %} 有关,但我已经将其包含在表单中,并将中间件放在 settings.py 中。如果有影响的话,同一页面上还会有一个 get 请求。

表格

<form id="formname" name="formname" method="POST" action="">{% csrf_token %}
    <table width="50%" border="0" cellspacing="0" cellpadding="5">
        <tr>
            <td width="41%" align="right" valign="middle">Category :</td>
            <td width="59%" align="left" valign="middle">
                <select name="category" id="category" onchange="javascript: dropdownlist(this.options[this.selectedIndex].value);">
                    <option value="">Select Building</option>
                    <option value="Marcus">Marcus</option>
                    <option value="Pettit">Pettit</option>
                </select>
            </td>
        </tr>
        <tr>
            <td align="right" valign="middle">Location :</td>
            <td align="left" valign="middle">
                <script type="text/javascript" language="JavaScript">
                    document.write('<select name="subcategory"><option value="">Select Location</option>   </select>')
                </script>
                <noscript>
                    <select name="subcategory" id="subcategory">
                        <option value="">Select Location</option>
                    </select>
                </noscript>
            </td>
        </tr>
        <tr>
            <td>
                <td align="left" valign="middle">
                    <input value="Inventory Safety Log" type="submit">
                </td>
        </tr>
    </table>
</form>

Javascript

<script language="javascript" type="text/javascript">
function dropdownlist(listindex) {

    document.formname.subcategory.options.length = 0;
    switch (listindex) {

        case "Marcus":
            document.formname.subcategory.options[0] = new Option("Select Location", "");
            document.formname.subcategory.options[1] = new Option("Chemical Room", "Chemicals");
            document.formname.subcategory.options[2] = new Option("Supply Room", "Supplies");
            document.formname.subcategory.options[3] = new Option("Gas Storage G205", "G205");
            document.formname.subcategory.options[4] = new Option("In-Organic Sub Fab G230", "G230");
            document.formname.subcategory.options[5] = new Option("Gas Bunker", "Gas Bunker");
            break;
        case "Pettit":
            document.formname.subcategory.options[0] = new Option("Select Location", "");
            document.formname.subcategory.options[1] = new Option("Chemical Room", "Chemicals");
            document.formname.subcategory.options[2] = new Option("Supply Room", "Supplies");
            document.formname.subcategory.options[3] = new Option("Utility Chase #19", "19");
            document.formname.subcategory.options[4] = new Option("Utility Chase #25", "25");
            document.formname.subcategory.options[5] = new Option("Utility Chase #29", "29");
            document.formname.subcategory.options[6] = new Option("Utility Chase #30", "30");
            document.formname.subcategory.options[7] = new Option("Utility Chase #36", "36");
            document.formname.subcategory.options[8] = new Option("Utility Chase #44", "44");
            document.formname.subcategory.options[9] = new Option("Gas Cage", "Gas Cage");
            document.formname.subcategory.options[10] = new Option("Bunker", "Bunker");
            break;
    }
    return true;
}

</script>

感谢您提供任何意见、建议、提示或见解。

主要问题是,当我尝试发布表单时,它会将我带到 csrf 验证失败页面。

最佳答案

由于动态篡改表单数据,您遇到了问题。您需要使用django forms来干净地处理它。现在,您可以使用csrf_exempt装饰器作为临时解决方法

关于javascript - javascript 表单和 Django 存在问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17550753/

相关文章:

python - Django:模型索引太慢

javascript - 在提交之前检查 javascript 中的 django 表单错误的最佳方法是什么?

c++ - Qt等待POST完成

javascript - Webview Javascript 在 Android 7.0 及更高版本中不起作用

javascript - JQuery 循环闪烁图像

javascript - 将文本区域中的 "+"更改为 &lt;input type ='checkbox' >

javascript - 如何使用 jquery 添加/删除图像?

python - 使用 Django-orm 查询多个对象

android - Volley - 阻塞方式的http请求

php - 带有过多嵌套字符串引号的 Post 参数