ttomcat-1778514358873.zip-extract/apache-tomcat-11.0.18-src/java/org/apache/catalina/tribes/ByteMessage.java

Path
ttomcat-1778514358873.zip-extract/apache-tomcat-11.0.18-src/java/org/apache/catalina/tribes/ByteMessage.java
Status
scanned
Type
file
Name
ByteMessage.java
Extension
.java
Programming language
Java
Mime type
text/plain
File type
ASCII text, with CRLF line terminators
Tag

      
    
Rootfs path

      
    
Size
3135 (3.1 KB)
MD5
9d9ef157d2a24dd6cba63e90da0b8b5f
SHA1
fb756559f41a67727e4fcbf07ce347e073ef4267
SHA256
065e9db97daa9f2a57a8ac240c3fd1f75d8aad8508d0841dba02c8e97a69e9de
SHA512

      
    
SHA1_git
727e21ffb3e64257ea358348acda248568eacad4
Is binary

      
    
Is text
True
Is archive

      
    
Is media

      
    
Is legal

      
    
Is manifest

      
    
Is readme

      
    
Is top level

      
    
Is key file

      
    
ByteMessage.java | 3.1 KB |

/* * 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.catalina.tribes; import java.io.Externalizable; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectOutput; /** * A byte message is not serialized and deserialized by the channel instead it is sent as a byte array. * <p> * By default, Tribes uses java serialization when it receives an object to be sent over the wire. Java serialization is * not the most efficient of serializing data, and Tribes might not even have access to the correct class loaders to * deserialize the object properly. * <p> * The ByteMessage class is a class where the channel when it receives it will not attempt to perform serialization, * instead it will simply stream the <code>getMessage()</code> bytes. * <p> * If you are using multiple applications on top of Tribes you should add some sort of header so that you can decide * with the <code>ChannelListener.accept()</code> whether this message was intended for you. */ public class ByteMessage implements Externalizable { /** * Storage for the message to be sent */ private byte[] message; /** * Creates an empty byte message. * <p> * Constructor also for deserialization. */ public ByteMessage() { } /** * Creates a byte message with * * @param data byte[] - the message contents */ public ByteMessage(byte[] data) { message = data; } /** * Returns the message contents of this byte message * * @return byte[] - message contents, can be null */ public byte[] getMessage() { return message; } /** * Sets the message contents of this byte message * * @param message byte[] */ public void setMessage(byte[] message) { this.message = message; } @Override public void readExternal(ObjectInput in) throws IOException { int length = in.readInt(); message = new byte[length]; in.readFully(message); } @Override public void writeExternal(ObjectOutput out) throws IOException { out.writeInt(message != null ? message.length : 0); if (message != null) { out.write(message, 0, message.length); } } }
Detected license expression
apache-2.0
Detected license expression (SPDX)
Apache-2.0
Percentage of license text
30.99
Copyrights

      
    
Holders

      
    
Authors

      
    
License detections License expression License expression SPDX
apache_2_0-4bde3f57-78aa-4201-96bf-531cba09e7de apache-2.0 Apache-2.0
URL Start line End line
http://www.apache.org/licenses/LICENSE-2.0 9 9