2012-03-03 2 views
0

Я искал какое-то время для чего-то, что может помочь мне в этом.Как получить сгенерированный сгенерированный скрытый INPUT перед отправкой назад

Это пример FORM, что я хочу, смоделированный вход с завитка

<form action="http://www.website.com/login?from=login" class="lightbox_form" method="post" name="login"> 
<input name="authenticity" type="hidden" value="da1249c71258cd02a8bd038cf3ccca1c9ebef155" /> 
<input type="text" name="login_or_email" size="20" class="input" id="login"> 
<input type="password" size="20" name="login_password" class="input" id="word_user"> 
<button type="submit" class="new_submit"><span class="inner">Log In</span></button> 
</form> 

Если видите вы видите ниже

<input name="authenticity" type="hidden" value="da1249c71258cd02a8bd038cf3ccca1c9ebef155" /> 

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

Я использую CURL, но я не знаю, как получить скрытое поле и отправить обратно в том же сеансе. Пробовал использовать get_meta_tags, но не работал

set_time_limit(0); 
$http_agent = "Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.2.13) Gecko/20101203 Firefox/3.6.13 (.NET CLR 3.5.30729)"; 
$header = array(); 
$header[0] = "Accept: text/xml,application/xml,application/xhtml+xml,"; 
$header[0] .= "text/html;q=0.9,text/plain;q=0.8,image/png,*/*;q=0.5"; 
$header[] = "Cache-Control: max-age=0"; 
$header[] = "Connection: keep-alive"; 
$header[] = "Keep-Alive: 300"; 
$header[] = "Accept-Charset: ISO-8859-1,utf-8;q=0.7,*;q=0.7"; 
$header[] = "Accept-Language: en-us,en;q=0.5"; 
$header[] = "Pragma: "; // browsers keep this blank. 

curl_setopt($ch, CURLOPT_URL, "http://www.website.com/login?from=login"); 

curl_setopt($ch, CURLOPT_USERAGENT, $http_agent); 
curl_setopt($ch, CURLOPT_HTTPHEADER, $header); 
curl_setopt($ch, CURLOPT_POST, true); 
curl_setopt ($ch, CURLOPT_COOKIEJAR, ROOT_DIR.'cookies.txt'); 
curl_setopt($ch, CURLOPT_AUTOREFERER, true); 
//curl_setopt($ch, CURLOPT_POSTFIELDS, 'login_or_email=mail&login_password=pass&authenticity_token='.$cag.''); 
curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); 
curl_setopt($ch, CURLOPT_BINARYTRANSFER, true); 


$output = curl_exec($ch); 
$info = curl_getinfo($ch); 
curl_close($ch); 



//print $output; 
print_r ($output); 

Любые идеи?

ответ

1

Я считаю, что вам нужно разобрать HTML-код, возвращаемый вызовом curl_exec вручную. Библиотека curl не обрабатывает HTML для вас, она будет обрабатывать материал HTTP, но обработка данных, возвращаемых с сервера, зависит от вашего приложения.

1

Вы можете использовать pret_match(), чтобы получить значение случайной

//$html is the return of the curl request 
preg_match('/<input name="authenticity" type="hidden" value="([^"]*)" \/>/', $html, $match); 

значение будет в $ матче [1].

+0

да то будет большой, но, если я получаю случайное значение с завитком и отправить обратно с завитком, Его регенерирует с новым .. – radiaku

+0

я не понял ваш комментарий. У вас есть значение скрытого поля в $ match [1], поэтому вы можете использовать его в следующем запросе на завивки. – botzko

+0

Да, у меня уже $ match [1], но когда я снова создаю CURL, его генерация будет сгенерирована новым. Поэтому я должен получить скрытую ценность и отправить обратно в один CURL, это возможно? – radiaku

0
$regex= '/<input name="authenticity" type="hidden" value="([^"]*)" \/>/i'; 
if (preg_match($regex, $html, $list)) 
    $rand= $list[0]; 
else 
    print "Not found"; 
+0

Добро пожаловать в переполнение стека. Пожалуйста, подумайте над редактированием вашего ответа, чтобы включить объяснение относительно того, как работает ваш код, чтобы он был более полезен будущим читателям :). – Matt

Смежные вопросы