通过Http访问服务器的一个服务软件的数据,浏览器会弹出以下验证弹框:
由于想用PHP curl方法获取数据,但不知道怎么设置用户名和密码验证参数:
这样发现不起作用:
curl_setopt($curl, CURLOPT_USERPWD, "name:pwd");
curl_setopt($curl, CURLOPT_HTTPAUTH, CURLAUTH_ANY);
使用postman模拟登陆登陆以后我发现请求头里面有一项:
然后在PHP curl方法里面加了一个请求头:
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-type: application/json','Authorization:Basic TnhFY29AMjAxNjojQGlIeVg0eStHUFE='));
这样就能请求到数据了。
但问题是由于脚本需要放到服务器上一直运行,这种写死的验证过期就又验证失败,没有权限了。
怎么能够设置php Curl 用户名密码参数 方法一直验证登录呢?
这是PHP HTTP验证,一般都不这么干,毕竟HTTP验证太简陋了
http://php.net/manual/zh/feat...
添加个这属性
使用CURL模拟登录拿到Authorization Token
使用第1步拿到的Token进行下一步请求
第1步中的Token可以适当做下缓存,缓存时间视服务端而定。
题外话:个人感觉服务端那边是Yii2写的。
之前有做过类似的 搞了半天觉得太麻烦,最终用phantomjs解决。php调用node程序。