Path: blob/aarch64-shenandoah-jdk8u272-b10/jdk/src/share/sample/nio/chatserver/NameReader.java
38829 views
/*1* Copyright (c) 2011 Oracle and/or its affiliates. All rights reserved.2*3* Redistribution and use in source and binary forms, with or without4* modification, are permitted provided that the following conditions5* are met:6*7* - Redistributions of source code must retain the above copyright8* notice, this list of conditions and the following disclaimer.9*10* - Redistributions in binary form must reproduce the above copyright11* notice, this list of conditions and the following disclaimer in the12* documentation and/or other materials provided with the distribution.13*14* - Neither the name of Oracle nor the names of its15* contributors may be used to endorse or promote products derived16* from this software without specific prior written permission.17*18* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS19* IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,20* THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR21* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR22* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,23* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,24* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR25* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF26* LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING27* NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS28* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.29*/3031/*32* This source code is provided to illustrate the usage of a given feature33* or technique and has been deliberately simplified. Additional steps34* required for a production-quality application, such as security checks,35* input validation and proper error handling, might not be present in36* this sample code.37*/383940import java.nio.ByteBuffer;4142/**43* The first state a newly connected {@code Client} is in, this44* handles writing out the welcoming message and reads the response45* up to a newline. When a newline character have been received46* it changes the handler from NameReader to MessageReader on the47* client.48*/49class NameReader implements DataReader {50private final StringBuilder buffer = new StringBuilder();51private final ChatServer chatServer;52private boolean once = true;53private static final String NEWLINE = "\n";5455public NameReader(ChatServer chatServer) {56this.chatServer = chatServer;57}5859/**60* Writes the welcoming message to the client the first time this method61* is called.62*63* @param client the client to receive the message64*/65@Override66public void beforeRead(Client client) {67// if it is a long name that takes more than one read we only want to display Name: once.68if (once) {69client.writeStringMessage("Name: ");70once = false;71}72}7374public boolean acceptsMessages() {75return false;76}7778/**79* Receives incoming data from the socket, searches for a newline80* and tries to set the username if one is found81*/82@Override83public void onData(Client client, ByteBuffer buffer, int bytes) {84buffer.flip();85String name;86name = this.buffer.append(new String(buffer.array(), 0, bytes)).toString();87if (name.contains(NEWLINE)) {88onUserNameRead(client, name);89}90}9192/**93* Splits the name on the newlines, takes the first as the username94* and appends everything else to the clients message buffer.95* Sets the clients handler to MessageReader.96*97* @param client the client to set the username for98* @param name the string containing the buffered input99*/100private void onUserNameRead(Client client, String name) {101String[] strings = name.split(NEWLINE, 2);102client.setUserName(strings[0].trim());103sendRemainingParts(client, strings);104client.setReader(new ClientReader(chatServer, new MessageReader(chatServer)));105client.writeStringMessage("Welcome " + client.getUserName() + "\n");106}107108/**109* Appends the remaining parts to the clients message buffer110*111* @param client the client112* @param strings the messages to append to the buffer113*/114private void sendRemainingParts(Client client, String[] strings) {115for (int i = 1; i < strings.length; ++i) {116client.appendMessage(strings[i]);117}118}119}120121122