天天看點

Linux curl 表單登入或送出與cookie使用

Linux curl 表單登入或送出與cookie使用

本文主要講解通過curl 實作表單送出登入。單獨的表單送出與表單登入都差不多,是以就不單獨說了。

說明:針對curl表單送出實作登入,不是所有網站都适用,原因是有些網站背景做了限制或有其他校驗。我們不知道這些網站背景的限制或校驗機制具體是什麼,是以直接curl表單登入可能是不行的。

當然,如下案例是可以用curl登入的。

案例:LeanCloud登入

要求和結果

要求:通過curl登入後,能正常通路leancloud的應用頁面。

登入頁面連結如下:

1

https://leancloud.cn/dashboard/login.html#/signin

能正常通路如下頁面:

https://leancloud.cn/dashboard/applist.html#/apps

浏覽器通路效果:

無登入直接通路結果

浏覽器通路結果

上圖紅框 403 中的通路連接配接如下:

https://leancloud.cn/1.1/clients/self/apps

通過curl 驗證是否登入

複制代碼

1 [root@iZ28xbsfvc4Z ~]# curl -i

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."}

擷取表單字段資訊

擷取表單送出連結

通過下圖可得到表單送出的連結資訊。具體如下:

https://leancloud.cn/1.1/signin

curl 表單登入并儲存cookie資訊

1 curl -v -c leancloud1.info -X POST -F 'email=yourname' -F 'password=yourpassword'

2 # 或則

3 curl -v -c leancloud3.info -X POST -d 'email=yourname&password=yourpassword'

檢視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 #

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

4 Date: Sun, 14 Jul 2019 11:52:47 GMT

帶有cookie檔案的通路

1 # 使用cookie

2 [root@iZ28xbsfvc4Z 20190714_02]# curl -i -b leancloud1.info

3 ## 或者

4 [root@iZ28xbsfvc4Z 20190714_02]# curl -i -b leancloud3.info

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; …………'

2 HTTP/1.1 200 OK

4 Date: Sat, 20 Jul 2019 08:11:37 GMT

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

繼續閱讀