我有一个 java 套接字服务器,它在连接时将 Animal 对象发送到 Flash 客户端。
对象的发送方式如下:
Amf3Output amf3Output = new Amf3Output(SerializationContext.getSerializationContext());
amf3Output.setOutputStream(userSocket.getOutputStream());
amf3Output.writeObject(animal);
flash端的代码是:
var object:Object = socket.readObject();
trace(object);
trace(object as Animal);
然而,当第二条踪迹给我一个null
我检查过java发送了31个字节,Flash接收了31个字节。
我认为我的 Java 和 AS3 类可能不符合某些 AMF 要求。
Java类:
package main;
public class Animal {
public String name;
public int age;
}
AS3类:
package
{
[Bindable]
[RemoteClass(alias="main.Animal")]
public class Animal
{
public var name:String;
public var age:int;
}
}
我不熟悉 Java 和可用的 AMF 序列化器/反序列化器,但闪存确实支持通过套接字发送类型化对象,并且如果发送正确的数据,则可以正常工作。下面是 ruby 中的套接字服务器与 Flash 应用程序通信的示例。我使用 RocketAMF 在连接后通过套接字将 AMF3 对象发送到客户端。
套接字测试.as:
package {
import flash.display.Sprite;
import flash.net.registerClassAlias;
import org.rackAMF.*;
import flash.net.Socket;
import flash.events.*;
public class SocketTest extends Sprite {
private var socket:Socket;
public function SocketTest() {
registerClassAlias('Animal', Animal);
socket = new Socket();
socket.addEventListener(ProgressEvent.SOCKET_DATA, onResponse);
socket.connect("localhost", 8081);
}
private function onResponse(e:ProgressEvent):void {
var animal:Animal = socket.readObject() as Animal;
trace(Object(animal).constructor); // [trace] [class Animal]
trace(animal.name); // [trace] Zebra
trace(animal.age); // [trace] 5
}
}
}
class Animal {
public var name:String;
public var age:int;
}
套接字服务器.rb:
require 'rubygems'
require 'socket'
require 'rocketamf'
class Animal
attr_accessor :name, :age
end
# Map "Animal" in ruby to "Animal" in flash
RocketAMF::ClassMapper.define do |m|
m.map :as => 'Animal', :ruby => 'Animal'
end
server = TCPServer.open(8081)
loop {
client = server.accept
animal = Animal.new
animal.name = "Zebra"
animal.age = 5
client.write RocketAMF.serialize(animal, 3)
client.close
}
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)