Franck,

Version 3.1.0 working perfect!

After overring the writingCollection( very little code change ), I have
managed to load very complex type of data from server!!!

Please see:

[image: Inline image 1]

Thank you very much!

Best,

-Gary



On Tue, Jun 3, 2014 at 6:52 AM, Franck Wolff <[email protected]> wrote:

> See https://github.com/fwolff/flex-vectors-example and especially
>
> https://github.com/fwolff/flex-vectors-example/blob/master/java/org/granite/example/vectors/java/VectorService.java
> ,
> which shows how to serialize java arrays / collections as AMF vectors
> (sorry this feature isn't well documented yet).
>
> Franck.
>
>
> 2014-06-02 23:18 GMT+02:00 Gary Yang <[email protected]>:
>
> > Hi Frank,
> >
> > I just did a little test against GraniteDS, it can parse bytes into Java
> > Object very well even for strong typed vector array.
> >
> > But I don't see GraniteDS can convert a Java Array into Actionscript
> > Vector, could you help me please?
> >
> >
> > I also took a look in org.granite.messaging.amf.io.AMF3Serializer, it
> > serializes all Java Collection into actionscript
> > mx.collection.ArrayCollection, does mobile app based on Flex have
> > ArrayCollection compiled in? Which is the best way to change this default
> > behaviour please?
> >
> >
> > Best,
> >
> > -Gary
> >
> >
> >
> >
> >
> > On Fri, May 30, 2014 at 12:02 PM, Gary Yang <[email protected]>
> > wrote:
> >
> > > Right, I want to try GraniteDS because
> > >
> > > 1) Vector support is important!
> > >
> > > 2) BlazeDS is too old, 2011 code based on JDK5! No one can guarantee it
> > > works with JDK8/Servlet3!!
> > >
> > >
> > > But I am very sure BlazeDS can catch up very fast once development back
> > on
> > > track!
> > >
> > > -Gary
> > >
> > >
> > > On Fri, May 30, 2014 at 11:50 AM, Christofer Dutz <
> > > [email protected]> wrote:
> > >
> > >> Or we will be able to finally start tweaking BlazeDS as soon as we
> have
> > >> the parity release out the door ;-)
> > >>
> > >> Chris
> > >>
> > >> -----Ursprüngliche Nachricht-----
> > >> Von: Gary Yang [mailto:[email protected]]
> > >> Gesendet: Freitag, 30. Mai 2014 17:14
> > >> An: [email protected]
> > >> Betreff: Re: AMF3 Serialization Benchmark (GraniteDS 3.1.0.M1 vs.
> > BlazeDS
> > >> 4.0.0)
> > >>
> > >> Franck,
> > >>
> > >> Very impressive!
> > >>
> > >> I guess it is time to switch to GraniteDS.
> > >>
> > >> Thanks.
> > >>
> > >> -Gary
> > >>
> > >>
> > >>
> > >> On Fri, May 30, 2014 at 4:41 AM, Franck Wolff <[email protected]>
> > wrote:
> > >>
> > >> > Gary,
> > >> >
> > >> > Just have a look at the link I gave you before:
> > >> >
> > >> >
> > https://github.com/fwolff/amf-benchmark/blob/master/src/org/granite/be
> > >> > nchmark/amf/BenchmarkGraniteDSAmf.java
> > >> > .
> > >> > It doesn't run inside a servlet container, does it?
> > >> >
> > >> > F.
> > >> >
> > >> >
> > >> > 2014-05-29 17:22 GMT+02:00 Gary Yang <[email protected]>:
> > >> >
> > >> > > Franck,
> > >> > >
> > >> > > Does GraniteDS have to run inside a servlet container? I only want
> > >> > > to AMF serialization/deserialization function which has nothing to
> > >> > > do with network, http or servlet.
> > >> > >
> > >> > > thanks.
> > >> > >
> > >> > > -Gary
> > >> > >
> > >> > >
> > >> > > On Thu, May 29, 2014 at 7:44 AM, Franck Wolff <[email protected]
> >
> > >> > wrote:
> > >> > >
> > >> > > > Gary,
> > >> > > >
> > >> > > > See the benchmark classes:
> > >> > > >
> > >> > > >
> > >> > > >
> > >> > >
> > >> >
> > https://github.com/fwolff/amf-benchmark/blob/master/src/org/granite/be
> > >> > nchmark/amf/BenchmarkBlazeDSAmf.java
> > >> > > > vs.
> > >> > > >
> > >> > > >
> > >> > >
> > >> >
> > https://github.com/fwolff/amf-benchmark/blob/master/src/org/granite/be
> > >> > nchmark/amf/BenchmarkGraniteDSAmf.java
> > >> > > >
> > >> > > > GraniteDS needs a bit more configuration, but is still very easy
> > >> > > > to
> > >> > use.
> > >> > > >
> > >> > > > BTW, about DTOs: you can have a look to our Converter/Reverter
> > >> > > > feature, even if it isn't meant to be used this way in the first
> > >> > > > place (see documentation
> > >> > > >
> > >> > > >
> > >> > >
> > >> >
> > http://www.granitedataservices.com/public/docs/latest/docs/reference/f
> > >> > lex/graniteds-refguide-flex.html#extensibility.customtypes
> > >> > > > ).
> > >> > > >
> > >> > > > Let's say you have a bean MyBean on your server and you want to
> > >> > serialize
> > >> > > > MyBeanDTO instead (and vice-versa). You can easily write this
> kind
> > >> > > > of
> > >> > > > converter:
> > >> > > >
> > >> > > > public class MyBeanConverter extends Converter implements
> Reverter
> > >> > > > {
> > >> > > >
> > >> > > >     public MyBeanConverter(Converters converters) {
> > >> > > >         super(converters);
> > >> > > >     }
> > >> > > >
> > >> > > >     // AMF3Deserialization (Converter)...
> > >> > > >
> > >> > > >     @Override
> > >> > > >     protected boolean internalCanConvert(Object value, Type
> > >> > targetType) {
> > >> > > >     return (value instanceof MyBeanDTO);
> > >> > > >     }
> > >> > > >
> > >> > > >     @Override
> > >> > > >     protected Object internalConvert(Object value, Type
> > targetType)
> > >> {
> > >> > > >     MyBean bean = new MyBean();
> > >> > > >     MyBeanDTO dto = (MyBeanDTO)value;
> > >> > > >     // copy properties from dto to bean...
> > >> > > >         return bean;
> > >> > > >     }
> > >> > > >
> > >> > > >     // AMF3Serialization (Reverter)...
> > >> > > >
> > >> > > >     public boolean canRevert(Object value) {
> > >> > > >         return (value instanceof MyBean);
> > >> > > >     }
> > >> > > >
> > >> > > >     public Object revert(Object value) {
> > >> > > >     MyBeanDTO dto = new MyBeanDTO();
> > >> > > >     MyBean bean = (MyBean)value;
> > >> > > >     // copy properties from bean to dto...
> > >> > > >         return dto;
> > >> > > >     }
> > >> > > > }
> > >> > > >
> > >> > > > Then, just plug this new converter (along with any others) in
> your
> > >> > > > granite-config.xml:
> > >> > > >
> > >> > > > <granite-config>
> > >> > > >   <converters>
> > >> > > >     <converter type="path.to.MyBeanConverter" />
> > >> > > >   </converters>
> > >> > > > </granite-config>
> > >> > > >
> > >> > > > According to this configuration, all MyBean instances will be
> > >> > serialized
> > >> > > as
> > >> > > > MyBeanDTOs and all MyBeanDTOs will be deserialized as MyBeans
> (you
> > >> > don't
> > >> > > > need to anything else, your services can return eg. a collection
> > >> > > > of
> > >> > > MyBeans
> > >> > > > it will be serialized as a collection of MyBeanDTOs). Of course,
> > >> > > > it can
> > >> > > be
> > >> > > > a bit restrictive if you want to have different DTOs classes
> for a
> > >> > > > same bean class...
> > >> > > >
> > >> > > > Franck.
> > >> > > >
> > >> > > >
> > >> > > > 2014-05-29 2:33 GMT+02:00 Gary Yang <[email protected]>:
> > >> > > >
> > >> > > > > Sounds great!
> > >> > > > >
> > >> > > > > Do you think it is possible that I can use the
> > >> > > > > serialization/deserialization features as simple as using
> > >> > > > > BlazeDS
> > >> > like
> > >> > > > > below?
> > >> > > > >
> > >> > > > >
> > >> > > > > in pom.xml :
> > >> > > > >
> > >> > > > >         <dependency>
> > >> > > > >             <groupId>org.springframework.flex</groupId>
> > >> > > > >             <artifactId>spring-flex-core</artifactId>
> > >> > > > >         </dependency>
> > >> > > > >
> > >> > > > > then in Java file:
> > >> > > > >
> > >> > > > >         ... ...
> > >> > > > >
> > >> > > > >         Amf3Output aOut= new Amf3Output(new
> > >> SerializationContext());
> > >> > > > >         aOut.setOutputStream( outStream );
> > >> > > > >         aOut.writeObject(data);
> > >> > > > >
> > >> > > > >         ... ...
> > >> > > > >
> > >> > > > >         Amf3Input aIn = new Amf3Input( new
> > SerializationContext()
> > >> );
> > >> > > > >         aIn.setInputStream( inputStream );
> > >> > > > >         data = aIn.readObject();
> > >> > > > >
> > >> > > > > Thanks.
> > >> > > > >
> > >> > > > >
> > >> > > > > - Gary
> > >> > > > >
> > >> > > > >
> > >> > > > >
> > >> > > > > On Wed, May 14, 2014 at 8:51 AM, Franck Wolff
> > >> > > > > <[email protected]>
> > >> > > > wrote:
> > >> > > > >
> > >> > > > > > Hi everybody,
> > >> > > > > >
> > >> > > > > > We have just published the benchmark results on the
> GraniteDS
> > >> blog:
> > >> > > > > >
> > >> > > > > >
> > >> > > > >
> > >> > > >
> > >> > >
> > >> >
> > http://www.granitedataservices.com/2014/05/14/amf3-benchmark-graniteds
> > >> > -3-1-vs-blazeds-4-0
> > >> > > > > > .
> > >> > > > > >
> > >> > > > > > Feedback would be very appreciated.
> > >> > > > > >
> > >> > > > > > Franck
> > >> > > > > > @graniteds
> > >> > > > > >
> > >> > > > >
> > >> > > >
> > >> > >
> > >> >
> > >>
> > >
> > >
> >
>

Reply via email to