无法从 Betfair WebAPI c# 检索会话密钥
Cannot retrieve session key from Betfair WebAPI c#
我一直在尝试登录 these steps and using this source code 之后的 Betfair 帐户。这工作正常,我 returned 了一个会话密钥,但是如果我尝试在另一个项目中重复这些步骤来获取会话密钥,我会收到一个 "CERT_AUTH_REQUIRED" 错误,这意味着我随请求一起发送的客户端证书。
更奇怪的是,如果我创建另一个引用工作 Betfair 项目的项目并将这个新项目简单地 运行 Betfair 项目中的 Program.Main 方法我得到 "CERT_AUTH_REQUIRED"再次留言?
当 Betfair 应用程序是解决方案的 Launch 项目时,它可以工作,但如果我将启动 betfair 控制台应用程序的第二个项目设置为启动项目,它不会 return 成功响应(尽管代码 运行 没问题,并且执行了所有相同的步骤,只是网络响应失败了)。
有人知道为什么会这样吗?
我设法让该代码适用于非交互式登录。我确实做了这个改变。这听起来有点熟悉,因为我记得有那个错误。
private WebRequestHandler getWebRequestHandlerWithCert(string certFilename)
{
var cert = new X509Certificate2(certFilename, "", X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.Exportable);
var clientHandler = new WebRequestHandler();
clientHandler.ClientCertificates.Add(cert);
return clientHandler;
}
我刚刚发现的另一件事可能会导致同样的错误,如果您在下面的步骤中输入导出密码。这可能在您创建密钥后发生了变化,因为它将其标记为可导出,因此我不需要在代码中添加 X509KeyStorageFlags.Exportable
:
openssl pkcs12 -export -in client-2048.crt -inkey client-2048.key -out client-2048.p12
我假设导出密码是示例应用程序提示的内容,但事实并非如此,因此导出密码应留空。
我一直在尝试登录 these steps and using this source code 之后的 Betfair 帐户。这工作正常,我 returned 了一个会话密钥,但是如果我尝试在另一个项目中重复这些步骤来获取会话密钥,我会收到一个 "CERT_AUTH_REQUIRED" 错误,这意味着我随请求一起发送的客户端证书。
更奇怪的是,如果我创建另一个引用工作 Betfair 项目的项目并将这个新项目简单地 运行 Betfair 项目中的 Program.Main 方法我得到 "CERT_AUTH_REQUIRED"再次留言?
当 Betfair 应用程序是解决方案的 Launch 项目时,它可以工作,但如果我将启动 betfair 控制台应用程序的第二个项目设置为启动项目,它不会 return 成功响应(尽管代码 运行 没问题,并且执行了所有相同的步骤,只是网络响应失败了)。
有人知道为什么会这样吗?
我设法让该代码适用于非交互式登录。我确实做了这个改变。这听起来有点熟悉,因为我记得有那个错误。
private WebRequestHandler getWebRequestHandlerWithCert(string certFilename)
{
var cert = new X509Certificate2(certFilename, "", X509KeyStorageFlags.MachineKeySet | X509KeyStorageFlags.PersistKeySet | X509KeyStorageFlags.Exportable);
var clientHandler = new WebRequestHandler();
clientHandler.ClientCertificates.Add(cert);
return clientHandler;
}
我刚刚发现的另一件事可能会导致同样的错误,如果您在下面的步骤中输入导出密码。这可能在您创建密钥后发生了变化,因为它将其标记为可导出,因此我不需要在代码中添加 X509KeyStorageFlags.Exportable
:
openssl pkcs12 -export -in client-2048.crt -inkey client-2048.key -out client-2048.p12
我假设导出密码是示例应用程序提示的内容,但事实并非如此,因此导出密码应留空。