当前位置: 首页 > 知识库问答 >
问题:

如何使用cURL调试CORS请求?

胡越泽
2023-03-14

如何使用cURL调试CORS请求?到目前为止,我找不到任何“模拟”飞行前请求的方法。

共有3个答案

耿炎彬
2023-03-14

下面的bash脚本“corstest”适合我。这是基于Jun的上述评论。

用法

corstest[-v]url

实例

./corstest https://api.coindesk.com/v1/bpi/currentprice.json
https://api.coindesk.com/v1/bpi/currentprice.json Access-Control-Allow-Origin: *

阳性结果显示为绿色

./corstest https://github.com/IonicaBizau/jsonrequest
https://github.com/IonicaBizau/jsonrequest does not support CORS
you might want to visit https://enable-cors.org/ to find out how to enable CORS

阴性结果显示为红色和蓝色

v选项将显示完整的curl标题

胸部

#!/bin/bash
# WF 2018-09-20
# https://stackoverflow.com/a/47609921/1497139

#ansi colors
#http://www.csc.uvic.ca/~sae/seng265/fall04/tips/s265s047-tips/bash-using-colors.html
blue='\033[0;34m'  
red='\033[0;31m'  
green='\033[0;32m' # '\e[1;32m' is too bright for white bg.
endColor='\033[0m'

#
# a colored message 
#   params:
#     1: l_color - the color of the message
#     2: l_msg - the message to display
#
color_msg() {
  local l_color="$1"
  local l_msg="$2"
  echo -e "${l_color}$l_msg${endColor}"
}


#
# show the usage
#
usage() {
  echo "usage: [-v] $0 url"
  echo "  -v |--verbose: show curl result" 
  exit 1 
}

if [ $# -lt 1 ]
then
  usage
fi

# commandline option
while [  "$1" != ""  ]
do
  url=$1
  shift

  # optionally show usage
  case $url in      
    -v|--verbose)
       verbose=true;
       ;;          
  esac
done  


if [ "$verbose" = "true" ]
then
  curl -s -X GET $url -H 'Cache-Control: no-cache' --head 
fi
origin=$(curl -s -X GET $url -H 'Cache-Control: no-cache' --head | grep -i access-control)


if [ $? -eq 0 ]
then
  color_msg $green "$url $origin"
else
  color_msg $red "$url does not support CORS"
  color_msg $blue "you might want to visit https://enable-cors.org/ to find out how to enable CORS"
fi
姜飞飙
2023-03-14
curl -H "Access-Control-Request-Method: GET" -H "Origin: http://localhost" --head http://www.example.com/
  1. 替换http://www.example.com/ 使用您要测试的URL

备选答案的理由

我时不时地用谷歌搜索这个问题,被接受的答案永远不是我需要的。首先,它打印出大量文本的响应体。添加--head只输出标题。第二,在测试S3URL时,我们需要提供额外的头-H“访问控制请求方法:GET”

希望这能节省时间。

廉博赡
2023-03-14

下面介绍如何使用curl调试CORS请求。

使用cUrl发送常规CORS请求:

curl -H "Origin: http://example.com" --verbose \
  https://www.googleapis.com/discovery/v1/apis?fields=

-H“原点:http://example.com“标志是发出请求的第三方域。无论你的领域是什么,都要替换。

--verbose标志打印出整个响应,以便您可以查看请求和响应头。

我上面使用的url是对支持CORS的GoogleAPI的一个示例请求,但是您可以在测试的任何url中替换它。

响应应包括访问控制允许原点标题。

使用cUrl发送飞行前请求:

curl -H "Origin: http://example.com" \
  -H "Access-Control-Request-Method: POST" \
  -H "Access-Control-Request-Headers: X-Requested-With" \
  -X OPTIONS --verbose \
  https://www.googleapis.com/discovery/v1/apis?fields=

这看起来类似于常规的CORS请求,但有一些补充:

-H标志向服务器发送额外的飞行前请求标头

-X OPTIONS标志表示这是一个HTTP OPTIONS请求。

如果预飞行请求成功,则响应应包括访问-控制-允许-起源、访问-控制-允许-方法和访问-控制-允许-头。如果预检请求不成功,则不应出现这些标头,否则HTTP响应将不会为200。

您还可以使用-H标志指定其他标头,例如User-Agent

 类似资料:
  • 我想使用客户端证书对每个目录的身份验证进行故障排除。我特别想知道服务器发送哪些可接受的客户端证书。 如何调试SSL握手,最好使用cURL?

  • 问题内容: 我正在用PHP构建一个REST Web服务客户端,此刻我正在使用curl来向该服务发出请求。 如何使用curl发出经过身份验证的请求(http基本)?我必须自己添加标题吗? 问题答案: 你要这个: Zend有一个REST客户端和zend_http_client,我敢肯定PEAR有某种包装。但是它很容易自己完成。 因此,整个请求可能如下所示:

  • 问题内容: 我有一个angular.js应用程序,我需要做CORS请求。 我想使用以下角度资源定义我的休息服务“角度”:http : //docs.angularjs.org/tutorial/step_11。 但是我还没有找到一种方法来使它工作。在google上,我找到了以下示例代码:http : //jsfiddle.net/ricardohbin/E3YEt/,但这似乎不适用于angular

  • 我试图将curl请求转换为python请求,但我有问题要转换-u。 我的解决方案: 编辑: 现在我得到 答复[400] (curl cmd正在工作)

  • 问题内容: 我想知道如何使此代码支持数组?目前,数组似乎只发送第一个值。 这是我的代码: 这就是在api上收到的 中的第二个值发生了什么? 问题答案: 您只是错误地创建了数组。您可以使用http_build_query: 因此,您可以使用的整个代码为:

  • 本文向大家介绍PHP如何使用cURL实现Get和Post请求,包括了PHP如何使用cURL实现Get和Post请求的使用技巧和注意事项,需要的朋友参考一下 先来看一下在PHP中建立cURL请求的基本步骤:   (1)初始化     curl_init()   (2)设置变量     curl_setopt() 。最为重要。有一长串cURL参数可供设置,它们能指定URL请求的各个细节。要一次性全部看