Проблема с токеном cURL X-CSRF

0

У меня есть этот PHP-прокси, используя cURL (ниже). Всякий раз, когда он получает POST заголовок X-CSRF имеет значение null. Маркер X-CSRF является единственной разницей в заголовке POST между использованием прокси и нет.

Поэтому мне интересно, как это сделать, чтобы токен X-CSRF настроен правильно, как без использования прокси-сервера?

$ch = curl_init();
curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Windows NT 6.3; WOW64; rv:34.0) Gecko/20100101 Firefox/34.0');

$browserRequestHeaders = getallheaders();
$curlRequestHeaders = array();
foreach ($browserRequestHeaders as $name => $value) {
  $curlRequestHeaders[] = $name . ": " . $value;
}
curl_setopt($ch, CURLOPT_HTTPHEADER, $curlRequestHeaders);


switch ($_SERVER["REQUEST_METHOD"]) {
  case "POST":
    curl_setopt($ch, CURLOPT_POST, TRUE);
    curl_setopt($ch, CURLOPT_POSTFIELDS, file_get_contents("php://input"));
  break;
  case "PUT":
    curl_setopt($ch, CURLOPT_PUT, TRUE);
    curl_setopt($ch, CURLOPT_INFILE, fopen("php://input"));
  break;
}

//Other cURL options.
curl_setopt($ch, CURLOPT_HEADER, TRUE);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, TRUE);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
curl_setopt ($ch, CURLOPT_FAILONERROR, TRUE);
curl_setopt($ch, CURLOPT_NOBODY, 0);

// Cookie cURL options.
curl_setopt ($ch, CURLOPT_COOKIEJAR, $ckfile); 
curl_setopt ($ch, CURLOPT_COOKIEFILE, $ckfile);

//handle other cookies cookies
foreach ($_COOKIE as $k=>$v) {
  if(is_array($v)){
    $v = serialize($v);
  }
    curl_setopt($ch,CURLOPT_COOKIE,"$k=$v; domain=.$cookiedomain ; path=/");
  }

// Set the request URL.
curl_setopt($ch, CURLOPT_URL, $url);

// Make the request.
$response = curl_exec($ch);
curl_setopt($ch, CURLOPT_POST, 0);
$responseInfo = curl_getinfo($ch);
$headerSize = curl_getinfo($ch, CURLINFO_HEADER_SIZE);
curl_close($ch);

Изображение с заголовками http://i.stack.imgur.com/78fVV.jpg

Теги:
csrf
curl
proxy

2 ответа

0
Лучший ответ

Должен проксировать идентификатор $_SESSION между клиентом и серверами в php.

1

Вы используете вызовы AJAX, и, как показывает ваше изображение, заголовок X-CSRF-Token не устанавливается на этих вызовах. Вы должны установить его явно, как описано в разделе Добавление заголовка X-CSRF-Token глобально ко всем экземплярам XMLHttpRequest(); , например, с (скопированным оттуда):

(function() {
var send = XMLHttpRequest.prototype.send,
    token = $('meta[name=csrf-token]').attr('content');
XMLHttpRequest.prototype.send = function(data) {
    this.setRequestHeader('X-CSRF-Token', token);
    return send.apply(this, arguments);
};
}());

Поэтому исправление не в PHP, а в коде AJAX. Заменить token = $('meta[name=csrf-token]').attr('content'); с кодом, который получает токен CSRF из вашего HTML.

  • 0
    $ ('Meta [name = csrf-token]'). Attr ('content'); также содержит ноль.
  • 0
    да, как предложено в редактировании: вам нужно заменить это кодом, который работает с реальным HTML, который у вас есть; вам нужно будет посмотреть исходный код HTML, который возвращается с веб-сайта, чтобы найти подходящий элемент для вашего варианта использования
Показать ещё 1 комментарий

Ещё вопросы

Сообщество Overcoder
Наверх
Меню