卷曲 - 而与卷曲的PHP相同的请求不(内部服务器错误500)
问题描述:
我用我的用户名和密码试图登录在网站提示脚本工作。卷曲 - 而与卷曲的PHP相同的请求不(内部服务器错误500)
我尝试使用青烟提示,我设法做在两个步骤:首先我发送一个GET请求一个页面保存的cookie,然后我使用这些Cookie来发送POST请求另一页是登录页面。
我这样做是因为我试图重现在浏览器的开发人员控制台中记录的请求。
这些都是工作
curl -c cookie.txt --location "ss16589.scuolanext.info" --cacert ca-bundle.crt
curl --location "https://www.portaleargo.it/argoweb/famiglia/common/j_security_check" --data "utente=xxxxxxx&j_password=xxxxxxx&j_username=xxxxxxx"%"23SS16589&submit=Entra" -b cookie.txt --cacert ca-bundle.crt
我需要开发一个PHP页面,它可以执行相同的任务的两个命令。
该第一页作品。我得到我的cookie.txt充满美味的饼干。
<?php
$url = 'ss16589.scuolanext.info';
$cookie = __DIR__ . '/cookie.txt'; // file and folder must be writeable
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HEADER, true);
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_MAXREDIRS, 1000);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0);
curl_setopt($ch, CURLOPT_CAINFO, getcwd().'\cacert.pem');
curl_setopt($ch, CURLOPT_COOKIESESSION, 1); //forza l'uso di cookie nuovi
curl_setopt($ch, CURLOPT_COOKIEJAR, $cookie); //per salvare i cookie
$result = curl_exec($ch);
$errors=curl_error($ch);
curl_close($ch);
echo '<br>Result:<br>';
echo $result;
echo'<br>------------------<br>Errors:<br>';
echo $errors;
echo'<br>------------------<br>Cookies:<br>';
echo file_get_contents($cookie);
?>
此页面无效。
<?php
$url = 'https://www.portaleargo.it/argoweb/famiglia/common/j_security_check';
$cookie = __DIR__ . '/cookie.txt'; // file and folder must be writeable
$ch = curl_init();
curl_setopt($ch, CURLOPT_URL, $url);
curl_setopt($ch, CURLOPT_HEADER, true);
curl_setopt($ch, CURLOPT_POST, true);
curl_setopt($ch, CURLOPT_POSTFIELDS, 'utente=xxxxxxx&j_password=xxxxxxx&j_username=xxxxxxx#SS16589&submit=Entra');
/*
//tried in another way, same result
$data = array(
'utente' => 'xxxxxxx',
'j_password' => 'xxxxxxx',
'j_username' => 'xxxxxxx#SS16589',
'submit' => 'Entra'
);
curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($data));
*/
curl_setopt($ch, CURLOPT_FOLLOWLOCATION, true);
curl_setopt($ch, CURLOPT_MAXREDIRS, 1000);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 0);
curl_setopt($ch, CURLOPT_CAINFO, getcwd().'\cacert.pem');
curl_setopt($ch, CURLOPT_COOKIEFILE, $cookie); //per usare i cookie
$result = curl_exec($ch);
$errors=curl_error($ch);
curl_close($ch);
echo '<br>Result:<br>';
echo $result;
echo'<br>------------------<br>Errors:<br>';
echo $errors;
echo'<br>------------------<br>Cookies:<br>';
echo file_get_contents($cookie);
?>
起初我发送的字符#像在提示请求(“%” 23),但该网站没有承认,所以我改变了,它似乎工作。
编辑:的 “#” 字符是确定的,在“中的 ”%“ 23人错把刚%23件作品(但仍然有同样的错误)
但现在我。 有此错误从第二PHP页面结果:
HTTP Status 500 -
type Exception report
message
description The server encountered an internal error() that prevented it from fulfilling this request.
exception
javax.servlet.ServletException: java.lang.NullPointerException
javax.faces.webapp.FacesServlet.service(FacesServlet.java:154)
com.backbase.bjsf.webapp.filter.UploadFilter.doFilter(Unknown Source)
com.backbase.bjsf.webapp.filter.BackbaseApplicationFilter.doFilter(Unknown Source)
it.argosoft.alunniweb.modulofamiglia.filter.ModuloFamigliaUserFilter.doFilter(ModuloFamigliaUserFilter.java:97)
root cause
javax.faces.FacesException: java.lang.NullPointerException
org.apache.myfaces.context.servlet.ServletExternalContextImpl.dispatch(ServletExternalContextImpl.java:425)
org.apache.myfaces.application.jsp.JspViewHandlerImpl.renderView(JspViewHandlerImpl.java:211)
com.backbase.bjsf.application.BackbaseViewHandler.renderView(Unknown Source)
org.apache.myfaces.lifecycle.RenderResponseExecutor.execute(RenderResponseExecutor.java:41)
org.apache.myfaces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:132)
javax.faces.webapp.FacesServlet.service(FacesServlet.java:140)
com.backbase.bjsf.webapp.filter.UploadFilter.doFilter(Unknown Source)
com.backbase.bjsf.webapp.filter.BackbaseApplicationFilter.doFilter(Unknown Source)
it.argosoft.alunniweb.modulofamiglia.filter.ModuloFamigliaUserFilter.doFilter(ModuloFamigliaUserFilter.java:97)
root cause
org.apache.jasper.JasperException: java.lang.NullPointerException
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:413)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:326)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:253)
javax.servlet.http.HttpServlet.service(HttpServlet.java:847)
org.apache.myfaces.context.servlet.ServletExternalContextImpl.dispatch(ServletExternalContextImpl.java:419)
org.apache.myfaces.application.jsp.JspViewHandlerImpl.renderView(JspViewHandlerImpl.java:211)
com.backbase.bjsf.application.BackbaseViewHandler.renderView(Unknown Source)
org.apache.myfaces.lifecycle.RenderResponseExecutor.execute(RenderResponseExecutor.java:41)
org.apache.myfaces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:132)
javax.faces.webapp.FacesServlet.service(FacesServlet.java:140)
com.backbase.bjsf.webapp.filter.UploadFilter.doFilter(Unknown Source)
com.backbase.bjsf.webapp.filter.BackbaseApplicationFilter.doFilter(Unknown Source)
it.argosoft.alunniweb.modulofamiglia.filter.ModuloFamigliaUserFilter.doFilter(ModuloFamigliaUserFilter.java:97)
root cause
java.lang.NullPointerException
com.backbase.bjsf.component.UIBBComponentBase.initProperties(Unknown Source)
com.backbase.bjsf.component.UIBackbaseComponentBase.initProperties(Unknown Source)
com.backbase.bjsf.component.UIBackbaseCommandButton.initProperties(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.b(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.b(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.b(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.b(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.b(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.b(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.b(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.c(Unknown Source)
com.backbase.bjsf.application.BackbaseStateManager.saveSerializedView(Unknown Source)
org.apache.myfaces.taglib.core.ViewTag.doAfterBody(ViewTag.java:125)
org.apache.jsp.index_jsp._jspService(index_jsp.java:585)
org.apache.jasper.runtime.HttpJspBase.service(HttpJspBase.java:70)
javax.servlet.http.HttpServlet.service(HttpServlet.java:847)
org.apache.jasper.servlet.JspServletWrapper.service(JspServletWrapper.java:369)
org.apache.jasper.servlet.JspServlet.serviceJspFile(JspServlet.java:326)
org.apache.jasper.servlet.JspServlet.service(JspServlet.java:253)
javax.servlet.http.HttpServlet.service(HttpServlet.java:847)
org.apache.myfaces.context.servlet.ServletExternalContextImpl.dispatch(ServletExternalContextImpl.java:419)
org.apache.myfaces.application.jsp.JspViewHandlerImpl.renderView(JspViewHandlerImpl.java:211)
com.backbase.bjsf.application.BackbaseViewHandler.renderView(Unknown Source)
org.apache.myfaces.lifecycle.RenderResponseExecutor.execute(RenderResponseExecutor.java:41)
org.apache.myfaces.lifecycle.LifecycleImpl.render(LifecycleImpl.java:132)
javax.faces.webapp.FacesServlet.service(FacesServlet.java:140)
com.backbase.bjsf.webapp.filter.UploadFilter.doFilter(Unknown Source)
com.backbase.bjsf.webapp.filter.BackbaseApplicationFilter.doFilter(Unknown Source)
it.argosoft.alunniweb.modulofamiglia.filter.ModuloFamigliaUserFilter.doFilter(ModuloFamigliaUserFilter.java:97)
note The full stack trace of the root cause is available in the JBoss Web/7.0.17.Final logs.
哪些是两个请求之间的差异(提示和php)?
我能做些什么来解决这个问题?
任何想法?
感谢您的帮助,并为我可怕的英语感到抱歉。 Giosch
答
我忘了将用户代理添加到两个php页面。我刚从两个脚本中删除了注释选项。这解决了我的问题