Android C2DM使用基于java的Web服务,但如果我尝试使用基于WS-dotNet的Web服务,就会出现401错误

Android C2DM使用基于java的Web服务,但如果我尝试使用基于WS-dotNet的Web服务,就会出现401错误,android,.net,iis-7,android-c2dm,httpwebresponse,Android,.net,Iis 7,Android C2dm,Httpwebresponse,我用Java做了一个简单的Web服务,并在JBoss5.1中部署了它。 此WS处理向Android手机发送通知消息的C2DM服务。我在谷歌c2dm api中设置了所有类似于红色的内容,首先,我注册了c2dm服务。在这种情况下,一切都很好 现在我必须在IIS7上的.NET中执行同样的操作。有关.Net代码的一些说明: WebService提供setRegId()和pushMessage()方法 在设置字符串“reg_id”和“device_id”后,setRegId()只需调用handShake

我用Java做了一个简单的Web服务,并在JBoss5.1中部署了它。 此WS处理向Android手机发送通知消息的C2DM服务。我在谷歌c2dm api中设置了所有类似于红色的内容,首先,我注册了c2dm服务。在这种情况下,一切都很好

现在我必须在IIS7上的.NET中执行同样的操作。有关.Net代码的一些说明:

  • WebService提供setRegId()和pushMessage()方法

  • 在设置字符串“reg_id”和“device_id”后,setRegId()只需调用handShakeRegId()

  • 所有注释的代码都是我试图解决的问题,但都是无用的

这就是代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Services;
using System.Net;
using System.Text;
using System.IO;
using System.Diagnostics;

namespace WebService1
{

[WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]

public class Service1 : System.Web.Services.WebService
{

    private String accountType = "HOSTED_OR_GOOGLE";
    private String email = "example@gmail.com";
    private String password = "password";
    private String service = "ac2dm";
    private String source = "com.cloudTest.app";
    private String HTTPHeaderCT = "application/x-www-form-urlencoded";

    private String auth;
    private String reg_Id;
    private String deviceId;
    private String collapseKey = "CollapseKey";

    public void handShakeRegId()
    {

        HttpWebRequest req;
        Stream reqst;
        try
        {
            req = (HttpWebRequest)WebRequest.Create(@"https://www.google.com/accounts/ClientLogin");

         //   string proxy = null;
         //   req.MaximumAutomaticRedirections = 4;
         //   req.MaximumResponseHeadersLength = 4;
         //   req.Credentials = CredentialCache.DefaultCredentials;
            string data = String.Format("accountType={0}&Email={1}&Passwd={2}&service={3}&source={4}", accountType, email, password, service, source);

            byte[] buffer = Encoding.UTF8.GetBytes(data);
         //   ASCIIEncoding encoding = new ASCIIEncoding();
         //   byte[] buffer = encoding.GetBytes(data);

            req.Method = "POST";
            req.ContentType = HTTPHeaderCT;
            req.ContentLength = buffer.Length;
          //  req.Proxy = new WebProxy(proxy, true);
          //  req.CookieContainer = new CookieContainer();

            reqst = req.GetRequestStream(); // add form data to request stream
            reqst.Write(buffer, 0, buffer.Length);

        }
        catch (Exception e)
        {
            Debug.WriteLine("--------------------");
            Debug.Write("(handShakeRegId) Request Error:" + e);
            Debug.WriteLine("--------------------");
            throw;
        }

        HttpWebResponse res;
        Stream resst;
        try
        {
            res = (HttpWebResponse)req.GetResponse();

            resst = res.GetResponseStream();
            StreamReader sr = new StreamReader(resst, Encoding.UTF8);
            string response = sr.ReadToEnd();

            string SID = response.Substring((response.IndexOf("SID=") + 4),
            (response.IndexOf("\n") - 4));//extracting SID

            string Auth = response.Substring((response.IndexOf("Auth=") + 5),
            (response.Length - (response.IndexOf("Auth=") + 5)) - 1);//extracting Auth

            auth = Auth;
        }
        catch (Exception e)
        {
            Debug.Write("(handShakeRegId) Response Error:" + e);
            throw;
        }

        resst.Flush();
        resst.Close();
        reqst.Flush();
        reqst.Close();
    }

    [WebMethod]
    public void setRegId(String reg_id, String device_id)
    {

        reg_Id = reg_id;
        deviceId = device_id;

        Debug.WriteLine("RegID=" + reg_Id);
        Debug.WriteLine("--------------------");
        Debug.WriteLine("DeviceID=" + deviceId);

        handShakeRegId();
    }

    [WebMethod]
    public void pushMessage(String msg)
    {
        // Needed! Without an SSL Exception comes out
        System.Net.ServicePointManager.ServerCertificateValidationCallback += delegate(object sender,
        System.Security.Cryptography.X509Certificates.X509Certificate certificate,
        System.Security.Cryptography.X509Certificates.X509Chain chain,
        System.Net.Security.SslPolicyErrors sslPolicyErrors) { return true; };

        HttpWebRequest req;
        Stream reqst;

        try
        {

            req = (HttpWebRequest)WebRequest.Create("http://android.apis.google.com/c2dm/send");
            //req.MaximumAutomaticRedirections = 4;
            //req.MaximumResponseHeadersLength = 4;
            //req.Credentials = CredentialCache.DefaultCredentials;
            //req.Credentials = new NetworkCredential("example@gmail.com","password");
            //req.KeepAlive = true;

            //string proxy = null;


            string data = String.Format("registration_id={0}&collapse_key={1}&data.message={2}", reg_Id, collapseKey, msg);

           // ASCIIEncoding encoding = new ASCIIEncoding();
           // byte[] buffer = encoding.GetBytes(data);

            byte[] buffer = Encoding.UTF8.GetBytes(data);

            req.Method = "POST";
            req.ContentType = HTTPHeaderCT;
            req.ContentLength = buffer.Length;
            req.Headers.Add("Authorization", "GoogleLogin auth=" + auth);

           // req.Proxy = new WebProxy(proxy, true);
           // req.CookieContainer = new CookieContainer();

            reqst = req.GetRequestStream(); // add form data to request stream
            reqst.Write(buffer, 0, buffer.Length);
        }
        catch (Exception e)
        {
            Debug.Write("(PushMessageMsgOUT)Error: " + e);
            throw;
        }

        HttpWebResponse res;
        Stream resst;

        try
        {
            res = (HttpWebResponse)req.GetResponse();

            HttpStatusCode responseCode = ((HttpWebResponse)res).StatusCode;
            if (responseCode.Equals(HttpStatusCode.Unauthorized) || responseCode.Equals(HttpStatusCode.Forbidden))
            {
                Debug.WriteLine("Unauthorized - need new token");
            }
            else if (!responseCode.Equals(HttpStatusCode.OK))
            {
                Debug.WriteLine("Response from web service not OK :");
                Debug.WriteLine(((HttpWebResponse)res).StatusDescription);
            }

            resst = res.GetResponseStream();
            StreamReader sr = new StreamReader(resst);

            string response = sr.ReadToEnd();

        }
        catch (Exception e)
        {
            Debug.WriteLine("(pushMessageMsgIN) Error: "+e);
            throw;
        }

        resst.Flush();
        resst.Close();
        reqst.Flush();
        reqst.Close();
    }
  }
}
  • 握手法效果很好!我可以毫无问题地获得身份验证令牌
  • setRegId方法由Android设备调用(在我的例子中是Android+GoogleApi 2.2模拟器)
pushMessage getResponse()中出现的错误总是相同的(这很奇怪,因为我实现的连接与握手方法中的连接完全相同:-/):

System.dll中发生了类型为“System.Net.WebException”的第一次意外异常 (pushMessageMsgIN)错误:System.Net.WebException:远程服务器错误(401)在System.Net.HttpWebRequest.GetResponse()中未经授权

搜索有用的东西需要2天,但是。。。。没有什么!! 这很有压力

我希望有人能帮助我


我对IIS中的身份验证有所了解,所以我启用了匿名用户和其他未知的东西,只是为了尝试。没什么

解决:我的愚蠢!!!我在私有字符串源代码中犯了一个错误!!我指定了一个错误的包名!--

Heeeelpppp!!!!!!!!!!!!没有人能帮我。uffffi假设您将您的身份验证令牌存储在某处。你不能就这样引用。当您调用pushMessage()时,我假设您的身份验证令牌为空。已解决:我的愚蠢!!!我在私有字符串源代码中犯了一个错误!!我指定了一个错误的应用程序包名称!哈亚:)