前言
本文主要讲解通过curl 实现表单提交登录。单独的表单提交与表单登录都差不多,因此就不单独说了。
说明:针对curl表单提交实现登录,不是所有网站都适用,原因是有些网站后台做了限制或有其他校验。我们不知道这些网站后台的限制或校验机制具体是什么,因此直接curl表单登录可能是不行的。
当然,如下案例是可以用curl登录的。
案例:LeanCloud登录
要求和结果
要求:通过curl登录后,能正常访问leancloud的应用页面。
登录页面链接如下:
1 | https://leancloud.cn/dashboard/login.html#/signin |
能正常访问如下页面:
1 | https://leancloud.cn/dashboard/applist.html#/apps |
浏览器访问效果:
无登录直接访问结果
浏览器访问结果
上图红框 403 中的访问连接如下:
1 | https://leancloud.cn/1.1/clients/self/apps |
通过curl 验证是否登录
1 | [root@iZ28xbsfvc4Z ~]# curl -i https://leancloud.cn/1.1/clients/self/apps |
获取表单字段信息
获取表单提交链接
通过下图可得到表单提交的链接信息。具体如下:
1 | https://leancloud.cn/1.1/signin |
curl 表单登录并保存cookie信息
1 | curl -v -c leancloud1.info -X POST -F 'email=yourname' -F 'password=yourpassword' https://leancloud.cn/1.1/signin |
查看cookie信息
1 | [root@iZ28xbsfvc4Z 20190714_02]# ll |
每列字段说明:
domain:创建并可以读取变量的域名。
flag:一个 TRUE/FALSE 值,表明给定域中的所有机器是否都可以访问该变量。此值由浏览器自动设置,具体取决于你为域设置的值。
path:变量在域中有效的路径。
secure:一个 TRUE/FALSE 值,表明是否需要与域的安全连接来访问变量。
expiration:该变量将过期的UNIX时间。UNIX时间定义为自1970年1月1日00:00:00 GMT开始的秒数。
name:变量名称
value:变量值
校验是否登录成功
直接访问和带有cookie访问,这两种访问方式,请对比查看。
直接访问
1 | [root@iZ28xbsfvc4Z 20190714_02]# curl -i https://leancloud.cn/1.1/clients/self/apps |
带有cookie文件的访问
1 | # 使用cookie |
复制浏览器的cookie访问
1 | [root@iZ28xbsfvc4Z 20190720]# curl -i -H 'cookie: _ga=GA1.2.2055706705.1560005524; …………' https://leancloud.cn/1.1/clients/self/apps |
由上可知curl登录成功。