Skip to content
Nasimi Mamedov edited this page Aug 7, 2023 · 1 revision

CSRF

Сross Site Request Forgery ( межсайтовая подделка запроса )

Когда юзер заходит на сайт, созданный злоумышленником, от его лица может быть отправлен запрос на другой сервер, на котором юзер аутентифицирован

CSRF-атака возможна только в том случае, если сервер не требует обязательного включения в запрос подтверждения со стороны юзера, которое не может подделано атакующим скриптом

Для защиты от CSRF-атак можно использовать заголовок X-CSRF-TOKEN

  • Токен должен быть предоставлен сервером
  • Его можно записать в куки на клиенте
  • При отправке запроса можно добавить заголовок X-CSRF-TOKEN со значением токена, предоставленным сервером

При получении ( POST - PUT - DELETE ) запроса сервер проверяет заголовок X-CSRF-TOKEN, и если значение не совпадает с токеном клиента или заголовок отсутствует, запрос отклоняется

var xhr = new XMLHttpRequest()
xhr.open (
    "POST",
    'http://ptsv2.com/t/mbkkong/post', true
)

xhr.setRequestHeader (
    "Content-Type",
    "application/x-www-form-urlencoded"
)
xhr.setRequestHeader(
    "X-CSRF-TOKEN",
    "AIJu7NUduZPGo-7uZ"
)

xhr.onreadystatechange = function() {
    if( this.readyState === 4 && this.status === 200 ) {
         console.log ( 'success' )
         console.log ( this.responseText )
    }
}
xhr.send ( "name=mbkkong&speciality=frontEnd" )

© Nasimi Mamedov 2018

Курсы были созданы для студентов A-Level Ukraine.

Использование данных материалов или любой их части коммерческими школами ( курсами ) является нарушением авторских прав.

A-Level Ukraine


1 2 3 4 5
6 7 8 9 10
11 12 13 14 15
16 17 18 19

Занятие 1

⤵️

Занятие 2

⤴️ ⤵️

Занятие 3

⤴️ ⤵️

Занятие 4

⤴️ ⤵️

Занятие 5

⤴️ ⤵️

Занятие 6

⤴️ ⤵️

Занятие 7

⤴️ ⤵️

Занятие 8

⤴️ ⤵️

Занятие 9

⤴️ ⤵️

Занятие 10

⤴️ ⤵️

Занятие 11

⤴️ ⤵️

Занятие 12

⤴️ ⤵️

Занятие 13

⤴️ ⤵️

Занятие 14

⤴️ ⤵️

Занятие 15

⤴️ ⤵️

Занятие 16

⤴️ ⤵️

Занятие 17

⤴️ ⤵️

Занятие 18

⤴️ ⤵️

Занятие 19

⤴️ ⤵️

⤴️

ico20 Дополнительно
dir-20 Справочная инфо

Clone this wiki locally