smbplugin.java
来自「opennms得相关源码 请大家看看」· Java 代码 · 共 144 行
JAVA
144 行
//// This file is part of the OpenNMS(R) Application.//// OpenNMS(R) is Copyright (C) 2002-2003 The OpenNMS Group, Inc. All rights reserved.// OpenNMS(R) is a derivative work, containing both original code, included code and modified// code that was published under the GNU General Public License. Copyrights for modified // and included code are below.//// OpenNMS(R) is a registered trademark of The OpenNMS Group, Inc.//// Copyright (C) 1999-2001 Oculan Corp. All rights reserved.//// This program is free software; you can redistribute it and/or modify// it under the terms of the GNU General Public License as published by// the Free Software Foundation; either version 2 of the License, or// (at your option) any later version.//// This program is distributed in the hope that it will be useful,// but WITHOUT ANY WARRANTY; without even the implied warranty of// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the// GNU General Public License for more details. //// You should have received a copy of the GNU General Public License// along with this program; if not, write to the Free Software// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.// // For more information contact: // OpenNMS Licensing <license@opennms.org>// http://www.opennms.org/// http://www.opennms.com///// Tab Size = 8//package org.opennms.netmgt.capsd;import java.io.IOException;import java.net.InetAddress;import java.net.UnknownHostException;import java.util.Map;import jcifs.netbios.NbtAddress;import org.apache.log4j.Category;import org.opennms.core.utils.ThreadCategory;/** * <P> * This class is designed to be used by the capabilities daemon to test for SMB * support on remote interfaces. The class implements the Plugin interface that * allows it to be used along with other plugins by the daemon. * </P> * * @author <A HREF="mailto:mike@opennms.org">Mike </A> * @author <A HREF="mailto:weave@oculan.com">Weave </A> * @author <A HREF="http://www.opennsm.org">OpenNMS </A> * */public final class SmbPlugin extends AbstractPlugin { /** * The protocol that this plugin checks for. */ private final static String PROTOCOL_NAME = "SMB"; /** * Test to see if the passed host talks SMB & has a NetBIOS name. * * @param host * The remote host to check. * * @return True if the remote interface responds talks SMB and has a NETBIOS * name. False otherwise. */ private boolean isSmb(InetAddress host) { Category log = ThreadCategory.getInstance(getClass()); boolean isAServer = false; try { NbtAddress nbtAddr = NbtAddress.getByName(host.getHostAddress()); // If the retrieved SMB name is equal to the IP address // of the host, the it is safe to assume that the interface // does not support SMB // if (nbtAddr.getHostName().equals(host.getHostAddress())) { if (log.isDebugEnabled()) log.debug("SmbPlugin: failed to retrieve SMB name for " + host.getHostAddress()); } else { isAServer = true; } } catch (UnknownHostException e) { if (log.isDebugEnabled()) log.debug("SmbPlugin: UnknownHostException: " + e.getMessage()); } catch (IOException e) { log.info("SmbPlugin: An unexpected I/O exception occured checking host " + host.getHostAddress(), e); } catch (Throwable t) { log.error("SmbPlugin: An undeclared throwable exception was caught checking host " + host.getHostAddress(), t); } return isAServer; } /** * Returns the name of the protocol that this plugin checks on the target * system for support. * * @return The protocol name for this plugin. */ public String getProtocolName() { return PROTOCOL_NAME; } /** * Returns true if the protocol defined by this plugin is supported. If the * protocol is not supported then a false value is returned to the caller. * * @param address * The address to check for support. * * @return True if the protocol is supported by the address. */ public boolean isProtocolSupported(InetAddress address) { return isSmb(address); } /** * Returns true if the protocol defined by this plugin is supported. If the * protocol is not supported then a false value is returned to the caller. * The qualifier map passed to the method is used by the plugin to return * additional information by key-name. These key-value pairs can be added to * service events if needed. * * @param address * The address to check for support. * @param qualifiers * The map where qualification are set by the plugin. * * @return True if the protocol is supported by the address. */ public boolean isProtocolSupported(InetAddress address, Map qualifiers) { return isSmb(address); }}
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?