All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.jn.agileway.codec.serialization.bson.Bsons Maven / Gradle / Ivy

Go to download

Provide an unified codec API for hession, kryo, protostuff, fst, fes, xson, cbor, jackson, json, etc....

There is a newer version: 3.1.12
Show newest version
package com.jn.agileway.codec.serialization.bson;

import com.jn.agileway.codec.serialization.SchemaedStruct;
import com.jn.langx.annotation.NonNull;
import com.jn.langx.annotation.Nullable;
import com.jn.langx.codec.CodecException;
import com.jn.langx.util.ClassLoaders;
import com.jn.langx.util.Preconditions;
import com.jn.langx.util.collection.Collects;
import com.jn.langx.util.io.IOs;
import com.jn.langx.util.logging.Loggers;
import com.jn.langx.util.reflect.Reflects;
import org.bson.BsonBinaryReader;
import org.bson.BsonBinaryWriter;
import org.bson.codecs.Codec;
import org.bson.codecs.DecoderContext;
import org.bson.codecs.EncoderContext;
import org.bson.codecs.configuration.CodecProvider;
import org.bson.codecs.configuration.CodecRegistries;
import org.bson.codecs.configuration.CodecRegistry;
import org.bson.codecs.pojo.PojoCodecProvider;
import org.bson.io.BasicOutputBuffer;

import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.nio.ByteBuffer;
import java.util.Iterator;
import java.util.List;
import java.util.ServiceLoader;

public class Bsons {
    private static final CodecRegistry codecRegistry;

    static {
        Iterator providerIterator = ServiceLoader.load(CodecProvider.class).iterator();
        List providers = Collects.newArrayList();
        while (providerIterator.hasNext()) {
            try {
                CodecProvider provider = providerIterator.next();
                providers.add(provider);
            }catch (Throwable ex){
                Loggers.getLogger(Bsons.class).warn(ex.getMessage(),ex);
            }
        }

        // Pojo
        PojoCodecProvider pojoCodecProvider = PojoCodecProvider.builder().automatic(true).build();
        providers.add(pojoCodecProvider);

        // java.lang.Object

        codecRegistry = CodecRegistries.fromProviders(providers);
    }

    public static  T deserializeWithSchema(byte[] bytes) {
        Class structClass = SchemaedStruct.class;
        SchemaedStruct struct = deserialize(bytes, structClass);
        byte[] data = struct.getValue();
        String schema = struct.getName();
        try {
            Class tClass = ClassLoaders.loadClass(schema);
            return deserialize(data, tClass);
        } catch (ClassNotFoundException ex) {
            throw new CodecException(ex);
        }
    }

    public static  T deserialize(byte[] bytes, @NonNull Class targetClass) {
        Preconditions.checkNotNull(targetClass);

        ByteBuffer buffer = ByteBuffer.wrap(bytes);
        BsonBinaryReader reader = new BsonBinaryReader(buffer);
        Codec codec = codecRegistry.get(targetClass);
        DecoderContext decoderContext = DecoderContext.builder()
                .build();
        T t = codec.decode(reader, decoderContext);
        return t;
    }


    public static  byte[] serializeWithSchema(T obj){
        try {
            byte[] objBytes = serialize(obj);
            SchemaedStruct struct = new SchemaedStruct();
            struct.setName(Reflects.getFQNClassName(obj.getClass()));
            struct.setValue(objBytes);
            return serialize(struct);
        }catch (IOException ex){
            throw new CodecException(ex);
        }
    }

    /**
     * 序列化对象本身
     */
    public static  byte[] serialize(T obj) throws IOException {
        ByteArrayOutputStream stream = new ByteArrayOutputStream();
        try {
            serialize(obj, stream);
            return stream.toByteArray();
        } finally {
            IOs.close(stream);
        }
    }

    /**
     * 序列化对象本身
     */
    public static  void serialize(T obj, @NonNull OutputStream stream) throws IOException {
        serialize(obj, null, stream);
    }

    /**
     * 序列化对象本身
     */
    public static  void serialize(T obj, @Nullable BsonBinaryWriter writer, @NonNull OutputStream stream) throws IOException {
        Preconditions.checkNotNull(stream);

        BasicOutputBuffer buffer = null;
        if (writer == null) {
            writer = new BsonBinaryWriter(new BasicOutputBuffer());
        }
        buffer = (BasicOutputBuffer) writer.getBsonOutput();
        Class tClass = (Class) obj.getClass();
        Codec codec = codecRegistry.get(tClass);
        EncoderContext encoderContext = EncoderContext.builder()
                .isEncodingCollectibleDocument(true)
                .build();
        codec.encode(writer, obj, encoderContext);
        writer.flush();
        buffer.pipe(stream);
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy