当前位置: 首页 > 工具软件 > OpenAMF > 使用案例 >

OpenAMF 配置文件 详解

林俊英
2023-12-01
OpenAMF openamf-config.xml 配置

第一个标签

<amf-serializer>
                        <force-lower-case-keys>false</force-lower-case-keys>
</amf-serializer>

这个标签的存在的意义在于当openamf发送传递给Flash 客户端的AMF消息时,是否把用来返回自定义类的Hashmap里面的key转换成小写。
一边情况下,当我们发送一个hashmap给客户端时,客户端把它当作一个custom class的object来对待。

比如你有一个java方法返回一个hashmap

public Hashmap getValue(){

Hashmap resultObj=new Hashmap();
result.put("nameSpace","com.flashseer.org");
return resultObj;
}


在actionscript中你可以用

resultObj.nameSpace

的写法来引用java里面hashmap中的一个值。

当你把这个标签的属性设置为true的时候,返回给Flash client的object中,所有的key都被转换成小写。

所以,如果你使用Actionscript2.0的时候,因为AS2区分大小写。你就不可能用resultObj.nameSpace来引用了。
因为,nameSpace已经被转换为小写了。你必须使用namespace来引用。

这里,官方的example里面注释说了,
如果你用actionscrpt2.0的话,把这个设置为false。否则,如果你用了大写的字母作为key,在客户端就会出问题。
如果你用as1的话,可以设置为true


第二个标签


        <invoker>
                <name>Java</name>
                <class>org.openamf.invoker.JavaServiceInvoker</class>
        </invoker>
       
这个标签是用来调用java端的服务的。
这里,提供了许多的invoker供你使用。
放在这里的是最常用的一个invoker。这个invoker的作用就是根据service的位置在classpath里面找到这个class,并且调用其中的方法。

另外,还可以使用其他的invoker,
比如EJB,Spring,WebService都是非常实用的invoker.
按照需要,放置这些invoker.
可以在example的配置文件里找到所有的invoker

       
       
       
第三个标签:自定义类的映射
       
        <custom-class-mapping>
                <java-class>org.openamf.examples.Person</java-class>
                <custom-class>org.openamf.examples.Person</custom-class>
        </custom-class-mapping>

这个映射的作用是让你的FlashClient接收到正确的类型。
比如,在flashclient端,你调用一个方法后,接收到一个resultObj

如果你不进行类型映射,那么,这个resultObj是没有类型的。他就是一个object.你无法使用这个object的方法,只能通过引用属性的方法引用到属性。
但是,如果你在这里做了映射,在flash里面就可以得到一个具有类型的object。
用 trace(resultObj instanceof org.openamf.examples.Person) 就可以看到效果。


这个标签可以重复,映射多个自定义class


       
第四个标签:命名你的service(注意,这个部分需要使用advancedGateway)
        <service>
                <!--name这个 node定义一下你的service的名字,这样,你就不用在flash里面把你的整个class都写在里面了,而只需要用这个name来代替-->
                <name>Directory</name>
                <!--这个标签的作用其实就是让你指定你上面定义的那个name对应哪个class。-->
    <service-location>org.flashseer.Example</service-location>
                <!---这个标签 同上面的invoker标签对应,这样,一旦advancedGateway发现了你定义的这个service,就不用遍历所有的invoker来查找相应的服务。
                注意如果你没有定义这个的话,默认情况下,openamf会给所有可能的class打一个分,取分最高的来调用--->
    <invoker-ref>Java</invoker-ref>
               
                <!--这里定义一下需要call的方法-->
                <method>
                        <!-- 方法名 -->
                        <name>addPerson</name>
                        <!--参数定义,这里的参数可以使用一个class的名字或者使用通配符,
                        *就代表许多个参数,?代表一个参数-->
                        <parameter>
                                <type>*</type>
                        </parameter>
               
       
                        <!-- 这个result-filter实际上是可以自己来写实现的。实现org.openamf.filter.ResultFilter即可
                        其中,class标签中,是你需要使用的filter。 你可以使用两个由openamf提供的filter,也可以自己来实现。
                        其中parameter的两个标签其实就是一个自定义的object,你可以自己随便定义然后,在实现filter的时候来使用。
                         -->
                        <result-filter>
                                <class>org.openamf.filter.BeanListToRecordSet</class>
                                <parameter>
                                        <name>ignore</name>
                                        <value>extraInfo</value>
                                </parameter>
                        </result-filter>
                </method>
        </service>
       
        这个标签的意义在于它可以帮助你更快,更方便的找到flash remoting说调用的service.前面也提到了,如果你不指定的话,可能会导致每次openamf都要去做match,计算匹配值,然后取高的。 
 类似资料: