登入使用curl指令模拟http请求

curl_init  时间:2021-04-19  阅读:()

使用curl指令模拟HTTP请求c url是很方便的Rest客戶端可以很方便的完成許多Rest API測試的需求甚至如果是需要先登入或認證的rest api也可以進行測試利用curl指令可以送出HTTP GET,POST,PUT,DELETE,也可以改變HTTP header來滿足使用REST API需要的特定條件。curl的参数很多這邊僅列出目前測試REST時常用到的:

-X/--reques t[GET|P O ST|PUT|DELET E|…]使用指定的httpmethod發出httpreques t-H/--header設定request裡的header

-i/--inc lude顯示response的header

-d/--data設定httpp arameters

-v/--verb os e輸出比較多的訊息

-u/--us er使用者帳號、密碼

-b/--cookiecookielinux command line的參數常 同一個功能常會有兩個功能完全相同參數一個是比較短的參數前面通常是用-(一個-)導引符號另一個比較長的參數通常會用--(兩個-)導引符號在curl使用說明

-X,--requestCOMMANDSpecifyrequestc ommandtouse

--resolveHOST:PORT:ADDRESSForceresolveofHOST:PORTtoADDRESS

--retryNUMRetryreque s tNUMtime s iftrans ientprob l em s o cc ur

--retry-delaySECONDSWhenretrying,w aitth ismanys ec ondsbetw eeneach

--retry-max-time S ECOND S Retryon lyw ith inthis p er iod

參數-X跟--request兩個功能是一樣的所以使用時ex:curl-X POST http://www.example.c om/跟curl--request POST http://www.example.c om/是相等的功能

GET/P O S T/PUT/DELETE使用方式

-X後面加http methodc url-XGET”http://www.res t.c om/api/us ers”curl-XPOS T”http://www.rest.c om/api/us ers”c url-XPUT”http://w ww.res t.c om/api/us ers”c url-XDELET E”http://w ww.r es t.c om/ap i/us ers”ur l要加引號也可以不加引號也可以如果有非純英文字或數字外的字元不加引號可能會有問題如果是網碼過的ur l也要加上引號

HEADER

在http header加入的訊息curl-v-i-H”Content-Type:app lic ation/js on”http://www.example.c om/us ers

HTTP Parameterhttp參數可以直接加在url的query s tring也可以用-d帶入參數間用串接或使用多個-d

#使用` `串接多個參數curl-XPOST-d”param1=value1 param2=value2”

#也可使用多個`-d` 效果同上curl-XPOST-d”param 1=value 1”-d”param2=value2”curl-XPOST-d”param 1=a0spac e”

#“a space”url encode後空白字元會編碼成’%20’為”a%20space”編碼後的參數可以直接使用curl-XPOST-d”param1=a%20space”postjson格式得資料

如同時需要傳送request parameter跟json request parameter可以加在url後面 json資料則放入-d的參數然後利用單引號將json資料含起來(如果json內容是用單引號 -d的參數則改用雙引號包覆) header要加入”Content-Type:app lic ation/js on”跟”Ac c ept:applic ation/js on”

ept:app lication/json”-d’{“boolean”:false,”foo”:”bar”}’

#不加”Accept:application/json”也可以c urlhttp://www.example.c om?modifier=kent-XPUT-i-H”Cont ent-Type:app lic ation/js on”-d’{“boolean”:false,”foo”:”bar”}’

需先認證或登入才能使用的s ervic e

許多服務需先進行登入或認證後才能存取其API服務依服務要求的條件 的curl可以透過cookie session或加入在header加入session key api key或認證的token來達到認證的效果。session例子:

後端如果是用session記錄使用者登入資訊後端會傳一個session id給前端前端需要在每次跟後端的requests的header中置入此session id後端便會以此session id識別前端是屬於那個session 以達到session的效果curl--requestGET’http://www.rest.c om/api/us ers’--header’s es s ionid:1234567890987654321’c ookie例子

如果是使用c ookie在認證後後端會回一個c ookie回來把該c ookie成檔案當要存取需要任務的url時再用-b cookie_file的方式在request中植入cookie即可正常使用

#將c ookie存檔c url-i-XP O S T-dus ername=kent-dpassw ord=kent 123-c~/c ookie.txthttp://w ww.res t.c om/auth

#載入cookie到request中c url-i--header”Ac c ept:app lic ation/js on”-XGET-b~/c ookie.txthttp://www.rest.c om/us ers/1

檔案上傳c url-i-XP O S T-F’file=@/Us ers/kent/my_file.txt’-F’name=a_file_name’

這個是透過HTTP multipart POST上傳資料 -F是使用http query parameter的方式指定檔案位置的參數要加上@

HTTP Bas ic Authentication(HTTP基本認證)

如果網站是採HTTP基本認證,可以使用--user username:password登入c url-i--us erkent:s ecrethttp://www.res t.c om/ap i/fo o’

認證失敗時會是401 Unauthorized

HTTP/1.1401 Unauthorized

Server:Ap ache-Coyote/1.1

X-Content-Type-Options:nosniff

X-XSS-Protection:1;mode=block

Cache-Control:no-c ache,no-store,max-age=0,must-revalidate

Pragma:no-c ache

Exp ir e s:0

X-Frame-Options:DENY

WWW-Authentic ate:Bas ic realm=“Realm”

Content-Typ e:text/html;c hars et=utf-8

Content-Languag e:en

Content-Length:1022

Date:Thu,15 May201406:32:49 GMT

認證通過時會回應200OK

HTTP/1.1200OK

Server:Ap ache-Coyote/1.1

X-Content-Type-Options:nosniff

X-XSS-Protection:1;mode=block

Cache-Control:no-c ache,no-store,max-age=0,must-revalidate

Pragma:no-c ache

Exp ir e s:0

X-Frame-Options:DENY

Set-Cookie:JSES SIONID=A75066DCC816CE31 D8F69255DEB6C30B;Path=/mdserver/;HttpOnly

Content-Type:app lic ation/js on;chars et=UTF-8

Trans fer-Enc oding:c hunked

Date:Thu,15May201406:14:11 G MT

可以把認證後的c ookie存起來重複使用c url-i--us erkent:s ecrethttp://www.res t.c om/api/foo’-c~/c ookies.txt登入之前暫存的cookies可以不用每次都認證c url-ihttp://w ww.res t.c om/api/foo’-b~/c ookies.txt

racknerd新上架“洛杉矶”VPS$29/年,3.8G内存/3核/58gSSD/5T流量

racknerd发表了2021年美国独立日的促销费用便宜的vps,两种便宜的美国vps位于洛杉矶multacom室,访问了1Gbps的带宽,采用了solusvm管理,硬盘是SSDraid10...近两年来,racknerd的声誉不断积累,服务器的稳定性和售后服务。官方网站:https://www.racknerd.com多种加密数字货币、信用卡、PayPal、支付宝、银联、webmoney,可以付...

PacificRack 下架旧款方案 续费涨价 谨慎自动续费

前几天看到网友反馈到PacificRack商家关于处理问题的工单速度慢,于是也有后台提交个工单问问,没有得到答复导致工单自动停止,不清楚商家最近在调整什么。而且看到有网友反馈到,PacificRack 商家的之前年付低价套餐全部下架,而且如果到期续费的话账单中的产品价格会涨价不少。所以,如果我们有需要续费产品的话,谨慎选择。1、特价产品下架我们看到他们的所有原来发布的特价方案均已下架。如果我们已有...

JUSTG提供俄罗斯和南非CN2 GIA主机年$49.99美元JUSTGgia南非cn2南非CN2justG

JUSTG,这个主机商第二个接触到,之前是有介绍到有提供俄罗斯CN2 GIA VPS主机活动的,商家成立时间不久看信息是2020年,公司隶属于一家叫AFRICA CLOUD LIMITED的公司,提供的产品为基于KVM架构VPS主机,数据中心在非洲(南非)、俄罗斯(莫斯科),国内访问双向CN2,线路质量不错。有很多服务商实际上都是国人背景的,有的用英文、繁体搭建的冒充老外,这个服务商不清楚是不是真...

curl_init为你推荐
清华大学经济管理学院设备itunescss3圆角在HTML里如何实现圆角矩形?ipadwifiIpad怎么用移动无线上网win7telnetwindows7的TELNET服务在哪里开启啊x-router设置路由器是我的上网设置是x怎么弄win7还原系统windows7怎么还原系统啊morphvoxpro怎么用怎么使用morphvox prochrome18chrome的加速功能怎么开启呢?ios5.1.1固件下载我的iphone4 现在是IOS5.1.1 用爱思助手下载APP都说系统版本太低 但是我手机只有
虚拟主机试用 php主机 bash漏洞 北京双线机房 网络空间租赁 空间技术网 电信主机 购买国外空间 西安服务器托管 wordpress中文主题 国外网页代理 godaddy空间 免费赚q币 xshell5注册码 forwarder alexa世界排名 pptpvpn linuxvi命令 宿主机 戴尔主机 更多