Всегда получаю HTML в ответ от RTC - PullRequest
1 голос
/ 09 апреля 2020

Похоже, что серверу RT C не нравится мой URL-запрос. Я могу по существу добавить все, что я хочу, после части "host" в URL и получить тот же результат. Так что я догадываюсь, что то, что у меня есть, неправильно. После ответа из моего предыдущего поста я почти уверен, что у меня есть правильный URL из файла "services" в теге <oslc_cm:simpleQuery><dc:title>Change request queries</dc:title>. Так что я не уверен, что есть что-то еще, что ему не нравится? Он больше не проходит проверку подлинности, и теперь я использую форму, а не basi c, поэтому я не думаю, что она связана с проверкой подлинности. Кажется, он просто игнорирует все и вся, но все же знает, что мои полномочия не ошибаются. Есть идеи?

Обновление: я также пытался поменять местами все двоеточия с% 3A, так как документация Jazz не выглядела особенно последовательной в их примерах, если это было необходимо или нет. Хотя те же результаты.

        string host = "https://my.host.com:9443/ccm/";
        string item = host + "oslc/contexts/_MySp3ci4lK3Y/workitems?" +
                                  "oslc.where=dcterms:identifier=%222494443%22&" +
                                  "oslc.properties=dcterms:title,dcterms:identifier&" +
                                  "oslc.prefix=dcterms=%3Chttp://purl.org/dc/terms/%3E";
        Debug.Log("Request");
        HttpWebRequest request = (HttpWebRequest)WebRequest.Create(item);
        request.Accept = "application/json";
        request.Headers.Add("OSLC-Core-Version", "2.0");
        WebResponse response = request.GetResponse();
        string AuthHeader = response.Headers["X-com-ibm-team-repository-web-auth-msg"];
        //check if authentication has failed
        if ((AuthHeader != null) && AuthHeader.Equals("authrequired"))
        {
            Debug.Log("Authentication Required");
            HttpWebRequest _formPost = (HttpWebRequest)WebRequest.Create(host + "authenticated/j_security_check"); // Same response without the "authenticated/j_security_check"
            _formPost.Method = "POST";
            _formPost.Timeout = 30000;
            _formPost.Headers.Add("OSLC-Core-Version", "2.0");
            _formPost.CookieContainer = request.CookieContainer;
            _formPost.Accept = "text/xml";
            _formPost.ContentType = "application/x-www-form-urlencoded";

            Byte[] _outBuffer = Encoding.UTF8.GetBytes(credentials); //store in byte buffer
            _formPost.ContentLength = _outBuffer.Length;
            Stream _str = _formPost.GetRequestStream();
            _str.Write(_outBuffer, 0, _outBuffer.Length); //update form
            _str.Close();

            //FormBasedAuth Step2:submit the login form and get the response from the server
            HttpWebResponse _formResponse = (HttpWebResponse)_formPost.GetResponse();

            string _rtcAuthHeader = _formResponse.Headers["X-com-ibm-team-repository-web-auth-msg"];
            //check if authentication has failed
            if ((_rtcAuthHeader != null) && _rtcAuthHeader.Equals("authfailed"))
            {
                Debug.Log("Authentication Failed");
                return;
            }
            else
            {
                //login successful
              // *** Still says AuthRequired here for some reason ***
                Debug.Log("Auth Header = " + _rtcAuthHeader); 
                _formResponse.GetResponseStream().Flush();
                _formResponse.Close();
                //FormBasedAuth Step3: Resend the request for the protected resource.
                response = (HttpWebResponse)request.GetResponse();
            }
        }
        else if (AuthHeader == null)
        {
            Debug.Log("AuthHeader Null");
        }
        else
        {
            Debug.Log("AuthHeader = " + AuthHeader);
        }

        Debug.Log("Response Stream");
        Stream responseStream = response.GetResponseStream();
        byte[] buffer = new byte[BufferSize];
        int read;
        while ((read = responseStream.Read(buffer, 0, buffer.Length)) > 0)
        {
            // Prints out an HTML Doc rather than a JSON string.
            Debug.Log(Encoding.UTF8.GetString(buffer));
        }

1 Ответ

1 голос
/ 11 апреля 2020

Это то, что я понял.

Комментарий "// * По-прежнему говорит, что AuthRequired здесь по какой-то причине *" говорит о том, что авторизация действительно не происходит. Значение заголовка для «X-com-ibm-team-repository-web-auth-msg» действительно будет нулевым, если оно официально больше не требуется.

Это происходит сбой, потому что:

  1. Самому _formPost требуется базовая c аутентификация для отправки значений формы
  2. CookieContainer имеет значение null. Создание нового CookieContainer позволяет продолжить аутентификацию.
  3. "authenticated / j_security_check" неверно. Это должно быть просто "j_security_check".
  4. При повторном запросе данных после аутентификации необходимо создать новый запрос и использовать CookieContainer из оригинала.
...