我在我的应用程序中使用pyAMF,但我想设置智能服务,如下所述:

时间:2010-07-28 20:45:04

标签: python pyamf

在正常的应用程序中,我设置了服务

services = {
    'users.login': login,
    'test': router
}

但我想这样做:

services = [
    'users.login',
    'test'
]

并且每个请求都转到路由器功能。这需要2个参数:服务名称(在这种情况下可以是“users.login”或“test”)和输入(这是flex发送给python的对象) 然后,如果来自flex的命令(服务)被命名为“users.login”。我想用params运行路由器然后这将打开commands.users.login包中的函数login。我该怎么办?感谢。

2 个答案:

答案 0 :(得分:2)

如果我正确理解您的问题,为了实现这一点,您将需要覆盖您正在使用的Gateway类上的getServiceRequest

from pyamf.remoting.gateway.django import DjangoGateway
from pyamf.remoting.gateway import UnknownServiceError


class MyGateway(DjangoGateway):
    def __init__(self, router_func, **kwargs):
        self.router = router_func

        DjangoGateway.__init__(self, **kwargs)

    def getServiceRequest(self, request, target):
        try:
            return DjangoGateway.getServiceRequest(self, request, target)
        except UnknownServiceError, e:
            pass

        # cached service was not found, try to discover it
        try:
            service_func = self.router(target)
        except:
            # perhaps some logging here
            service_func = None

        if not service_func:
            # couldn't find a service matching `target`, crap out appropriately
            raise e

        self.addService(service_func, target)

        return DjangoGateway.getServiceRequest(self, request, target)

self.router是您提供给网关构造函数的函数。它接受AMF远程请求的字符串目标并返回匹配函数。如果它返回None或引发异常,则会向请求者返回未知的服务响应。

希望这可以为您的需求奠定基础。

答案 1 :(得分:0)

昨晚解决了!

from pyamf.remoting.gateway.google import WebAppGateway
import logging

class TottysGateway(WebAppGateway):
def __init__(self, services_available, root_path, not_found_service, logger, debug):
    # override the contructor and then call the super
    self.services_available = services_available
    self.root_path = root_path
    self.not_found_service = not_found_service
    WebAppGateway.__init__(self, {}, logger=logging, debug=True)

def getServiceRequest(self, request, target):
    # override the original getServiceRequest method
    try:
        # try looking for the service in the services list
        return WebAppGateway.getServiceRequest(self, request, target)
    except:
        pass

    try:
        # don't know what it does but is an error for now
        service_func = self.router(target)
    except:
        if(target in self.services_available):
            # only if is an available service import it's module
            # so it doesn't access services that should be hidden
            try:
                module_path = self.root_path + '.' + target
                paths = target.rsplit('.')
                func_name = paths[len(paths) - 1]
                import_as = '_'.join(paths) + '_' + func_name
                import_string = "from "+module_path+" import "+func_name+' as service_func'
                exec import_string
            except:
                service_func = False

    if(not service_func):
        # if is not found load the default not found service
        module_path = self.rootPath + '.' + self.not_found_service
        import_string = "from "+module_path+" import "+func_name+' as service_func'

    # add the service loaded above
    assign_string = "self.addService(service_func, target)"
    exec assign_string

    return WebAppGateway.getServiceRequest(self, request, target)