4

我正在将 Indy10 与 Delphi 一起使用,并试图让Google 的 OAuth工作。第一步是向 OAuthGetRequestToken 方法发出请求。下面的代码返回 400 错误。任何帮助将不胜感激。

procedure TForm1.Button1Click(Sender: TObject);
    var
      IdHTTP: TIdHTTP;
      IdSSLIOHandlerSocket1: TIdSSLIOHandlerSocketOpenSSL;
      Params: TStringList;
      mString: String;
    begin
      Params := tstringlist.create;
      IdSSLIOHandlerSocket1 := TIdSSLIOHandlerSocketOpenSSL.create(nil);
      IdHTTP := TIdHTTP.create(nil);

      with IdSSLIOHandlerSocket1 do begin
        SSLOptions.Method := sslvSSLv3;
        SSLOptions.Mode :=  sslmUnassigned;
        SSLOptions.VerifyMode := [];
        SSLOptions.VerifyDepth := 2;
      end;
      with IdHTTP do begin
        IOHandler := IdSSLIOHandlerSocket1;
        ReadTimeout := 0;
        AllowCookies := True;
        ProxyParams.BasicAuthentication := False;
        ProxyParams.ProxyPort := 0;
        Request.ContentLength := -1;
        Request.ContentRangeEnd := 0;
        Request.ContentRangeStart := 0;
        Request.ContentType := 'application/x-www-form-urlencoded';
        request.host := 'https://www.google.com';
        Request.Accept := 'text/html, */*';

        Request.BasicAuthentication := False;
        Request.UserAgent := 'Mozilla/3.0 (compatible; Indy Library)';
        HTTPOptions := [hoForceEncodeParams];
      end;
      Params.Add('scope=https://www.google.com/analytics/feeds/');
      Params.Add('oauth_consumer_key=anonymous');
      Params.Add('oauth_signature_method=HMAC-SHA1');
      Params.Add('oauth_signature=wOJIO9A2W5mFwDgiDvZbTSMK%2FPY%3D');
      Params.Add('oauth_timestamp=137131200');
      Params.Add('oauth_nonce=4572616e48616d6d65724c61686176');
      showmessage(HTTPDecode(IdHTTP.Post('https://www.google.com/accounts/OAuthGetRequestToken',Params)));

    end;
4

3 回答 3

2

检查除了 400 之外,您是否在响应标头中也收到了返回消息。大多数 Web 服务都提供了某种关于出现问题的文本描述。

还要验证 OpenSSL 库是否已实际加载,否则 Indy 可能会退回到服务器可能不接受的未编码通信。

于 2009-10-15T06:28:10.713 回答
2

尝试通过HTTP Fiddler路由您的请求。

我发现这是一个很好的工具来跟踪 http/https 级别的问题。

——杰伦

于 2009-10-15T08:23:09.490 回答
2

查看响应 DataString(引发异常的地方),它将为您提供问题的更详细原因。
例如,尝试使用您的代码,我首先得到一个“与当前时间相差太远的时间戳”,然后在更新 oauth_timestamp 后,我得到一个“无效签名”......

于 2009-10-15T21:06:47.987 回答