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

org.apache.juneau.serializer.OutputStreamSerializer Maven / Gradle / Ivy

There is a newer version: 9.0.1
Show newest version
// ***************************************************************************************************************************
// * Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements.  See the NOTICE file *
// * distributed with this work for additional information regarding copyright ownership.  The ASF licenses this file        *
// * to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance            *
// * with the License.  You may obtain a copy of the License at                                                              *
// *                                                                                                                         *
// *  http://www.apache.org/licenses/LICENSE-2.0                                                                             *
// *                                                                                                                         *
// * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an  *
// * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.  See the License for the        *
// * specific language governing permissions and limitations under the License.                                              *
// ***************************************************************************************************************************
package org.apache.juneau.serializer;

import static org.apache.juneau.internal.StringUtils.*;

import org.apache.juneau.*;

/**
 * Subclass of {@link Serializer} for byte-based serializers.
 */
public abstract class OutputStreamSerializer extends Serializer {

	/**
	 * Constructor.
	 *
	 * @param propertyStore
	 * 	The property store containing all the settings for this object.
	 * @param produces
	 * 	The media type that this serializer produces.
	 * @param accept
	 * 	The accept media types that the serializer can handle.
	 * 	

* Can contain meta-characters per the media-type specification of * RFC2616/14.1 *

* If empty, then assumes the only media type supported is produces. *

* For example, if this serializer produces "application/json" but should handle media types of * "application/json" and "text/json", then the arguments should be: *
super(propertyStore, "application/json", "application/json", "text/json"); *
...or... *
super(propertyStore, "application/json", "*​/json"); */ protected OutputStreamSerializer(PropertyStore propertyStore, String produces, String...accept) { super(propertyStore, produces, accept); } //-------------------------------------------------------------------------------- // Abstract methods //-------------------------------------------------------------------------------- @Override /* SerializerSession */ public abstract OutputStreamSerializerSession createSession(SerializerSessionArgs args); //-------------------------------------------------------------------------------- // Other methods //-------------------------------------------------------------------------------- @Override /* Serializer */ public final boolean isWriterSerializer() { return false; } /** * Convenience method for serializing an object to a byte. * * @param o The object to serialize. * @return The output serialized to a byte array. * @throws SerializeException If a problem occurred trying to convert the output. */ @Override public final byte[] serialize(Object o) throws SerializeException { return createSession(createDefaultSessionArgs()).serialize(o); } /** * Convenience method for serializing an object to a hex-encoded String. * * @param o The object to serialize. * @return The output serialized to a hex-encoded string. * @throws SerializeException If a problem occurred trying to convert the output. */ public final String serializeToHex(Object o) throws SerializeException { return toHex(serialize(o)); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy