Linux curl 表单登录或提交与cookie使用

简介: Linux curl 表单登录或提交与cookie使用本文主要讲解通过curl 实现表单提交登录。单独的表单提交与表单登录都差不多,因此就不单独说了。说明:针对curl表单提交实现登录,不是所有网站都适用,原因是有些网站后台做了限制或有其他校验。

Linux curl 表单登录或提交与cookie使用
本文主要讲解通过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
2 HTTP/1.1 403 Forbidden
3 Server: openresty
4 Date: Sun, 14 Jul 2019 11:35:28 GMT
5 Content-Type: application/json;charset=utf-8
6 Transfer-Encoding: chunked
7 Connection: keep-alive
8 Vary: Accept-Encoding
9 Cache-Control: no-cache,no-store
10 Pragma: no-cache
11
12 {"code":1,"error":"User doesn't sign in."}
复制代码

获取表单字段信息

获取表单提交链接
通过下图可得到表单提交的链接信息。具体如下:

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
2 # 或则
3 curl -v -c leancloud3.info -X POST -d 'email=yourname&password=yourpassword' https://leancloud.cn/1.1/signin

查看cookie信息
复制代码
1 [root@iZ28xbsfvc4Z 20190714_02]# ll
2 total 32
3 -rw-r--r-- 1 root root 337 Jul 14 19:45 leancloud1.info
4 -rw-r--r-- 1 root root 335 Jul 14 19:46 leancloud3.info
5 [root@iZ28xbsfvc4Z 20190714_02]# cat leancloud1.info
6 # Netscape HTTP Cookie File
7 # http://curl.haxx.se/docs/http-cookies.html
8 # This file was generated by libcurl! Edit at your own risk.
9
10 #HttpOnly_leancloud.cn FALSE / TRUE 1563709522 uluru_user Ff1IPOiMX%2F6ipevuxy0OOg%3D%3D
11 leancloud.cn FALSE / TRUE 1563709522 XSRF-TOKEN 5647dc84bd6eaea37eca2d07ae0e401cca4ba76803989c8559XXXXX7283da
12 [root@iZ28xbsfvc4Z 20190714_02]# cat leancloud3.info
13 # Netscape HTTP Cookie File
14 # http://curl.haxx.se/docs/http-cookies.html
15 # This file was generated by libcurl! Edit at your own risk.
16
17 #HttpOnly_leancloud.cn FALSE / TRUE 1563709591 uluru_user arTwQm6JylzLjBaQt7TpiQ%3D%3D
18 leancloud.cn FALSE / TRUE 1563709591 XSRF-TOKEN 751e12827c7c046408541bc1bf962b5912ac35b0d07f88120XXXXXX40704704
复制代码
每列字段说明:
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
2 HTTP/1.1 403 Forbidden
3 Server: openresty
4 Date: Sun, 14 Jul 2019 11:52:47 GMT
5 Content-Type: application/json;charset=utf-8
6 Transfer-Encoding: chunked
7 Connection: keep-alive
8 Vary: Accept-Encoding
9 Cache-Control: no-cache,no-store
10 Pragma: no-cache
11
12 {"code":1,"error":"User doesn't sign in."}
复制代码

带有cookie文件的访问
复制代码
1 # 使用cookie
2 [root@iZ28xbsfvc4Z 20190714_02]# curl -i -b leancloud1.info https://leancloud.cn/1.1/clients/self/apps
3 ## 或者
4 [root@iZ28xbsfvc4Z 20190714_02]# curl -i -b leancloud3.info https://leancloud.cn/1.1/clients/self/apps
5 HTTP/1.1 200 OK
6 Server: openresty
7 Date: Sun, 14 Jul 2019 11:53:29 GMT
8 Content-Type: application/json;charset=utf-8
9 Transfer-Encoding: chunked
10 Connection: keep-alive
11 Vary: Accept-Encoding
12 Cache-Control: no-cache,no-store
13 Pragma: no-cache
14 Strict-Transport-Security: max-age=31536000
15
16 [{"app_domain":null,"description":null,"archive_status":0,"biz_type":"dev","master_key": ………………
复制代码

复制浏览器的cookie访问
复制代码
1 [root@iZ28xbsfvc4Z 20190720]# curl -i -H 'cookie: _ga=GA1.2.2055706705.1560005524; …………' https://leancloud.cn/1.1/clients/self/apps
2 HTTP/1.1 200 OK
3 Server: openresty
4 Date: Sat, 20 Jul 2019 08:11:37 GMT
5 Content-Type: application/json;charset=utf-8
6 Transfer-Encoding: chunked
7 Connection: keep-alive
8 Vary: Accept-Encoding
9 Cache-Control: no-cache,no-store
10 Pragma: no-cache
11 Strict-Transport-Security: max-age=31536000
12
13 [{"app_domain":null,"description":null,"archive_status":0,"biz_type":"dev","master_key": ………………
复制代码

由上可知curl登录成功。

原文地址https://www.cnblogs.com/zhanglianghhh/p/11331211.html

相关文章
|
30天前
|
网络协议 Linux 网络安全
curl(http命令行工具):Linux下最强大的网络数据传输工具
curl(http命令行工具):Linux下最强大的网络数据传输工具
42 0
|
27天前
|
监控 安全 Shell
【Shell 命令集合 系统管理 】Linux 查看系统上的失败登录记录 lastb命令 使用指南
【Shell 命令集合 系统管理 】Linux 查看系统上的失败登录记录 lastb命令 使用指南
35 0
|
27天前
|
安全 Unix Shell
【Shell 命令集合 网络通讯 】Linux 向所有当前登录的用户发送消息或通知 wall命令 使用指南
【Shell 命令集合 网络通讯 】Linux 向所有当前登录的用户发送消息或通知 wall命令 使用指南
28 0
|
28天前
|
监控 Linux Shell
【Shell 命令集合 网络通讯 】Linux管理终端设备的登录过程 getty命令 使用指南
【Shell 命令集合 网络通讯 】Linux管理终端设备的登录过程 getty命令 使用指南
31 0
|
27天前
|
监控 Shell Linux
【Shell 命令集合 系统管理 】Linux 显示当前登录到系统的用户信息 who命令 使用指南
【Shell 命令集合 系统管理 】Linux 显示当前登录到系统的用户信息 who命令 使用指南
43 1
|
27天前
|
Unix Shell Linux
【Shell 命令集合 系统管理 】Linux 显示当前登录用户的登录名 logname命令 使用指南
【Shell 命令集合 系统管理 】Linux 显示当前登录用户的登录名 logname命令 使用指南
28 0
|
27天前
|
存储 安全 Shell
【Shell 命令集合 系统管理 】Linux 显示系统中所有用户的登录记录 last命令 使用指南
【Shell 命令集合 系统管理 】Linux 显示系统中所有用户的登录记录 last命令 使用指南
32 0
|
3月前
|
Shell Linux
linux shell脚本判断当前登录用户是否为root
linux shell脚本判断当前登录用户是否为root
49 1
|
9天前
|
Linux 网络安全 数据安全/隐私保护
linux免密登录最简单--图文详解
linux免密登录最简单--图文详解
20 2
|
27天前
|
存储 Shell Linux
【Shell 命令集合 系统管理 】Linux 显示当前登录用户的用户 whoami命令 使用指南
【Shell 命令集合 系统管理 】Linux 显示当前登录用户的用户 whoami命令 使用指南
42 1