security的整合,在做登陆的时候发现需要调用*(ChannelSet).login(name,pass)才能调用spring
Security的组件实现验证。但是问题来了,这个ChannelSet从哪儿来??总不能自己凭空new一个吧??google了一下返现
Christophe Coenraets给的spring-flex-testdrive里也是直接通过 Javascript代码
- var channel:AMFChannel = new AMFChannel("my-amf", "http://localhost:8080/messagebroker/amf");
- var channelSet:ChannelSet = new ChannelSet();
- channelSet.addChannel(channel);
var channel:AMFChannel = new AMFChannel("my-amf", "http://localhost:8080/messagebroker/amf");
var channelSet:ChannelSet = new ChannelSet();
channelSet.addChannel(channel);
来得到ChannelSet,这样硬编码明显不行,部署路径一变马上就白瞎了,继续google半天未果,逼急了我直接加断点调试进源码里看,最
终发现可以通过一下的方法来获得在services-config.xml中配置的ChannelSet:
Javascript
代码- var cs:ChannelSet=ServerConfig.getChannelSet(destination);
var cs:ChannelSet=ServerConfig.getChannelSet(destination);
这里的destination可以是任何一个泥已知的RemoteObject的destination,这样就会自动取到该
RemoteObject得默认destination,也就是services-config.xml中default-channels标记所配置的
ChannelSet。
Javascript
代码- var c:Channel=ServerConfig.getChannel("my-secure-amf", false);
var c:Channel=ServerConfig.getChannel("my-secure-amf", false);
即可获得services-config.xml中任意id的channel。