axios通過django的csrf驗證

來源:互聯網
上載者:User

標籤:requested   http   代碼   ret   axios   ade   word   style   reg   

django會在瀏覽器的cookie裡面儲存一項csrftoken=GvzB3ilhlgadishmascacsilreclherlkjhaklsdv3qx4M96XRG88omScDPQaKoMxJ;

這個是從django產生的,django會檢查每個http請求的headers 裡面的  X-CSRFToken 項的值是否和cookie裡面儲存的值相同,如果不相同或者缺失,就拒絕這個請求,如果相同,說明這次請求是從真實使用者發起的。

所以要做的就是在每次請求的 headers 裡面加上X-CSRFToken:csrftoken值

axios的配置代碼如下:

                //添加請求攔截器,在發送請求前攔截,對請求進行操作                this.$http.interceptors.request.use((config) => {                    config.headers[‘X-Requested-With‘] = ‘XMLHttpRequest‘;                    let regex = /.*csrftoken=([^;.]*).*$/; // 用於從cookie中匹配 csrftoken值                    config.headers[‘X-CSRFToken‘] = document.cookie.match(regex) === null ? null : document.cookie.match(regex)[1];                    return config                });                // 發送 POST 請求                this.$http({                    method: ‘post‘,                    url: ‘http://127.0.0.1:8000/user/‘,                    data: {                        username: ‘abc123‘,                        password: ‘abc123‘                    }                });

 

axios通過django的csrf驗證

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.