Axis2C非官方与Axis2C员工



我将开发一个应用程序,该应用程序将使用一些基于SOAP的web服务框架。我做了一些研究,我有点喜欢Axis2C框架,但在一些主题中,我发现最初的Axis2C实现存在内存泄漏,它的官方开发已经停止。

幸运的是,有Axis2C的非官方分支,也有基于Axis2C的Staff框架。现在的问题是,Axis2C子体中哪一个更好或更容易使用?我知道,Staff用C++封装了Axis2C,但我不介意简单的C。Staff也修复了内存泄漏吗?

谢谢你的建议。

我不能告诉你Axis2/C上的工作已经停止,它还在继续,但非常非常慢。如果你研究主干回购,今年你只能看到5次提交。。。Trunk版本1.7.0(未发布)有许多更改和新功能,但发布日期仍然未知。

原始Axis2/C-1.6.0确实存在内存泄漏和已知问题,不适合生产。Axis2/C-official基于原始的Axis2/C-1.6.0,修复了大多数关键问题,并提供了其他有用的功能。但非官方分支,当然,拥有和原来相同的API,您将花费相同的时间来开发服务或客户端使用起来并不容易也不难

如果我们谈论WSF Staff,它旨在快速开发WEB服务和客户端。与Axis2/C相比,您只需要编写几行代码就可以启动服务或客户端工作。您不需要了解内部消息结构:您只使用简单(bool、int、string等)或复杂(struct、typedef、std containers…)类型(当然,您可以对消息进行低级访问)。Axis2/C有类似的功能,名为ADB(Axis数据绑定),但它是通过C方式完成的,您需要编写额外的代码行来访问请求和结果。

请注意,ADB(和生成的服务)存在内存泄漏,并且在非官方分支中未修复。

为了比较更容易使用的东西——ADB或Staff,我想举一个例子:

注意:您需要手动编写{}之间的代码。

Axis2/C从Axis2/C示例中实现计算器服务添加操作而不使用ADB(传统)的方法:

axiom_node_t *
axis2_calc_add(
    const axutil_env_t * env,
    axiom_node_t * node)
{
    axiom_node_t *param1_node = NULL;
    axiom_node_t *param1_text_node = NULL;
    axis2_char_t *param1_str = NULL;
    long int param1 = 0;
    axiom_node_t *param2_node = NULL;
    axiom_node_t *param2_text_node = NULL;
    axis2_char_t *param2_str = NULL;
    long int param2 = 0;
    if (!node)
    {
        AXIS2_ERROR_SET(env->error, AXIS2_ERROR_SVC_SKEL_INPUT_OM_NODE_NULL,
                        AXIS2_FAILURE);
        printf("Calculator client request ERROR: input parameter NULLn");
        return NULL;
    }
    /* iterating to the first child element skipping (empty) text elements */
    for (param1_node = axiom_node_get_first_child(node, env);
         param1_node && axiom_node_get_node_type(param1_node, env) != AXIOM_ELEMENT;
         param1_node = axiom_node_get_next_sibling(param1_node, env));
    if (!param1_node)
    {
        AXIS2_ERROR_SET(env->error,
                        AXIS2_ERROR_SVC_SKEL_INVALID_XML_FORMAT_IN_REQUEST,
                        AXIS2_FAILURE);
        printf("Calculator service  ERROR: invalid XML in requestn");
        return NULL;
    }
    param1_text_node = axiom_node_get_first_child(param1_node, env);
    if (!param1_text_node)
    {
        AXIS2_ERROR_SET(env->error,
                        AXIS2_ERROR_SVC_SKEL_INVALID_XML_FORMAT_IN_REQUEST,
                        AXIS2_FAILURE);
        printf("Calculator service  ERROR: invalid XML in requestn");
        return NULL;
    }
    if (axiom_node_get_node_type(param1_text_node, env) == AXIOM_TEXT)
    {
        axiom_text_t *text =
            (axiom_text_t *) axiom_node_get_data_element(param1_text_node, env);
        if (text && axiom_text_get_value(text, env))
        {
            param1_str = (axis2_char_t *) axiom_text_get_value(text, env);
        }
    }
    else
    {
        AXIS2_ERROR_SET(env->error,
                        AXIS2_ERROR_SVC_SKEL_INVALID_XML_FORMAT_IN_REQUEST,
                        AXIS2_FAILURE);
        printf("Calculator service ERROR: invalid XML in requestn");
        return NULL;
    }
    /* iterating to the second child element skipping (empty) text elements */
    for (param2_node = axiom_node_get_next_sibling(param1_node, env);
         param2_node && axiom_node_get_node_type(param2_node, env) != AXIOM_ELEMENT;
         param2_node = axiom_node_get_next_sibling(param2_node, env));
    if (!param2_node)
    {
        AXIS2_ERROR_SET(env->error,
                        AXIS2_ERROR_SVC_SKEL_INVALID_XML_FORMAT_IN_REQUEST,
                        AXIS2_FAILURE);
        printf("Calculator service  ERROR: invalid XML in requestn");
        return NULL;
    }
    param2_text_node = axiom_node_get_first_child(param2_node, env);
    if (!param2_text_node)
    {
        AXIS2_ERROR_SET(env->error,
                        AXIS2_ERROR_SVC_SKEL_INVALID_XML_FORMAT_IN_REQUEST,
                        AXIS2_FAILURE);
        printf("Calculator service  ERROR: invalid XML in requestn");
        return NULL;
    }
    if (axiom_node_get_node_type(param2_text_node, env) == AXIOM_TEXT)
    {
        axiom_text_t *text =
            (axiom_text_t *) axiom_node_get_data_element(param2_text_node, env);
        if (text && axiom_text_get_value(text, env))
        {
            param2_str = (axis2_char_t *) axiom_text_get_value(text, env);
        }
    }
    else
    {
        AXIS2_ERROR_SET(env->error,
                        AXIS2_ERROR_SVC_SKEL_INVALID_XML_FORMAT_IN_REQUEST,
                        AXIS2_FAILURE);
        printf("Calculator service ERROR: invalid XML in requestn");
        return NULL;
    }
    if (param1_str && param2_str)
    {
        long int result = 0;
        axis2_char_t result_str[255];
        axiom_element_t *ele1 = NULL;
        axiom_node_t *node1 = NULL,
            *node2 = NULL;
        axiom_namespace_t *ns1 = NULL;
        axiom_text_t *text1 = NULL;
        param1 = strtol(param1_str, NULL, 10);
        param2 = strtol(param2_str, NULL, 10);
        result = param1 + param2;
        sprintf(result_str, "%ld", result);
        ns1 = axiom_namespace_create(env,
                                     "http://axis2/test/namespace1", "ns1");
        ele1 = axiom_element_create(env, NULL, "result", ns1, &node1);
        text1 = axiom_text_create(env, node1, result_str, &node2);
        return node1;
    }
    AXIS2_ERROR_SET(env->error,
                    AXIS2_ERROR_SVC_SKEL_INVALID_OPERATION_PARAMETERS_IN_SOAP_REQUEST,
                    AXIS2_FAILURE);
    printf("Calculator service ERROR: invalid parametersn");
    return NULL;
}

Axis2/C从Axis2/C代码生成示例实现计算器服务WITH ADB的添加操作的方法:

    adb_addResponse_t * axis2_skel_Calculator_add(const axutil_env_t * env,
                                                    adb_add_t * add) 
{
    adb_addResponse_t * add_res = NULL;
    int ret_val = 0;
    int val1 = 0;
    int val2 = 0;
    val1 = adb_add_get_arg_0_0(add, env);
    val2 = adb_add_get_arg_1_0(add, env);
    ret_val = val1 + val2;
    add_res = adb_addResponse_create(env);
    adb_addResponse_set_addReturn(add_res, env, ret_val);
    return add_res;
}

员工实现计算器服务添加操作的方式:

int CalculatorImpl::add(int param_1, int param_2)
{
  return param_1 + param_2;
}

关于代码生成和编译过程,它将是:

对于轴2/C:

# generate service from WSDL
WSDL2C.sh -uri Calculator.wsdl -u -ss -sd
# implement src/axis2_skel_Calculator.c
# compile and install
cd src
# build
sh build.sh
# install
sudo mkdir $AXIS2C_HOME/services/calculator
sudo cp lib*.so ../resources/*.xml $AXIS2C_HOME/services/calculator

WSF员工:

# generate service from WSDL
staff_codegen -pwsdl -tcomponent_all Calculator.wsdl
# implement src/CalculatorImpl.cpp
# build and install
make && sudo -E make install

当然,您可以在Axis2/C-official上使用WSF Staff来从两者中获得所有好处。

事实证明,就在今天,我在谷歌搜索时发现了Axis2c是非官方的,我需要检查一下。

至于Axis2c(WSO2版本),我目前正在我的移动应用程序(基于Qt的-Meego/BB10)中使用它,您可能不想自己编写代码,而是想从WSDL文件生成代码。就像loentar所说的那样,WSO2版本实际上只是Axis2c的一个包装,但它确实让它的设置变得更容易。我会说使用WSO2版本或使用非官方版本,我发现Axis2c很难编译(我是C/C++/Qt/SOAP的新手,我试图为Meego/BB10交叉编译它——你可以想象它是怎么回事!),还记得STAFF是基于Qt的包装器,所以这是另一个依赖项。

底线是使用代码生成器,但要注意:

1-代码生成器有一个"rest of xml节点"(记不起方法/名称),但基本上它无法映射的所有xml都进入该节点,您可以对此运行xpath查询。然而,有时这个节点会被放在实际的真实节点对象之前,所以xml只是被转储到这个节点中,而不是你真正想要的节点对象。

2-生成的代码很大-我的意思是真的很大!我的移动库大约是190 MB,在没有调试的情况下大约是40 MB。

3-代码生成是java,所以你可以使用eclipse让代码生成你的代码getter!

第三点非常重要,就我个人而言,我发现这意味着我需要写更少的代码,因为XML中的每个项目都映射到一个字符串,而从我的QML代码(GUI代码)中,我只需处理这个字符串。

我可能已经偏离了正轨——尽管我宁愿使用Java来生成代码(更好的支持),但如果有选择的话,希望这会有所帮助。

对JeFf:的回应

在我为BB10尝试编译WSO2时,我意识到WSO2只是包括Axis2c文件夹,它首先编译各种asix2c库(我认为它首先编译),然后编译WSO2库(sandesh、savan等),我很幸运,我真正想要的只是WSDL的XML串行化/去串行化,而不是任何高级的soap功能(除了最基本的功能外,我对soap当然不太了解)。

假设头文件/api完全相同,可以简单地将axis2c库替换为非官方库。或者干脆把非官方文件夹放在官方文件夹上。

我自己必须首先在eclipse(BB10 SDK)中编译二进制文件,这是一项漫长而艰巨的任务,但与诺基亚Meego SDK不同的是,没有针对BB10的交叉编译工具,在Meego中,我只需要做零更改,这非常简单。

相关内容

  • 没有找到相关文章

最新更新