WCF Data Service - Proxy mid-tier service

后端 未结 2 1811
Happy的楠姐
Happy的楠姐 2021-01-25 10:59

The project we are working on is a classic 3 tiered architecture. tier 1 being the database server, tier 2 the application services and tier 3 the presentation tier (a web site)

相关标签:
2条回答
  • 2021-01-25 11:46

    If you don't need to change the shape or functionality of the data server, you should be able to simply forward the requests and responses, just like a transparent HTTP proxy. The only difference you might need to do is to tweak the service URL. Since the proxy service will have a different base URI than the real service, the payload would contain the real service URIs (in the links and such), which would not work. You can workaround this by using a custom host for your real service and lie to it about its URI. This is done through IDataServiceHost2 interface, you return the "new" URI from the AbsoluteRquestUri and AbsoluteServiceUri properties. Nice sample of an implementation of the interface (although for a different purpose) is here: http://blogs.msdn.com/b/tom_laird-mcconnell/archive/2010/01/18/using-ado-net-wcf-data-services-for-streaming-infinite-event-result-sets.aspx.

    If you need to change the shape or functionality, then you really need a true layering.

    Layering one WCF Data Service over another is currently rather hard. The LINQ expression trees generated by the "Server" are not always understood by the "Client" LINQ provider. That's what you're running into.

    There's a prototype (more like an experiment) of making this work to some extent by rewriting the expression trees. It's part of the OData Provider Toolkit which you can download here http://www.odata.org/developers/odata-sdk#/media/7579/odataprovidertoolkit.zip. (It's in the Experimental folder, AstoriaOverAstoria project).

    But please be aware that this is really just an experiment to show what kind of issues are there to be solved and so on. I definitely recommend to NOT use it in any kind of production environment.

    0 讨论(0)
  • 2021-01-25 11:47

    I have found it possible to expose a service on the Web Tier that references a service (not data directly) on the App Tier. This only works for queries at the moment. I am not sure what is needed to get it working for updates, deletes etc. Any Ideas anyone? Anyway, here are some instructions and code snippets:

    1. First you create a WCF Data Service on the App Tier bound to your edmx model.
    2. Then create WCF Data Service on the Web Tier not bound to an edmx model (custom).
    3. Create a Service Reference in the Web Tier Service to the App tier service.
    4. Pass the Entities type to the DataService generic declaration (should be angle brackets for VB but I couldn't get them to show:
    
            Public MyWebTierService 
            Inherits DataService[MyServiceReference.MyAppTierEntities]
    
    1. Add an override for CreateDataSource() that creates your reference to the App Tier:
    
     Protected Overrides Function CreateDataSource() As MyServiceReference.MyAppTierEntities
            Dim ctx = New MyServiceReference.MyAppTierEntities(New Uri("http://yourappservicelocation/AppService.svc/"))
            Return ctx
        End Function
    

    All you do now is create a reference to the service or bind it to your client app that supports OData. JSONP support can be added if required.

    So, this works fine for Queries but not for updates, probably because the Types are not the same (they may look the same, but are in difference assemblies after all). So, tracking is lost between the Web and App Tiers.

    It may be that we have to implement IUpdatable on the Web Tier to solve this. Not sure yet so any input would be useful.

    Hope this helps

    0 讨论(0)
提交回复
热议问题