jdk/src/sample/share/nio/server/ChannelIO.java
author emc
Wed, 05 Nov 2014 08:37:04 -0500
changeset 27386 784414cffd9a
parent 25859 3317bb8137f4
permissions -rw-r--r--
8035259: javac, incorrect shadowing of classes vs type parameters Summary: Cause javac to look at type variables first when resolving names in an extends/implements list Reviewed-by: mcimadamore, jlahoda
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     1
/*
14342
8435a30053c1 7197491: update copyright year to match last edit in jdk8 jdk repository
alanb
parents: 10292
diff changeset
     2
 * Copyright (c) 2004, 2011, Oracle and/or its affiliates. All rights reserved.
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
     3
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     4
 * Redistribution and use in source and binary forms, with or without
90ce3da70b43 Initial load
duke
parents:
diff changeset
     5
 * modification, are permitted provided that the following conditions
90ce3da70b43 Initial load
duke
parents:
diff changeset
     6
 * are met:
90ce3da70b43 Initial load
duke
parents:
diff changeset
     7
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
     8
 *   - Redistributions of source code must retain the above copyright
90ce3da70b43 Initial load
duke
parents:
diff changeset
     9
 *     notice, this list of conditions and the following disclaimer.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    10
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    11
 *   - Redistributions in binary form must reproduce the above copyright
90ce3da70b43 Initial load
duke
parents:
diff changeset
    12
 *     notice, this list of conditions and the following disclaimer in the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    13
 *     documentation and/or other materials provided with the distribution.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    14
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 2
diff changeset
    15
 *   - Neither the name of Oracle nor the names of its
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    16
 *     contributors may be used to endorse or promote products derived
90ce3da70b43 Initial load
duke
parents:
diff changeset
    17
 *     from this software without specific prior written permission.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    18
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    19
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
90ce3da70b43 Initial load
duke
parents:
diff changeset
    20
 * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    21
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
90ce3da70b43 Initial load
duke
parents:
diff changeset
    22
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR
90ce3da70b43 Initial load
duke
parents:
diff changeset
    23
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    24
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
90ce3da70b43 Initial load
duke
parents:
diff changeset
    25
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
90ce3da70b43 Initial load
duke
parents:
diff changeset
    26
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
90ce3da70b43 Initial load
duke
parents:
diff changeset
    27
 * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
90ce3da70b43 Initial load
duke
parents:
diff changeset
    28
 * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
90ce3da70b43 Initial load
duke
parents:
diff changeset
    29
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    30
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    31
10292
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    32
/*
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    33
 * This source code is provided to illustrate the usage of a given feature
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    34
 * or technique and has been deliberately simplified. Additional steps
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    35
 * required for a production-quality application, such as security checks,
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    36
 * input validation and proper error handling, might not be present in
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    37
 * this sample code.
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    38
 */
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    39
ed7db6a12c2a 7067811: Update demo/sample code to state it should not be used for production
nloodin
parents: 5506
diff changeset
    40
2
90ce3da70b43 Initial load
duke
parents:
diff changeset
    41
import java.io.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    42
import java.nio.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    43
import java.nio.channels.*;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    44
90ce3da70b43 Initial load
duke
parents:
diff changeset
    45
/**
90ce3da70b43 Initial load
duke
parents:
diff changeset
    46
 * A helper class for properly sizing inbound byte buffers and
90ce3da70b43 Initial load
duke
parents:
diff changeset
    47
 * redirecting I/O calls to the proper SocketChannel call.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    48
 * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
    49
 * Many of these calls may seem unnecessary until you consider
90ce3da70b43 Initial load
duke
parents:
diff changeset
    50
 * that they are placeholders for the secure variant, which is much
90ce3da70b43 Initial load
duke
parents:
diff changeset
    51
 * more involved.  See ChannelIOSecure for more information.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    52
 *
90ce3da70b43 Initial load
duke
parents:
diff changeset
    53
 * @author Brad R. Wetmore
90ce3da70b43 Initial load
duke
parents:
diff changeset
    54
 * @author Mark Reinhold
90ce3da70b43 Initial load
duke
parents:
diff changeset
    55
 */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    56
class ChannelIO {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    57
90ce3da70b43 Initial load
duke
parents:
diff changeset
    58
    protected SocketChannel sc;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    59
90ce3da70b43 Initial load
duke
parents:
diff changeset
    60
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
    61
     * All of the inbound request data lives here until we determine
90ce3da70b43 Initial load
duke
parents:
diff changeset
    62
     * that we've read everything, then we pass that data back to the
90ce3da70b43 Initial load
duke
parents:
diff changeset
    63
     * caller.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    64
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    65
    protected ByteBuffer requestBB;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    66
    static private int requestBBSize = 4096;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    67
90ce3da70b43 Initial load
duke
parents:
diff changeset
    68
    protected ChannelIO(SocketChannel sc, boolean blocking)
90ce3da70b43 Initial load
duke
parents:
diff changeset
    69
            throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    70
        this.sc = sc;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    71
        sc.configureBlocking(blocking);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    72
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    73
90ce3da70b43 Initial load
duke
parents:
diff changeset
    74
    static ChannelIO getInstance(SocketChannel sc, boolean blocking)
90ce3da70b43 Initial load
duke
parents:
diff changeset
    75
            throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    76
        ChannelIO cio = new ChannelIO(sc, blocking);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    77
        cio.requestBB = ByteBuffer.allocate(requestBBSize);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    78
90ce3da70b43 Initial load
duke
parents:
diff changeset
    79
        return cio;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    80
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    81
90ce3da70b43 Initial load
duke
parents:
diff changeset
    82
    SocketChannel getSocketChannel() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    83
        return sc;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    84
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    85
90ce3da70b43 Initial load
duke
parents:
diff changeset
    86
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
    87
     * Return a ByteBuffer with "remaining" space to work.  If you have to
90ce3da70b43 Initial load
duke
parents:
diff changeset
    88
     * reallocate the ByteBuffer, copy the existing info into the new buffer.
90ce3da70b43 Initial load
duke
parents:
diff changeset
    89
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
    90
    protected void resizeRequestBB(int remaining) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    91
        if (requestBB.remaining() < remaining) {
90ce3da70b43 Initial load
duke
parents:
diff changeset
    92
            // Expand buffer for large request
90ce3da70b43 Initial load
duke
parents:
diff changeset
    93
            ByteBuffer bb = ByteBuffer.allocate(requestBB.capacity() * 2);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    94
            requestBB.flip();
90ce3da70b43 Initial load
duke
parents:
diff changeset
    95
            bb.put(requestBB);
90ce3da70b43 Initial load
duke
parents:
diff changeset
    96
            requestBB = bb;
90ce3da70b43 Initial load
duke
parents:
diff changeset
    97
        }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    98
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
    99
90ce3da70b43 Initial load
duke
parents:
diff changeset
   100
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   101
     * Perform any handshaking processing.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   102
     * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   103
     * This variant is for Servers without SelectionKeys (e.g.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   104
     * blocking).
90ce3da70b43 Initial load
duke
parents:
diff changeset
   105
     * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   106
     * return true when we're done with handshaking.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   107
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   108
    boolean doHandshake() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   109
        return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   110
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   111
90ce3da70b43 Initial load
duke
parents:
diff changeset
   112
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   113
     * Perform any handshaking processing.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   114
     * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   115
     * This variant is for Servers with SelectionKeys, so that
90ce3da70b43 Initial load
duke
parents:
diff changeset
   116
     * we can register for selectable operations (e.g. selectable
90ce3da70b43 Initial load
duke
parents:
diff changeset
   117
     * non-blocking).
90ce3da70b43 Initial load
duke
parents:
diff changeset
   118
     * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   119
     * return true when we're done with handshaking.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   120
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   121
    boolean doHandshake(SelectionKey sk) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   122
        return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   123
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   124
90ce3da70b43 Initial load
duke
parents:
diff changeset
   125
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   126
     * Resize (if necessary) the inbound data buffer, and then read more
90ce3da70b43 Initial load
duke
parents:
diff changeset
   127
     * data into the read buffer.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   128
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   129
    int read() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   130
        /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   131
         * Allocate more space if less than 5% remains
90ce3da70b43 Initial load
duke
parents:
diff changeset
   132
         */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   133
        resizeRequestBB(requestBBSize/20);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   134
        return sc.read(requestBB);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   135
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   136
90ce3da70b43 Initial load
duke
parents:
diff changeset
   137
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   138
     * All data has been read, pass back the request in one buffer.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   139
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   140
    ByteBuffer getReadBuf() {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   141
        return requestBB;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   142
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   143
90ce3da70b43 Initial load
duke
parents:
diff changeset
   144
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   145
     * Write the src buffer into the socket channel.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   146
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   147
    int write(ByteBuffer src) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   148
        return sc.write(src);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   149
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   150
90ce3da70b43 Initial load
duke
parents:
diff changeset
   151
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   152
     * Perform a FileChannel.TransferTo on the socket channel.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   153
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   154
    long transferTo(FileChannel fc, long pos, long len) throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   155
        return fc.transferTo(pos, len, sc);
90ce3da70b43 Initial load
duke
parents:
diff changeset
   156
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   157
90ce3da70b43 Initial load
duke
parents:
diff changeset
   158
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   159
     * Flush any outstanding data to the network if possible.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   160
     * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   161
     * This isn't really necessary for the insecure variant, but needed
90ce3da70b43 Initial load
duke
parents:
diff changeset
   162
     * for the secure one where intermediate buffering must take place.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   163
     * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   164
     * Return true if successful.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   165
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   166
    boolean dataFlush() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   167
        return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   168
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   169
90ce3da70b43 Initial load
duke
parents:
diff changeset
   170
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   171
     * Start any connection shutdown processing.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   172
     * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   173
     * This isn't really necessary for the insecure variant, but needed
90ce3da70b43 Initial load
duke
parents:
diff changeset
   174
     * for the secure one where intermediate buffering must take place.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   175
     * <P>
90ce3da70b43 Initial load
duke
parents:
diff changeset
   176
     * Return true if successful, and the data has been flushed.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   177
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   178
    boolean shutdown() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   179
        return true;
90ce3da70b43 Initial load
duke
parents:
diff changeset
   180
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   181
90ce3da70b43 Initial load
duke
parents:
diff changeset
   182
    /*
90ce3da70b43 Initial load
duke
parents:
diff changeset
   183
     * Close the underlying connection.
90ce3da70b43 Initial load
duke
parents:
diff changeset
   184
     */
90ce3da70b43 Initial load
duke
parents:
diff changeset
   185
    void close() throws IOException {
90ce3da70b43 Initial load
duke
parents:
diff changeset
   186
        sc.close();
90ce3da70b43 Initial load
duke
parents:
diff changeset
   187
    }
90ce3da70b43 Initial load
duke
parents:
diff changeset
   188
90ce3da70b43 Initial load
duke
parents:
diff changeset
   189
}