在 WCF 服务中调用 SharePoint Web 服务

本文关键字:服务 SharePoint Web 调用 WCF | 更新日期: 2023-09-27 17:57:25

我是WCF服务的新手。我创建了一个简单的 asp.net Web 应用程序,并调用了 SharePoint Admin Web 服务来创建网站。以下是代码。

protected void btnSubmit_Click(object sender, EventArgs e)
    {
        CreateSiteClass objCreateSiteClass = new CreateSiteClass();
        objCreateSiteClass.CreateSite(txtSiteName.Text);
    }
[WebServiceBindingAttribute(Name = "AdminSoap", Namespace = "http://schemas.microsoft.com/sharepoint/soap/")]
public class CreateSiteClass : System.Web.Services.Protocols.SoapHttpClientProtocol
{
    public void CreateSite(string str)
    {
        try
        {
            AdminService.Admin admService = new AdminService.Admin();
            //admService.Credentials = System.Net.CredentialCache.DefaultCredentials;
            admService.Credentials = new System.Net.NetworkCredential("ashish.rautela", "badri@12345", "IRISSOFTWARE");
            admService.CreateSite(str, "Title", "Description", 1033, "STS#0", "IRISSOFTWARE''ashish.rautela", "Ashish Rautela", "ashish.rautela@irissoftware.com", "", "");
        }
        catch (System.Web.Services.Protocols.SoapException ex)
        {
            Console.WriteLine(ex.StackTrace);
        }
    }
}

这成功创建了站点(无论您将在函数参数中传递什么)

但我的要求是在 WCf 服务中使用此服务。因此,我创建了一个 WCF 应用程序,并在实现 IService1 接口的 Service1 类中编写了相同的函数。

WCF 服务已成功构建,当我在创建虚拟目录后浏览它时,它给了我以下路径:-

http://vm-sp-vishal.irissoftware.com:8888/WCFSiteCreateor/Service1.svc?wsdl

在此之后,我创建了一个简单的 asp.net Web 应用程序,并通过右键单击 ->添加服务引用在我的项目中添加了服务引用。然后我默认编写了以下代码.aspx.cs

protected void btnid_Click(object sender, EventArgs e)
{
    TestService(txt.Text);
}
protected void TestService(string strUrl)
{
    MyWCFAdminService.Service1Client objMyWCFAdminService = new MyWCFAdminService.Service1Client();
    objMyWCFAdminService.SiteCreatorClass(strUrl);
}

但是当我运行此应用程序并将函数参数传递到文本框中时,它给了我一个拒绝访问的错误。

我是运行此代码的 SharePoint 服务器中的服务器场管理员成员。

有什么帮助吗?

在 WCF 服务中调用 SharePoint Web 服务

听起来您需要

整理访问策略,因为您将跨域...

您可能需要在WCF服务(或SDHarepoint服务)的根目录中有一个clientaccesspolicy.xmlm文件。

它的内容需要像这样

<?xml version="1.0" encoding="utf-8" ?>
<access-policy>
  <cross-domain-access>
    <policy>
      <allow-from>
        <domain uri="*"/>
      </allow-from>
      <grant-to>
        <resource include-subpaths="true" path="/"/>
      </grant-to>
    </policy>
  </cross-domain-access>
</access-policy>

显然,这个不安全;)你觉得有一点。