📄 tcpadv.java
字号:
/*
* Copyright (c) 2001 Sun Microsystems, Inc. All rights
* reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
*
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in
* the documentation and/or other materials provided with the
* distribution.
*
* 3. The end-user documentation included with the redistribution,
* if any, must include the following acknowledgment:
* "This product includes software developed by the
* Sun Microsystems, Inc. for Project JXTA."
* Alternately, this acknowledgment may appear in the software itself,
* if and wherever such third-party acknowledgments normally appear.
*
* 4. The names "Sun", "Sun Microsystems, Inc.", "JXTA" and "Project JXTA" must
* not be used to endorse or promote products derived from this
* software without prior written permission. For written
* permission, please contact Project JXTA at http://www.jxta.org.
*
* 5. Products derived from this software may not be called "JXTA",
* nor may "JXTA" appear in their name, without prior written
* permission of Sun.
*
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL SUN MICROSYSTEMS OR
* ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
* SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
* LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
* USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
* OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
* OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
* ====================================================================
*
* This software consists of voluntary contributions made by many
* individuals on behalf of Project JXTA. For more
* information on Project JXTA, please see
* <http://www.jxta.org/>.
*
* This license is based on the BSD license adopted by the Apache Foundation.
*
* $Id: TCPAdv.java,v 1.19 2002/06/07 21:11:00 hamada Exp $
*/
package net.jxta.impl.protocol;
import java.io.*;
import java.util.*;
import net.jxta.document.*;
import net.jxta.protocol.*;
import net.jxta.id.ID;
/**
* This class implements the TCPAdvertisement. While being useful,
* application are not required to use it. However, applications that
* donot want to use it will still have to provide a class that
* extends net.jxta.TCP.TCPAdvertisement.
*
*/
public class TCPAdv extends TransportAdvertisement {
private String port = null;
private String multicastaddr = null;
private String multicastport = null;
private String multicastsize = null;
private String server = null;
private String interfaceAddress = null;
private String configMode = null;
private boolean multicastState = true;
public static class Instantiator implements AdvertisementFactory.Instantiator {
/**
* Returns the identifying type of this Advertisement.
*
* @return String the type of advertisement
*
* @since JXTA 1.0
**/
public String getAdvertisementType( ) {
return TCPAdv.getAdvertisementType();
}
/**
* Constructs an instance of <CODE>Advertisement</CODE> matching the type
* specified by the <CODE>advertisementType</CODE> parameter.
*
* @param advertisementType Specifies the mime media type to be associated with the
* <CODE>StructuredDocument</CODE> to be created.
* @return The instance of <CODE>Advertisement</CODE> or null if it
* could not be created.
*
* @exception InvocationTargetException error invoking target constructor
*
* @since JXTA 1.0
**/
public Advertisement newInstance( ) {
return new TCPAdv();
}
/**
* Constructs an instance of <CODE>Advertisement</CODE> matching the type
* specified by the <CODE>advertisementType</CODE> parameter.
*
* @param root Specifies a portion of a StructuredDocument which will be
* converted into an Advertisement.
* @return The instance of <CODE>Advertisement</CODE> or null if it
* could not be created.
*
* @exception InvocationTargetException error invoking target constructor
*
* @since JXTA 1.0
**/
public Advertisement newInstance( net.jxta.document.Element root ) {
return new TCPAdv( root );
}
};
public static String getAdvertisementType() {
return "jxta:TCPTransportAdvertisement";
}
public TCPAdv() {
}
public TCPAdv( Element root ) {
initialize( root );
}
public void initialize(Element root) {
if( !TextElement.class.isInstance( root ) )
throw new IllegalArgumentException( getClass().getName() + " only supports TextElement" );
TextElement doc = (TextElement) root;
String docName = doc.getName();
if( !docName.equals(getAdvertisementType()) &&
!docName.equals(super.getAdvertisementType()) )
throw new IllegalArgumentException( "Could not construct : "
+ getClass().getName()
+ "from doc containing a "
+ doc.getName() );
Enumeration elements = doc.getChildren();
while (elements.hasMoreElements()) {
TextElement elem = (TextElement) elements.nextElement();
if( elem.getName().equals("Protocol")) {
setProtocol( elem.getTextValue() );
continue;
}
if( elem.getName().equals("Port")) {
setPort( elem.getTextValue() );
continue;
}
if( elem.getName().equals("MulticastAddr")) {
setMulticastAddr( elem.getTextValue() );
continue;
}
if( elem.getName().equals("MulticastPort")) {
setMulticastPort( elem.getTextValue() );
continue;
}
if( elem.getName().equals("MulticastSize")) {
setMulticastSize( elem.getTextValue() );
continue;
}
if( elem.getName().equals("MulticastOff")) {
setMulticastState(false);
continue;
}
if( elem.getName().equals("Server")) {
setServer( elem.getTextValue() );
continue;
}
if( elem.getName().equals("InterfaceAddress")) {
setInterfaceAddress( elem.getTextValue() );
continue;
}
if( elem.getName().equals("ConfigMode")) {
setConfigMode( elem.getTextValue() );
continue;
}
}
}
public Document getDocument( MimeMediaType encodeAs ) {
StructuredTextDocument adv = (StructuredTextDocument)
StructuredDocumentFactory.newStructuredDocument(
encodeAs, super.getAdvertisementType() );
if( adv instanceof Attributable ) {
((Attributable)adv).addAttribute( "type", getAdvertisementType() );
}
Element e11 = adv.createElement("Protocol", getProtocol());
adv.appendChild(e11);
Element e12 = adv.createElement("Port", getPort());
adv.appendChild(e12);
if (! getMulticastState()) {
Element e19 = adv.createElement("MulticastOff");
adv.appendChild(e19);
}
Element e13 = adv.createElement("MulticastAddr", getMulticastAddr());
adv.appendChild(e13);
Element e14 = adv.createElement("MulticastPort", getMulticastPort());
adv.appendChild(e14);
Element e15 = adv.createElement("MulticastSize", getMulticastSize());
adv.appendChild(e15);
Element e16 = adv.createElement("Server", getServer());
adv.appendChild(e16);
Element e17 = adv.createElement("InterfaceAddress", getInterfaceAddress());
adv.appendChild(e17);
if (getConfigMode() != null) {
Element e18 = adv.createElement("ConfigMode", getConfigMode());
adv.appendChild(e18);
}
return adv;
}
/**
* returns the port
*@return string port
*
* @since JXTA 1.0
*/
public String getPort() {
return port;
}
/**
* returns the port
* @param string port
*
* @since JXTA 1.0
*/
public void setPort(String port) {
this.port = port;
}
/**
* returns the multicastaddr
* @return string multicastaddr
*
* @since JXTA 1.0
*/
public String getMulticastAddr() {
return multicastaddr;
}
/**
* set the multicastaddr
* @param string set multicastaddr
*
* @since JXTA 1.0
*/
public void setMulticastAddr(String multicastaddr) {
this.multicastaddr = multicastaddr;
}
/**
* returns the multicastport
* @return string multicastport
*
* @since JXTA 1.0
*/
public String getMulticastPort() {
return multicastport;
}
/**
* set the multicastport
* @param string set multicastport
*
* @since JXTA 1.0
*/
public void setMulticastPort(String multicastport) {
this.multicastport = multicastport;
}
/**
* returns the multicastsize
* @return string multicastsize
*
* @since JXTA 1.0
*/
public String getMulticastSize() {
return multicastsize;
}
/**
* set the multicastsize
* @param string set multicastsize
*
* @since JXTA 1.0
*/
public void setMulticastSize(String multicastsize) {
this.multicastsize = multicastsize;
}
/**
* set the multicast off
* @param boolean set multicastoff
*
* @since JXTA 1.0
*/
public void setMulticastState(boolean multicastState) {
this.multicastState = multicastState;
}
/**
* determine whether multicast if off or not
* @param boolean multicastoff
*
* @since JXTA 1.0
*/
public boolean getMulticastState() {
return this.multicastState;
}
/**
* returns the public address
* @return string public address
*
* @since JXTA 1.0
*/
public String getServer() {
return server;
}
/**
* set the public address. That is, a the address of a server socket
* to connect to from the outside. Argument is in the form host:port
*
* @param string address
*
* @since JXTA 1.0
*/
public void setServer(String a) {
this.server = a;
}
/**
* returns the ip address of the interface to which this tcp transport
* binds.
*
* @return string interface address
*
* @since JXTA 1.0
*/
public String getInterfaceAddress() {
return interfaceAddress;
}
/**
* set the ip address of the interface to which this tcp transport
* binds.
*
* @param string the interface address
*
* @since JXTA 1.0
*/
public void setInterfaceAddress(String ia) {
this.interfaceAddress = ia;
}
/**
* returns the config mode. That is, how the user prefers to configure
* the interface address: "auto", "manual", "alwaysmanual".
*
* @return string config mode
*
* @since JXTA 1.0
*/
public String getConfigMode() {
return configMode;
}
/**
* set the config mode. That is, how the user prefers to configure
* the interface address: "auto", "manual", "alwaysmanual".
*
* This is just a pure config item. It is never in published advs. The TCP
* transport strips it when it initializes.
*
* @param string mode. Can be "manual", "auto", "alwaysManual"
* other settings will act as the default which is "auto".
*
* @since JXTA 1.0
*/
public void setConfigMode(String mode) {
this.configMode = mode;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -