我可以在ServiceStack实现上更改SOAP端点的默认'/ soap11'路由

时间:2013-11-14 21:06:54

标签: servicestack

我知道我可以通过归因于DTO来管理REST-ful接口操作的路由

[Route("/widgets", "GET, POST")]
[DataContract()]
public class GetWidgetsRequest
{
    [DataMember]
    public string OutletCode { get; set; }
    [DataMember]
    public IList<Specification> WidgetsCaptured { get; set; }
}

但是我试图影响给定SOAP操作的端点的默认/ soap11附件,但是我没有成功搜索和试验过。

**POST /soap11 HTTP/1.1**
Host: localhost    
Content-Type: text/xml; charset=utf-8
Content-Length: nnn
SOAPAction: GetItemsRequest

问题中更广泛的问题是,我有哪些选择以及如何配置不同的端点设置?

谢谢!

2 个答案:

答案 0 :(得分:0)

请阅读SOAP Support docs了解在ServiceStack中使用SOAP的准则和限制。

答案 1 :(得分:0)

对于不同的SOAP路径,例如〜/ services,您可以添加自己的servicestack插件,该插件返回您自己的servicestack soap处理程序。

public class MySoapFeature : IPlugin 
{
    private static IHttpHandler GetHandlerForPathParts(string[] pathParts)
    {
        string str2 = string.Intern(pathParts[0].ToLower());
        if (pathParts.Length != 1) return null;
        if (str2 == "services")
        {
            return new MySoapHttpHandler();
        }

        return null;
    }

    public IHttpHandler ProcessRequest(string httpMethod, string pathInfo, string filePath)
    {
        char[] chrArray = new char[] { '/' };
        string[] strArrays = pathInfo.TrimStart(chrArray).Split(new char[] { '/' });
        if ((int)strArrays.Length == 0)
        {
            return null;
        }

        return MySoapFeature.GetHandlerForPathParts(strArrays);
    }

    public void Register(IAppHost appHost)
    {
        appHost.CatchAllHandlers.Add(this.ProcessRequest);
    }
}

然后基于Soap11Handler或Soap12Handler

实现此处理程序
    public class MySoapHttpHandler : Soap11Handler, IHttpHandler
{
    public MySoapHttpHandler()
        : base((EndpointAttributes)((long)32768))
    {
    }

    public new void ProcessRequest(HttpContext context)
    {
        if (context.Request.HttpMethod == "GET")
        {
            (new Soap11WsdlMetadataHandler()).Execute(context);
            return;
        }

        Message message = base.Send(null);
        context.Response.ContentType = base.GetSoapContentType(context.Request.ContentType);
        using (XmlWriter xmlWriter = XmlWriter.Create(context.Response.OutputStream))
        {
            message.WriteMessage(xmlWriter);
        }
    }


    public override void ProcessRequest(IHttpRequest httpReq, IHttpResponse httpRes, string operationName)
    {
        if (httpReq.HttpMethod == "GET")
        {
            (new Soap11WsdlMetadataHandler()).Execute(httpReq, httpRes);
            return;
        }

        Message message = base.Send(null, httpReq, httpRes);
        httpRes.ContentType = base.GetSoapContentType(httpReq.ContentType);
        using (XmlWriter xmlWriter = XmlWriter.Create(httpRes.OutputStream))
        {
            message.WriteMessage(xmlWriter);
        }
    }

然后在servicestack apphost配置()

中注册您的插件
Plugins.Add(new MySoapFeature());

然后为请求和响应创建Dto类。将“响应”添加到响应dto类名称中。不要在请求Dto上放置Route属性,因为它由Xml中的Soap方法名称路由。

[DataContract(Namespace = "http://mynamespace/schemas/blah/1.0")]
public class MySoapMethod
{}


DataContract(Namespace = "http://mynamespace/schemas/blah/1.0")]
public class MySoapMethodResponse
{
     [DataMember]
    public string SomeProperty { get; set; }
}

然后有一个服务来实现Soap Dto的

public class SOAPService : Service
{
    public MySoapMethodResponse Post(MySoapMethod request)
    {
        var response = new MySoapMethodResponse();
        response.SomeProperty = "blah";
        return response;
    }
}