Estou tentando usar o phantomJS (que ferramenta incrível é essa!) Para enviar um formulário para uma página para a qual tenho credenciais de logon e depois enviar o conteúdo da página de destino para o stdout. Consigo acessar o formulário e definir seus valores com êxito usando o phantom, mas não sei ao certo qual é a sintaxe correta para enviar o formulário e gerar o conteúdo da página subseqüente. O que tenho até agora é:
var page = new WebPage();
var url = phantom.args[0];
page.open(url, function (status) {
if (status !== 'success') {
console.log('Unable to access network');
} else {
console.log(page.evaluate(function () {
var arr = document.getElementsByClassName("login-form");
var i;
for (i=0; i < arr.length; i++) {
if (arr[i].getAttribute('method') == "POST") {
arr[i].elements["email"].value="[email protected]";
arr[i].elements["password"].value="mypassword";
// This part doesn't seem to work. It returns the content
// of the current page, not the content of the page after
// the submit has been executed. Am I correctly instrumenting
// the submit in Phantom?
arr[i].submit();
return document.querySelectorAll('html')[0].outerHTML;
}
}
return "failed :-(";
}));
}
phantom.exit();
}
javascript
forms
post
phantomjs
Vijay Boyapati
fonte
fonte
setInterval
uso internovar func = steps[testindex]
, entãoconsole.log("step " + (testindex + 1) + ": " + funcName(func))
. Isso permite adicionar descrição às etapas que estão sendo executadas.funcName
. Também achei mais fácil ao passar por uma série de páginas da web e tentar técnicas diferentes, renderizar a última página usandopage.render("output.png");
.COOKIE
e minha pergunta é: * este cookie está disponível nophantom.cookies
objeto quando o servidor retorna a resposta * ?Além disso, o CasperJS fornece uma ótima interface de alto nível para navegação no PhantomJS, incluindo clicar em links e preencher formulários.
CasperJS
Atualizado para adicionar artigo de 28 de julho de 2015 comparando PhantomJS e CasperJS .
(Obrigado ao comentarista Sr. M!)
fonte
#someid
para preencher com base em um ID.Enviar solicitações POST brutas às vezes pode ser mais conveniente. Abaixo você pode ver o exemplo original post.js do PhantomJS
fonte
GET
solicitações de maneira semelhante (fazendo algo parecidopage.open(server, 'get', data, ...
) não funcionará.Como mencionado acima, o CasperJS é a melhor ferramenta para preencher e enviar formulários. Exemplo mais simples possível de como preencher e enviar um formulário usando a função fill () :
fonte