首页域名资讯 正文

CURL使用HTTPS的技术小结

2024-12-02 2 0条评论

CURL是linux下命令行提交HTTP(S)请求的一个很有用的工具,支持表单数据提交、文件上传、文件下载、批量访问,多种HTTP方法等。其中对HTTPS的支持有些技术细节还是很有点讲究的,也是我在最近工作中费了不少时间摸索出来的。

CURL对HTTPS的支持是通过–cacert, –capath, –with-ca-bundle等参数来对HTTPS加以支持的,详细信息可以CURL –help来得到参数明细。[url]http://trustauth.cn/docs/ ssl certs.html[/url]里是CURL的官方文档介绍,其中讲了如何导入CA的具体方法,以及使用CA的方法。其中–with-ca-bundle可以用环境变量CURL_CA_BUNDLE(LINUX下)或CURL-ca-bundle.crt(WINDOWS下可搜索到该文件)来实现默认指定。

通过IE或其他浏览器访问HTTPS服务器我们可以很容易得到SSL的X.509安全证书,证书导出可以选择编码格式,我们通常选择DER或者BASE64编码方法,导出文件为cer后缀。需要注意的是对于openssl生成crt证书文件时–info参数会有区别。如对DER编码文件命令应该是

openssl x509 -inform DES -in /aaa-der.cer -text -out /.aaa-der.crt

其中aaa-der.cer是浏览器里导出的x.509证书文件,aaa-der.crt是加密CA证书被CURL所需加载验证的。如果导出用BASE64编码导出的,则命令行应该改为

openssl x509 -inform PEM -in /aaa-b64.cer -text -out /.aaa-b64.crt

其中-inform参数需要改为PEM,来对应编码格式BASE64。

另外,X.509证书如果是三层以上的,即除了底层的URL外,上面还有两层以上的,则说明该证书是一个证书夹,即便里面只有一个证书。这时候用在CURL时需作为–capath的参数值代入才能生效; 反之,如果只有两层的,即除了底层的URL外,上面只有一层的,则说明该证书只是一个证书,用在CURL里需作为–cacert里的参数值才能生效。

证书在CURL里能被通过必须具备以下三个条件:

1、被CA签证过的证书;

2、期限有效的;

3、URL能匹配请求。

其中第三个可以用过hosts添加ip-name对来实现欺骗,如果服务器的SSL证书属于复制使用的话。

千试百试,终于得到以上体会,希望有相关问题的人可以参考借鉴,也给自己以后参考使用。

用CURL对某web server进行访问,在几台不同网络的机器试,http在所有机器上都是正常的,https在其中的两台上不行,报socket 111无法连接的错误,其他的机器没问题。证书也没有问题。一整天也没有搞明白。因为web server不是我的可触及范围,结果也就是web server的问题,让我白忙活了这么久。因为web server没有启用ssl,它提供的ssl是网络设备ssl-box (netscaler)所支持的,所以所有内网机器都不会成功访问到web server的https端口,外网地址都可以,因为ssl是网络提供的,内网不会经过到netscaler去重定向https。这个是netscaler没配全的原因,唉!真苦!

 

文章版权及转载声明

本文作者:亿网 网址:https://edns.com/ask/post/150436.html 发布于 2024-12-02
文章转载或复制请以超链接形式并注明出处。