服务器无法处理请求。 --->请求失败,HTTP状态为401:未授权

时间:2012-05-13 21:19:21

标签: c# asp.net .net web-services asmx

我有一个Web服务,我已经编写了将值添加到sharepoint列表 我可以在localmachine上调用webservice。但是当我将它部署到服务器时,我得到状态401:未经授权。

任何人都可以告诉我为什么我收到401代理错误我试图在Web配置中添加代理标签它不起作用。

代码

 [WebService(Namespace = "http://tempuri.org/")]
[WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
[System.ComponentModel.ToolboxItem(false)]
public class Req : System.Web.Services.WebService
{

    [WebMethod]
    public Guid Add()
    {

        string uniqueGuid = string.Empty;
        string[] uniqueID;
    try 
    {           
                CrmList.Lists list = new CrmList.Lists();
                list.PreAuthenticate = true;


                #region getvalue
                list.Credentials = System.Net.CredentialCache.DefaultCredentials;
                XmlNode ndLists = list.GetListCollection();


                //XmlNode test = list.GetList(listName);

                list.Url = "http://site/_vti_bin/Lists.asmx";


                System.Xml.XmlDocument xmlDoc = new System.Xml.XmlDocument();

                string listName = Properties.Settings.Default.ListGuid;
                string viewName = Properties.Settings.Default.ViewGuid; 
                string rowLimit = Properties.Settings.Default.RowLimit;

                System.Xml.XmlElement query = xmlDoc.CreateElement("Query");
                System.Xml.XmlElement viewFields =
                    xmlDoc.CreateElement("ViewFields");
                System.Xml.XmlElement queryOptions =
                    xmlDoc.CreateElement("QueryOptions");


                query.InnerXml = "<OrderBy><FieldRef Name='ID' Ascending='False' /></OrderBy>";

                viewFields.InnerXml = @"<FieldRef Name='ID' />";


                queryOptions.InnerXml = "";


                System.Xml.XmlNode nodeListItems = list.GetListItems(listName, viewName, query, viewFields, rowLimit, queryOptions, "09bdac52-8897-41ee-8a0e-df5fdba617e9");





                #endregion

                string listdata=string.Empty;
                string InvoiceType =string.Empty;

                    listdata= @"<Method ID=""1"" Cmd=""New"">";

                    listdata += @"<Field Name=""ID""></Field>";

                    listdata += @"</Method>";

                    System.Xml.XmlDocument xdoc = new System.Xml.XmlDocument() ;

                    System.Xml.XmlElement xbatch = xdoc.CreateElement("Batch");
                    xbatch.SetAttribute("OnError", "Return");
                    xbatch.InnerXml = listdata;

                    try
                    {
                        list.UpdateListItems(listName, xbatch);

                    }
                    catch (Exception ex)
                    {

                    }



        #region getguid
                    System.Xml.XmlNode currentListValues = list.GetListItems(listName, viewName, query, viewFields, rowLimit, queryOptions,Properties.Settings.Default.WebGuid);
                    string test = string.Empty;
                    XmlDocument xdoc1 = new XmlDocument();
                    XmlNamespaceManager nsmanager = new XmlNamespaceManager(xdoc1.NameTable);
                    nsmanager.AddNamespace("ns1", "http://schemas.microsoft.com/sharepoint/soap");
                    xdoc1.LoadXml(currentListValues.InnerXml);
                    System.Xml.XmlElement root = xdoc1.DocumentElement;
                    List<string> str1 = new List<string>();
                    XmlAttributeCollection attCol;

                    bool IsGuid;
                    foreach (System.Xml.XmlNode listItem in root)
                    {
                        string name = listItem.Name;
                        string value = listItem.OuterXml;
                        attCol = listItem.Attributes;

                        for (int i = 0; i < attCol.Count; i++)
                        {
                            IsGuid = attCol[i].Value.ToString().Contains("{");
                            if (IsGuid)
                            {
                                uniqueID = attCol[i].Value.ToString().Split('{');
                                uniqueGuid = uniqueID[1].ToString().Replace("}", "");
                                //str1.Add(uniqueGuid);
                                break;
                            }


                        }
                        if (!string.IsNullOrEmpty(uniqueGuid))
                        {
                            break;
                        }

                    }
        #endregion


    }

            catch (Exception exc)
            {

                throw ;
            }
    Guid currentItemGuid = new Guid(uniqueGuid);
    return currentItemGuid;
    }
}

1 个答案:

答案 0 :(得分:0)

您需要使用有效的凭据。 DefaultCredentials正在您的计算机上工作,因为sharepoint知道用户。如果sharepoint位于另一台计算机上,则需要使用用户&amp ;;创建一个NetwordCredentials。密码在SharePoint服务器上有效。