C#,OAuth2在调试模式下失败,但在运行可执行文件

时间:2017-10-19 17:27:54

标签: c# oauth visual-studio-debugging

我有这段代码:(在示例中更改了用户名和密码)

string un="test@test.com";
string pw="hq23@3";
string url="https://login.salesforce.com/services/oauth/token";
string cliid = "3MVG9yZ.WNae345QAvlJ.HwD94PbdkgMvpoq2IgBi3CPP.r8EfNQB.uAAm72swYrQSaG5TdhXseqChQiIBvox";
string clisec = "33861436554340449385";
HOauth2 h = new HOauth2(lurl,cliid,clisec);
HOauthResult r = h.authenticate(un, pw);
Console.WriteLine(r.getErm());
Console.WriteLine(r.getAccessToken());
Console.ReadKey();

如果我构建项目并运行可执行文件,我得到预期的输出:

  

NOERROR   00DA0000000tuBSm!ARsAQQZEdOXXXZAqmYtG.Sj9.6d7_DYdrdKqdnoAkANT4I3Lb4F3Pgz0AYSkRWVJKTmy3cqbGWcV2gSYCxvAbXkg6mJ8l_jK

但是,在VS模式下以Debug/Release运行项目时,同一段代码会产生输出:

  

invalid_grant |身份验证失败

这让我发疯,我无法调试剩下的代码。 有没有人经历过类似的行为,并且解决了这个问题。 我在system.diagnostics中启用了App.config,并在两种情况下都将数据流与服务器进行了比较,它们是相同的,字节为字节。

1 个答案:

答案 0 :(得分:0)

问题不在于代码,而在于开发环境。 VS由于某种原因使用TLS1.0作为默认协议,而对于机器本身它是TLS1.2 在代码中强制使用TLS1.2后,将值设置为ServicePointManager,一切都开始工作了。由于接受TLS1.2的远程服务器传递的错误消息不具有描述性(400 Bad请求),因此花了一些时间来解决这个问题。 真正的解决方案是将VS设置为使用协议的默认机器设置。