大佬教程收集整理的这篇文章主要介绍了c – 如何判断libcurl是否正确处理了我的SSL文件,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我的libcurl在尝试登录期间立即失败(应该将“会话令牌”作为响应).我告诉卷曲关于我的证书和关键线:
curl_easy_setopt(curl,CURLOPT_SSLCERT,"client-2048.crt"); curl_easy_setopt(curl,CURLOPT_SSLKEY,"client-2048.key");
后来我打电话给curl_easy_perform(curl);我收到的答复是:
{"loginStatus":"CERT_AUTH_required"}
根据betfair documentation,这意味着:“需要证书或证书,但无法通过它进行身份验证”
所以我猜想SSL身份验证失败了.作为一个实验,我尝试将垃圾证书和密钥文件名称(例如“client-2048_XXX.crt”),但看到来自betfair或任何卷曲诊断的响应没有区别(通过curl_easy_setopt设置(curl,CURLOPT_DEBUGFUNCTION,my_tracE) ;和curl_easy_setopt(curl,CURLOPT_VERBOSE,1L);).所以我无法确定libcurl是否正确处理了我的证书和密钥文件.实际上我甚至怀疑它可能根本就没有处理它们 – 也许我错过了CURLOPT_PLEASE_USE_SSL_AUTHENTICATION的一些其他选项,导致文件被忽略?
编辑:所以对于记录,完整序列看起来像这样(隐藏一些文本):
curl_easy_setopt(curl,CURLOPT_URL,"https://identitysso.betfair.com/api/certlogin"); curl_easy_setopt(curl,"client-2048.key"); curl_easy_setopt(curl,CURLOPT_POST,1); struct curl_slist *chunk = NULL; chunk = curl_slist_append(chunk,"X-Application: _HIDDEN_"); chunk = curl_slist_append(chunk,"Content-Type: application/x-www-form-urlencoded"); curl_easy_setopt(curl,CURLOPT_httpHEADER,chunk); curl_easy_setopt(curl,CURLOPT_POSTFIELDS,"username=_HIDDEN_&password=_HIDDEN_"); curl_easy_perform(curl);
编辑:我想也许我以某种方式编译我的libcurl没有SSl.为了检查这个,我打电话给curl_version_info,其中包括:
char *ssl_version; /* human readable String */
打印出来的字符串为“WinSSL”,我认为这意味着包含了SSl.
编辑:仅供参考,我有四个“client-2048”文件,一个.crt,.pem,.key和.csr.它们都与我的exe文件位于同一目录中.我还在运行时打印出当前工作目录(由_getcwd()报告),只需仔细检查我的exe是否从正确的位置运行.
编辑:这是我的工作login.sh(请原谅它的不雅,我用剪切和粘贴代码进行黑客攻击,几乎不知道我在做什么). getlog.exe是我写的一个小实用程序,用于对某些JSON进行一些字符串操作.
#!/bin/bash # uses rescript APP_KEY=_HIDDEN_ #SESSION_TOKEN=$2 HOST=https://api.betfair.com/exchange/betTing AUTHURL=https://identitysso.betfair.com/api/certlogin CURL=curl function bflogin() { echo "bflogin()" OUT=$($CURL -s -k --cert client-2048.crt --key client-2048.key --data "username=_HIDDEN_&password=_HIDDEN_" -H "X-Application: $APP_KEY" -H "Content-Type: application/x-www-form-urlencoded" $AUTHURL) echo $OUT SESSION_TOKEN=$(echo $OUT | getlog.exE) echo echo "Here -> "$SESSION_TOKEN echo $SESSION_TOKEN > st.txt }
此外,由于您尚未指定密钥编码类型,因此PEM是默认值.您可以使用CURLOPT_SSLCERTTYPE选项更改编码类型,或尝试converting your keys to PEM.
以上是大佬教程为你收集整理的c – 如何判断libcurl是否正确处理了我的SSL文件全部内容,希望文章能够帮你解决c – 如何判断libcurl是否正确处理了我的SSL文件所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。