在 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服务(或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>
显然,这个不安全;)你觉得有一点。