使用curl不一致地接收500,而相同的url始终在浏览器中工作
从curl触发HTTPS请求时,我面临一个问题。 当我使用curl从命令行触发URL时,它会(有时,不总是)给出一个HTTP错误,404或500;相同的URL在浏览器中始终可以正常工作。我被卡住了,有人能指引我吗 简要日志:使用curl不一致地接收500,而相同的url始终在浏览器中工作,url,curl,https,forwarding,Url,Curl,Https,Forwarding,从curl触发HTTPS请求时,我面临一个问题。 当我使用curl从命令行触发URL时,它会(有时,不总是)给出一个HTTP错误,404或500;相同的URL在浏览器中始终可以正常工作。我被卡住了,有人能指引我吗 简要日志: * Hostname was NOT found in DNS cache * Trying 43.249.75.65... * Connected to api2.iHeart.com (43.249.75.65) port 443 (#0) * successful
* Hostname was NOT found in DNS cache
* Trying 43.249.75.65...
* Connected to api2.iHeart.com (43.249.75.65) port 443 (#0)
* successfully set certificate verify locations:
* CAfile: none
CApath: /etc/ssl/certs
* SSLv3, TLS handshake, Client hello (1):
* SSLv3, TLS handshake, Server hello (2):
* SSLv3, TLS handshake, CERT (11):
* SSLv3, TLS handshake, Server key exchange (12):
* SSLv3, TLS handshake, Server finished (14):
* SSLv3, TLS handshake, Client key exchange (16):
* SSLv3, TLS change cipher, Client hello (1):
* SSLv3, TLS handshake, Finished (20):
* SSLv3, TLS change cipher, Client hello (1):
* SSLv3, TLS handshake, Finished (20):
* SSL connection using ECDHE-RSA-AES128-GCM-SHA256
* Server certificate:
* subject: C=US; ST=California; L=San Francisco; O=Fastly, Inc.; CN=g.ssl.fastly.net
* start date: 2016-01-12 22:28:18 GMT
* expire date: 2017-01-12 22:28:18 GMT
* subjectAltName: api2.iHeart.com matched
* issuer: C=BE; O=GlobalSign nv-sa; CN=GlobalSign Organienter code herezation Validation CA - SHA256 - G2
* SSL certificate verify ok.
> GET /api/v1/catalog/searchAll?apikey=YW5kcm9pZHwzfGpzb258NC4wMg%3D%3D&host=console&keywords=q&queryArtist=True&queryBundle=True&queryStation=True&queryTrack=True&queryFeaturedStation=True&queryTalkShow=true&maxRows=5 HTTP/1.1
> User-Agent: curl/7.35.0
> Host: api2.iHeart.com
> Accept: */*
>
< HTTP/1.1 500 Domain Not Found
* Server Varnish is not blacklisted
< Server: Varnish
< Retry-After: 0
< content-type: text/html
< Cache-Control: private, no-cache
< connection: keep-alive
< Content-Length: 209
< Accept-Ranges: bytes
< Date: Fri, 05 Feb 2016 12:54:56 GMT
< Via: 1.1 varnish
< Connection: keep-alive
<html>
<head>
<title>Fastly error </title>
在DNS缓存中找不到主机名
*正在尝试43.249.75.65。。。
*已连接到api2.iHeart.com(43.249.75.65)端口443(#0)
*已成功设置证书验证位置:
*卡菲尔:没有
CApath:/etc/ssl/certs
*SSLv3,TLS握手,客户端hello(1):
*SSLv3,TLS握手,服务器hello(2):
*SSLv3,TLS握手,证书(11):
*SSLv3、TLS握手、服务器密钥交换(12):
*SSLv3,TLS握手,服务器完成(14):
*SSLv3、TLS握手、客户端密钥交换(16):
*SSLv3,TLS更改密码,客户端你好(1):
*SSLv3,TLS握手,完成(20):
*SSLv3,TLS更改密码,客户端你好(1):
*SSLv3,TLS握手,完成(20):
*使用ECDHE-RSA-AES128-GCM-SHA256的SSL连接
*服务器证书:
*主题:C=美国;ST=加利福尼亚州;L=旧金山;O=Fastly公司。;CN=g.ssl.fastly.net
*开始日期:2016-01-12 22:28:18 GMT
*截止日期:2017-01-12 22:28:18 GMT
*subjectAltName:api2.iHeart.com匹配
*发行人:C=BE;O=全球信号内华达州;CN=全局签名组织用户代码异端验证CA-SHA256-G2
*SSL证书验证正常。
>GET/api/v1/catalog/searchAll?apikey=YW5kcm9pZHwzfGpzb258NC4wMg%3D%3D&host=console&keywords=q&queryist=True&queryBundle=True&queryStation=True&queryTrack=True&queryfeaturestation=True&queryTalkShow=True&maxRows=5 HTTP/1.1
>用户代理:curl/7.35.0
>主持人:api2.iHeart.com
>接受:*/*
>
未找到相同的URL在浏览器中运行良好。您是如何运行curl命令的?像
curl'一样运行它https://api2.iHeart.com/api/v1/catalog/searchAll?apikey=YW5kcm9pZHwzfGpzb258NC4wMg%3D%3D&host=console&keywords=q&queryArtist=True&queryBundle=True&queryStation=True&queryTrack=True&queryFeaturedStation=True&queryTalkShow=true&maxRows=5“
可以更好地表达问题,消除重复,固定英语typos@Jucke84是的,我以同样的方式运行,当响应来自Apache服务器时,它有时会工作,错误仅出现在varnish https请求中。您到底是如何运行curl命令的?像curl'一样运行它https://api2.iHeart.com/api/v1/catalog/searchAll?apikey=YW5kcm9pZHwzfGpzb258NC4wMg%3D%3D&host=console&keywords=q&queryArtist=True&queryBundle=True&queryStation=True&queryTrack=True&queryFeaturedStation=True&queryTalkShow=true&maxRows=5“
可以更好地表达问题,消除重复,固定英语typos@Jucke84是的,我是以同样的方式运行的,当响应来自Apache服务器时,它有时会工作,只有https请求出错。