|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object com.fasterxml.jackson.databind.ObjectWriter
public class ObjectWriter
Builder object that can be used for per-serialization configuration of
serialization parameters, such as JSON View and root type to use.
(and thus fully thread-safe with no external synchronization);
new instances are constructed for different configurations.
Instances are initially constructed by ObjectMapper
and can be
reused in completely thread-safe manner with no explicit synchronization
Field Summary | |
---|---|
protected SerializationConfig |
_config
General serialization configuration settings |
protected JsonFactory |
_jsonFactory
Factory used for constructing JsonGenerator s |
protected PrettyPrinter |
_prettyPrinter
To allow for dynamic enabling/disabling of pretty printing, pretty printer can be optionally configured for writer as well |
protected JsonSerializer<Object> |
_rootSerializer
We may pre-fetch serializer if _rootType
is known, and if so, reuse it afterwards. |
protected JavaType |
_rootType
Specified root serialization type to use; can be same as runtime type, but usually one of its super types |
protected FormatSchema |
_schema
When using data format that uses a schema, schema is passed to generator. |
protected SerializerFactory |
_serializerFactory
|
protected DefaultSerializerProvider |
_serializerProvider
|
protected static PrettyPrinter |
NULL_PRETTY_PRINTER
We need to keep track of explicit disabling of pretty printing; easiest to do by a token value. |
Constructor Summary | |
---|---|
protected |
ObjectWriter(ObjectMapper mapper,
SerializationConfig config)
Alternative constructor for initial instantiation by ObjectMapper |
protected |
ObjectWriter(ObjectMapper mapper,
SerializationConfig config,
FormatSchema s)
Alternative constructor for initial instantiation by ObjectMapper |
protected |
ObjectWriter(ObjectMapper mapper,
SerializationConfig config,
JavaType rootType,
PrettyPrinter pp)
Constructor used by ObjectMapper for initial instantiation |
protected |
ObjectWriter(ObjectWriter base,
SerializationConfig config)
Copy constructor used for building variations. |
protected |
ObjectWriter(ObjectWriter base,
SerializationConfig config,
JavaType rootType,
JsonSerializer<Object> rootSer,
PrettyPrinter pp,
FormatSchema s)
Copy constructor used for building variations. |
Method Summary | |
---|---|
protected void |
_configAndWriteValue(JsonGenerator jgen,
Object value)
Method called to configure the generator as necessary and then call write functionality |
protected JsonSerializer<Object> |
_prefetchRootSerializer(SerializationConfig config,
JavaType valueType)
Method called to locate (root) serializer ahead of time, if permitted by configuration. |
protected DefaultSerializerProvider |
_serializerProvider(SerializationConfig config)
Overridable helper method used for constructing SerializerProvider to use for serialization. |
boolean |
canSerialize(Class<?> type)
|
JsonFactory |
getJsonFactory()
|
TypeFactory |
getTypeFactory()
|
boolean |
isEnabled(JsonParser.Feature f)
|
boolean |
isEnabled(MapperFeature f)
|
boolean |
isEnabled(SerializationFeature f)
|
Version |
version()
Method that will return version information stored in and read from jar that contains this class. |
ObjectWriter |
with(Base64Variant b64variant)
Method that will construct a new instance that uses specified default Base64Variant for base64 encoding |
ObjectWriter |
with(DateFormat df)
Fluent factory method that will construct a new writer instance that will use specified date format for serializing dates; or if null passed, one that will serialize dates as numeric timestamps. |
ObjectWriter |
with(FilterProvider filterProvider)
Method that will construct a new instance that uses specified provider for resolving filter instances by id. |
ObjectWriter |
with(Locale l)
|
ObjectWriter |
with(PrettyPrinter pp)
Method that will construct a new instance that will use specified pretty printer (or, if null, will not do any pretty-printing) |
ObjectWriter |
with(SerializationFeature feature)
Method for constructing a new instance that is configured with specified feature enabled. |
ObjectWriter |
with(SerializationFeature first,
SerializationFeature... other)
Method for constructing a new instance that is configured with specified features enabled. |
ObjectWriter |
with(TimeZone tz)
|
ObjectWriter |
withDefaultPrettyPrinter()
Method that will construct a new instance that will use the default pretty printer for serialization. |
ObjectWriter |
withFeatures(SerializationFeature... features)
Method for constructing a new instance that is configured with specified features enabled. |
ObjectWriter |
without(SerializationFeature feature)
Method for constructing a new instance that is configured with specified feature enabled. |
ObjectWriter |
without(SerializationFeature first,
SerializationFeature... other)
Method for constructing a new instance that is configured with specified features enabled. |
ObjectWriter |
withoutFeatures(SerializationFeature... features)
Method for constructing a new instance that is configured with specified features enabled. |
ObjectWriter |
withRootName(String rootName)
Method for constructing a new instance with configuration that specifies what root name to use for "root element wrapping". |
ObjectWriter |
withSchema(FormatSchema schema)
Method that will construct a new instance that uses specific format schema for serialization. |
ObjectWriter |
withType(Class<?> rootType)
Method that will construct a new instance that uses specific type as the root type for serialization, instead of runtime dynamic type of the root object itself. |
ObjectWriter |
withType(JavaType rootType)
Method that will construct a new instance that uses specific type as the root type for serialization, instead of runtime dynamic type of the root object itself. |
ObjectWriter |
withType(TypeReference<?> rootType)
|
ObjectWriter |
withView(Class<?> view)
Method that will construct a new instance that uses specified serialization view for serialization (with null basically disables view processing) |
void |
writeValue(File resultFile,
Object value)
Method that can be used to serialize any Java value as JSON output, written to File provided. |
void |
writeValue(JsonGenerator jgen,
Object value)
Method that can be used to serialize any Java value as JSON output, using provided JsonGenerator . |
void |
writeValue(OutputStream out,
Object value)
Method that can be used to serialize any Java value as JSON output, using output stream provided (using encoding JsonEncoding.UTF8 ). |
void |
writeValue(Writer w,
Object value)
Method that can be used to serialize any Java value as JSON output, using Writer provided. |
byte[] |
writeValueAsBytes(Object value)
Method that can be used to serialize any Java value as a byte array. |
String |
writeValueAsString(Object value)
Method that can be used to serialize any Java value as a String. |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
protected static final PrettyPrinter NULL_PRETTY_PRINTER
protected final SerializationConfig _config
protected final DefaultSerializerProvider _serializerProvider
protected final SerializerFactory _serializerFactory
protected final JsonFactory _jsonFactory
JsonGenerator
s
protected final JavaType _rootType
protected final JsonSerializer<Object> _rootSerializer
_rootType
is known, and if so, reuse it afterwards.
This allows avoiding further serializer lookups and increases
performance a bit on cases where readers are reused.
protected final PrettyPrinter _prettyPrinter
protected final FormatSchema _schema
Constructor Detail |
---|
protected ObjectWriter(ObjectMapper mapper, SerializationConfig config, JavaType rootType, PrettyPrinter pp)
ObjectMapper
for initial instantiation
protected ObjectWriter(ObjectMapper mapper, SerializationConfig config)
ObjectMapper
protected ObjectWriter(ObjectMapper mapper, SerializationConfig config, FormatSchema s)
ObjectMapper
protected ObjectWriter(ObjectWriter base, SerializationConfig config, JavaType rootType, JsonSerializer<Object> rootSer, PrettyPrinter pp, FormatSchema s)
protected ObjectWriter(ObjectWriter base, SerializationConfig config)
Method Detail |
---|
public Version version()
version
in interface Versioned
public ObjectWriter with(SerializationFeature feature)
public ObjectWriter with(SerializationFeature first, SerializationFeature... other)
public ObjectWriter withFeatures(SerializationFeature... features)
public ObjectWriter without(SerializationFeature feature)
public ObjectWriter without(SerializationFeature first, SerializationFeature... other)
public ObjectWriter withoutFeatures(SerializationFeature... features)
public ObjectWriter with(DateFormat df)
Note that the method does NOT change state of this reader, but rather construct and returns a newly configured instance.
public ObjectWriter withDefaultPrettyPrinter()
public ObjectWriter with(FilterProvider filterProvider)
public ObjectWriter with(PrettyPrinter pp)
public ObjectWriter withRootName(String rootName)
SerializationConfig.withRootName(String)
for details.
Note that method does NOT change state of this reader, but rather construct and returns a newly configured instance.
public ObjectWriter withSchema(FormatSchema schema)
Note that method does NOT change state of this reader, but rather construct and returns a newly configured instance.
public ObjectWriter withType(JavaType rootType)
Note that method does NOT change state of this reader, but rather construct and returns a newly configured instance.
public ObjectWriter withType(Class<?> rootType)
public ObjectWriter withType(TypeReference<?> rootType)
public ObjectWriter withView(Class<?> view)
Note that the method does NOT change state of this reader, but rather construct and returns a newly configured instance.
public ObjectWriter with(Locale l)
public ObjectWriter with(TimeZone tz)
public ObjectWriter with(Base64Variant b64variant)
Base64Variant
for base64 encoding
public boolean isEnabled(SerializationFeature f)
public boolean isEnabled(MapperFeature f)
public boolean isEnabled(JsonParser.Feature f)
public JsonFactory getJsonFactory()
public TypeFactory getTypeFactory()
public void writeValue(JsonGenerator jgen, Object value) throws IOException, JsonGenerationException, JsonMappingException
JsonGenerator
.
IOException
JsonGenerationException
JsonMappingException
public void writeValue(File resultFile, Object value) throws IOException, JsonGenerationException, JsonMappingException
IOException
JsonGenerationException
JsonMappingException
public void writeValue(OutputStream out, Object value) throws IOException, JsonGenerationException, JsonMappingException
JsonEncoding.UTF8
).
Note: method does not close the underlying stream explicitly
here; however, JsonFactory
this mapper uses may choose
to close the stream depending on its settings (by default,
it will try to close it when JsonGenerator
we construct
is closed).
IOException
JsonGenerationException
JsonMappingException
public void writeValue(Writer w, Object value) throws IOException, JsonGenerationException, JsonMappingException
Note: method does not close the underlying stream explicitly
here; however, JsonFactory
this mapper uses may choose
to close the stream depending on its settings (by default,
it will try to close it when JsonGenerator
we construct
is closed).
IOException
JsonGenerationException
JsonMappingException
public String writeValueAsString(Object value) throws JsonProcessingException
writeValue(Writer,Object)
with StringWriter
and constructing String, but more efficient.
Note: prior to version 2.1, throws clause included IOException
; 2.1 removed it.
JsonProcessingException
public byte[] writeValueAsBytes(Object value) throws JsonProcessingException
writeValue(Writer,Object)
with ByteArrayOutputStream
and getting bytes, but more efficient.
Encoding used will be UTF-8.
Note: prior to version 2.1, throws clause included IOException
; 2.1 removed it.
JsonProcessingException
public boolean canSerialize(Class<?> type)
protected DefaultSerializerProvider _serializerProvider(SerializationConfig config)
SerializerProvider
to use for serialization.
protected final void _configAndWriteValue(JsonGenerator jgen, Object value) throws IOException, JsonGenerationException, JsonMappingException
IOException
JsonGenerationException
JsonMappingException
protected final JsonSerializer<Object> _prefetchRootSerializer(SerializationConfig config, JavaType valueType)
|
||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |