无法使用生成的令牌命中第二个服务

时间:2015-06-17 10:01:51

标签: c# web-services rest soap drupal-services

我已经提供了两个服务,其中ist服务用于登录目的,它将返回一个xml节点令牌,我将在所有其他服务调用中添加为头,

在附加的示例代码中,函数中有两个函数 CreateObject()我正在点击登录服务并且我成功地获得了响应,并且从响应中我获取了令牌并使用令牌调用其他函数搜索(字符串标记)并在标头中传递令牌,但它提供了异常[System.Net.WebException] = {"The remote server returned an error: (403) Forbidden."}

但是当我在chrome Advanced Rest Client中看到它给出了预期的响应时

任何正确方向的建议或解决方案都会非常值得注意

请参阅下面的代码

 private  void CreateObject()
    {        
        try
        {
            string abc = "";
            Stream datastream;
            HttpWebRequest request = (HttpWebRequest)WebRequest.Create("www.example.com/abc/login");
            request.CookieContainer = new CookieContainer();
            request.AllowAutoRedirect = true;
            request.UserAgent = "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/535.2 (KHTML, like Gecko) Chrome/15.0.874.121 Safari/535.2";
            request.ContentType = "application/x-www-form-urlencoded";
            request.Accept = "application/xml";
            request.KeepAlive = true;
            String postData = "";
            request.Method = "POST";
            postData = String.Format("username={0}&password={1}", "sample", "sample");
            byte[] byteArray = Encoding.UTF8.GetBytes(postData);
            request.ContentLength = byteArray.Length;
            datastream = request.GetRequestStream();
            datastream.Write(byteArray, 0, byteArray.Length);


            HttpWebResponse response = (HttpWebResponse)request.GetResponse();
            datastream = response.GetResponseStream();
            String sourceCode = "";
            using (StreamReader reader = new StreamReader(datastream))
            {
                sourceCode = reader.ReadToEnd();
            }
            int pos = sourceCode.IndexOf("<?");
            string xmlpart = sourceCode.Substring(pos);
            //XmlReader reader1 = XmlReader.Create(sourceCode);
            XmlDocument doc = new XmlDocument();
            doc.LoadXml(xmlpart);
            XmlNodeList objNodeList = doc.GetElementsByTagName("token");
           string tokens = objNodeList[0].ChildNodes.Item(0).InnerText.Trim();
          search(tokens);

        }
        catch (Exception e)
        {

        }
    }

     public void search(string token)
        {
            Stream datastream;
            HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://example.com/services/suggestions/search");
            request.CookieContainer = new CookieContainer();
           // request.AllowAutoRedirect = true;
            System.Net.ServicePointManager.Expect100Continue = false;
           request.Headers.Add("x-csrf-token", token);
            request.UserAgent = "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/535.2 (KHTML, like Gecko) Chrome/15.0.874.121 Safari/535.2";
            request.ContentType = "application/x-www-form-urlencoded";
            request.Accept = "application/x-cdf,text/html,application/xhtml+xml,application/json,application/xml;q=0.9,*/*;q=0.8";
            String postData = "";
            request.Method = "POST";
            request.KeepAlive = true;
            postData = String.Format("param1={0}&param2={1}&param3={2}&param4={3}&param5={4}&param6={5}&param7={6}&param8={7}", "0", "1","1","1","0","1","2015-06-22","2015-06-22");
            byte[] byteArray = Encoding.UTF8.GetBytes(postData);
            request.ContentLength = byteArray.Length;
            datastream = request.GetRequestStream();
            datastream.Write(byteArray, 0, byteArray.Length);


            HttpWebResponse response = (HttpWebResponse)request.GetResponse();
            datastream = response.GetResponseStream();
            String sourceCode = "";
            using (StreamReader reader = new StreamReader(datastream))
            {
                sourceCode = reader.ReadToEnd();
            }

        }

1 个答案:

答案 0 :(得分:0)

最后我想出了问题是什么

我正在为请求

创建新的cookie容器
request.CookieContainer = new CookieContainer();

因此服务器无法进行身份验证

使用此代码解决了错误

CookieContainer cookieJar = new CookieContainer();
    private  void CreateObject()
        {        
            try
            {
                string abc = "";
                Stream datastream;
                HttpWebRequest request = (HttpWebRequest)WebRequest.Create("www.example.com/abc/login");
                request.CookieContainer = cookieJar;
                request.AllowAutoRedirect = true;
                request.UserAgent = "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/535.2 (KHTML, like Gecko) Chrome/15.0.874.121 Safari/535.2";
                request.ContentType = "application/x-www-form-urlencoded";
                request.Accept = "application/xml";
                request.KeepAlive = true;
                String postData = "";
                request.Method = "POST";
                postData = String.Format("username={0}&password={1}", "sample", "sample");
                byte[] byteArray = Encoding.UTF8.GetBytes(postData);
                request.ContentLength = byteArray.Length;
                datastream = request.GetRequestStream();
                datastream.Write(byteArray, 0, byteArray.Length);


                HttpWebResponse response = (HttpWebResponse)request.GetResponse();
                datastream = response.GetResponseStream();
                String sourceCode = "";
                using (StreamReader reader = new StreamReader(datastream))
                {
                    sourceCode = reader.ReadToEnd();
                }
                int pos = sourceCode.IndexOf("<?");
                string xmlpart = sourceCode.Substring(pos);
                //XmlReader reader1 = XmlReader.Create(sourceCode);
                XmlDocument doc = new XmlDocument();
                doc.LoadXml(xmlpart);
                XmlNodeList objNodeList = doc.GetElementsByTagName("token");
               string tokens = objNodeList[0].ChildNodes.Item(0).InnerText.Trim();
              search(tokens);

            }
            catch (Exception e)
            {

            }
        }

         public void search(string token)
            {
                Stream datastream;
                HttpWebRequest request = (HttpWebRequest)WebRequest.Create("http://example.com/services/suggestions/search");
                request.CookieContainer = cookieJar; // same cookejar is used as was used in login call
               // request.AllowAutoRedirect = true;
                System.Net.ServicePointManager.Expect100Continue = false;
               request.Headers.Add("x-csrf-token", token);
                request.UserAgent = "Mozilla/5.0 (Windows NT 6.1) AppleWebKit/535.2 (KHTML, like Gecko) Chrome/15.0.874.121 Safari/535.2";
                request.ContentType = "application/x-www-form-urlencoded";
                request.Accept = "application/x-cdf,text/html,application/xhtml+xml,application/json,application/xml;q=0.9,*/*;q=0.8";
                String postData = "";
                request.Method = "POST";
                request.KeepAlive = true;
                postData = String.Format("param1={0}&param2={1}&param3={2}&param4={3}&param5={4}&param6={5}&param7={6}&param8={7}", "0", "1","1","1","0","1","2015-06-22","2015-06-22");
                byte[] byteArray = Encoding.UTF8.GetBytes(postData);
                request.ContentLength = byteArray.Length;
                datastream = request.GetRequestStream();
                datastream.Write(byteArray, 0, byteArray.Length);


                HttpWebResponse response = (HttpWebResponse)request.GetResponse();
                datastream = response.GetResponseStream();
                String sourceCode = "";
                using (StreamReader reader = new StreamReader(datastream))
                {
                    sourceCode = reader.ReadToEnd();
                }

            }