- 浏览: 192622 次
- 性别:
- 来自: 长沙
文章分类
最新评论
-
LXX516:
LXX516 写道你好,运行时出现如下问题:E/Trace(1 ...
PC客户端与Android实现图片传送 -
LXX516:
你好,运行时出现如下问题:E/Trace(15019): er ...
PC客户端与Android实现图片传送 -
huzhenyu:
希望各位大顶起,支持国产免费软件
公式编辑器MathMarkEdit1.0发布 -
zhangyou1010:
默认是8000的端口,如果用sh catalina.sh jp ...
使用eclipse远程调试部署在tomcat上的应用程序 -
zhangyou1010:
有时间,也要玩玩QT,哈哈。
Qt Grid布局
from: http://wooden-baby.iteye.com/blog/351912
使用java线程扫描局域网ip简单方案
java 快速扫描局域网 ip 之二级嵌套类
方案一 :
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.ArrayList;
public class LanIP {
public ArrayList<String> getLanIPArrayList() {
ArrayList<String> arrayIP = null;
try {
InitSystem initSystem = null;
initSystem = new InitSystem();
Thread thread = new Thread(initSystem);
thread.start();
thread.join();
arrayIP = initSystem.getArrayIPUsed();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
return arrayIP;
}
private class InitSystem implements Runnable {
private int firstIP = 2;// 查询的 IP 地址的最后一位起始点
private int lastIP = 255;// 查询的 IP 地址的最后一位结束点
private volatile ArrayList<Thread> arrayThread;// 子线程段
private final int MAXTHREADNUM = 30; // 最大同时进行的子线程数量
private int threadNumNow;// 当前正在进行的子线程数量
private volatile ArrayList<String> arrayIP;// 局域网查询所有可能的 IP 地址的结果集
private volatile ArrayList<String> arrayIPUsed;// 局域网查询已经使用的 IP 地址的结果集
private InitSystem(String ip) {
arrayIP = new ArrayList<String>();
arrayIPUsed = new ArrayList<String>();
arrayThread = new ArrayList<Thread>();
setIPAddressList(ip);
}
private InitSystem() throws UnknownHostException {
this(InetAddress.getLocalHost().getHostAddress());
}
private synchronized ArrayList<String> getArrayIPUsed() {
try {
while (arrayIP.size() > 0) {
Thread.sleep(300);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
return arrayIPUsed;
}
private void setIPAddressList(String ip) {
// 根据这个 ip 地址查询它所在的局域网的所有可能 IP 地址的集合
int lastPointIndex = ip.lastIndexOf('.');
String stringIPHead = ip.substring(0, ++lastPointIndex);
String stringIP = null;
for (int i = firstIP; i <= lastIP; i++) {
stringIP = stringIPHead + i;
arrayIP.add(stringIP);
}
}
public void run() {
synchronized (this) {
try {
while (arrayIP.size() > 0) {
while (threadNumNow >= MAXTHREADNUM) {
for (Thread thread : arrayThread) {
if (!thread.getState().equals(
Thread.State.TERMINATED)) {
thread.join(5);
}
--threadNumNow;
}
arrayThread = new ArrayList<Thread>();
}
Thread thread = new Thread(new InnerClass(arrayIP
.remove(0)));
thread.start();
threadNumNow++;
arrayThread.add(thread);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
private class InnerClass implements Runnable {
// 线程查询一个 IP 是否是可以连接的 是则加入到相应的 IP 数组
private String ip;
private InnerClass(String ip) {
this.ip = ip;
}
private boolean isUsedIPAddress(String ip) {
synchronized (this) {
// 判断这个 IP 地址在当前局域网中是否是可连接的 IP
Process process = null;
BufferedReader bufReader = null;
String bufReadLineString = null;
try {
process = Runtime.getRuntime().exec(
"ping " + ip + " -w 100 -n 1");
bufReader = new BufferedReader(new InputStreamReader(
process.getInputStream()));
for (int i = 0; i < 6 && bufReader != null; i++) {
bufReader.readLine();
}
bufReadLineString = bufReader.readLine();
if (bufReadLineString == null) {
process.destroy();
return false;
}
if (bufReadLineString.indexOf("timed out") > 0
|| bufReadLineString.length() < 17
|| bufReadLineString.indexOf("invalid") > 0) {
process.destroy();
return false;
}
} catch (IOException e) {
e.printStackTrace();
}
process.destroy();
return true;
}
}
public void run() {
synchronized (this) {
if (isUsedIPAddress(ip)) {
arrayIPUsed.add(ip);
}
}
}
}
}
}
方案二 :
方案二与方案一只有一点是不一样的,就是在与下面这个相关的代码,采用的是队列而不是数组
将 private volatile ArrayList<Thread> arrayThread;// 子线程段
改为: private volatile ArrayBlockingQueue<Thread> queueThread;// 子线程队列
当然,其他相关的地方的处理也要做些修改.
注!!!!
在 linux下运行发现InetAddress.getLocalHost().getHostAddress();的返回值是127.0.0.1,这个与 windows下的返回值不一样。由于jdk在win和linux下这个方法的差异,这个程序在linux下不能如预期的那样工作,需要做一些技术上的改进。
使用java线程扫描局域网ip简单方案
java 快速扫描局域网 ip 之二级嵌套类
方案一 :
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.ArrayList;
public class LanIP {
public ArrayList<String> getLanIPArrayList() {
ArrayList<String> arrayIP = null;
try {
InitSystem initSystem = null;
initSystem = new InitSystem();
Thread thread = new Thread(initSystem);
thread.start();
thread.join();
arrayIP = initSystem.getArrayIPUsed();
} catch (UnknownHostException e) {
e.printStackTrace();
} catch (InterruptedException e) {
e.printStackTrace();
}
return arrayIP;
}
private class InitSystem implements Runnable {
private int firstIP = 2;// 查询的 IP 地址的最后一位起始点
private int lastIP = 255;// 查询的 IP 地址的最后一位结束点
private volatile ArrayList<Thread> arrayThread;// 子线程段
private final int MAXTHREADNUM = 30; // 最大同时进行的子线程数量
private int threadNumNow;// 当前正在进行的子线程数量
private volatile ArrayList<String> arrayIP;// 局域网查询所有可能的 IP 地址的结果集
private volatile ArrayList<String> arrayIPUsed;// 局域网查询已经使用的 IP 地址的结果集
private InitSystem(String ip) {
arrayIP = new ArrayList<String>();
arrayIPUsed = new ArrayList<String>();
arrayThread = new ArrayList<Thread>();
setIPAddressList(ip);
}
private InitSystem() throws UnknownHostException {
this(InetAddress.getLocalHost().getHostAddress());
}
private synchronized ArrayList<String> getArrayIPUsed() {
try {
while (arrayIP.size() > 0) {
Thread.sleep(300);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
return arrayIPUsed;
}
private void setIPAddressList(String ip) {
// 根据这个 ip 地址查询它所在的局域网的所有可能 IP 地址的集合
int lastPointIndex = ip.lastIndexOf('.');
String stringIPHead = ip.substring(0, ++lastPointIndex);
String stringIP = null;
for (int i = firstIP; i <= lastIP; i++) {
stringIP = stringIPHead + i;
arrayIP.add(stringIP);
}
}
public void run() {
synchronized (this) {
try {
while (arrayIP.size() > 0) {
while (threadNumNow >= MAXTHREADNUM) {
for (Thread thread : arrayThread) {
if (!thread.getState().equals(
Thread.State.TERMINATED)) {
thread.join(5);
}
--threadNumNow;
}
arrayThread = new ArrayList<Thread>();
}
Thread thread = new Thread(new InnerClass(arrayIP
.remove(0)));
thread.start();
threadNumNow++;
arrayThread.add(thread);
}
} catch (Exception e) {
e.printStackTrace();
}
}
}
private class InnerClass implements Runnable {
// 线程查询一个 IP 是否是可以连接的 是则加入到相应的 IP 数组
private String ip;
private InnerClass(String ip) {
this.ip = ip;
}
private boolean isUsedIPAddress(String ip) {
synchronized (this) {
// 判断这个 IP 地址在当前局域网中是否是可连接的 IP
Process process = null;
BufferedReader bufReader = null;
String bufReadLineString = null;
try {
process = Runtime.getRuntime().exec(
"ping " + ip + " -w 100 -n 1");
bufReader = new BufferedReader(new InputStreamReader(
process.getInputStream()));
for (int i = 0; i < 6 && bufReader != null; i++) {
bufReader.readLine();
}
bufReadLineString = bufReader.readLine();
if (bufReadLineString == null) {
process.destroy();
return false;
}
if (bufReadLineString.indexOf("timed out") > 0
|| bufReadLineString.length() < 17
|| bufReadLineString.indexOf("invalid") > 0) {
process.destroy();
return false;
}
} catch (IOException e) {
e.printStackTrace();
}
process.destroy();
return true;
}
}
public void run() {
synchronized (this) {
if (isUsedIPAddress(ip)) {
arrayIPUsed.add(ip);
}
}
}
}
}
}
方案二 :
方案二与方案一只有一点是不一样的,就是在与下面这个相关的代码,采用的是队列而不是数组
将 private volatile ArrayList<Thread> arrayThread;// 子线程段
改为: private volatile ArrayBlockingQueue<Thread> queueThread;// 子线程队列
当然,其他相关的地方的处理也要做些修改.
注!!!!
在 linux下运行发现InetAddress.getLocalHost().getHostAddress();的返回值是127.0.0.1,这个与 windows下的返回值不一样。由于jdk在win和linux下这个方法的差异,这个程序在linux下不能如预期的那样工作,需要做一些技术上的改进。
发表评论
-
CDT JNI
2012-12-01 23:26 779http://www.blogjava.net/orangew ... -
PC客户端与Android实现图片传送
2012-10-16 11:48 6521PC服务端,用于发送图片 import java.io.Dat ... -
h.264
2012-05-30 00:03 1295http://www.elecfans.com/video/a ... -
gxt mvc架构分析
2011-08-18 19:15 942http://www.bristol-gtug.org/?p= ... -
这个表达式你一眼看得出结论来吗?if ((n & -n) == n)
2011-06-09 11:47 918如题,很惭愧本人确实没有一眼看出来.首先定性思维第一反应把&q ... -
tomcat中将项目部署为根目录
2011-03-29 20:50 946修改server.xml <Context debug= ... -
AWT双缓冲,消除闪烁
2011-03-25 11:26 2112以上原文from:http://blog.csdn.net/w ... -
c++学习笔记
2011-02-21 21:48 9931.指针是用来保存内存地址的变量 如:int i; int * ... -
收藏hibernate二级缓存的两篇文章
2011-01-15 23:35 809http://www.iteye.com/topic/1890 ... -
sturts2标签使用说明
2011-01-07 14:27 1139http://www.roseindia.net/struts ... -
java -classpath使用
2011-01-06 22:29 949假设三个类:Dog继承Animal并引用Food那么怎么去执行 ... -
P6spy
2011-01-03 16:50 2710from:http://blog.chinaunix.net/ ... -
oracle修改表增加列删除列修改列
2010-12-28 13:20 2497oracle修改表增加列删除列修改列 1.增加列 ALTER ... -
Java应用程序安装成一个Windows NT服务
2010-12-24 14:22 1006http://wrapper.tanukisoftware.c ... -
play framwork导出war包
2010-12-04 12:42 1111play war myApp -o /myApp --zip -
JAVA静态导入(inport static)详解
2010-12-01 13:40 2094在Java 5中,import语句得到了增强,以便提供甚至更加 ... -
两段copy文件的代码
2010-11-26 09:25 8011.传统的基于IO的Copy方法 import java.io ... -
动态加载jar
2010-11-21 14:39 2801在eclipse中有个自动升级,可以直接通过一个互联上链接安装 ... -
java动态代理入门示例
2010-09-16 22:44 1101package com.huzy.proxy; impo ... -
让windows启动时自动运行bat脚本
2010-06-06 10:46 3266打开组策略运行输入gpedit.msc 用户配置window ...
相关推荐
在"JAVA SWING 多线程扫描局域网IP及端口 v2 源码"这个项目中,我们可以看到开发者使用了Swing来创建一个图形化的用户界面,同时结合多线程技术来实现局域网内的IP和端口扫描。 1. **Swing基础**:Swing是Java AWT...
描选定IP的常见TCP UDP端口 包括部分常见木马所使用端口 并可以自定义扫描端口 扫描同一网段的IP主要是用SHELL方法 使用PING命令并判断返回值内容 从而确定服务器是否打开 扫描端口的原理是使用socket类判断是否...
【Java线程扫描IP地址】知识点详解 在Java编程中,使用线程扫描IP地址是一项常见的网络编程任务,尤其在局域网环境里,我们可能需要查找可用的IP或者检查哪些IP已被占用。这个Java程序提供了简单的方法来实现这一...
Java扫描局域网活动主机是一项常见的网络管理任务,主要用于检测并获取网络中正在运行的设备信息。这个程序可能是一个小型的Java应用,利用了多线程技术和线程池来提高扫描速度,确保在短时间内高效地完成对局域网内...
对于局域网IP扫描器而言,多线程扫描有以下优势: 1. 提高扫描速度:多线程使得IP扫描器能同时处理多个任务,显著减少了扫描整个网络所需的时间。 2. 资源优化:用户可以根据网络规模和硬件配置调整线程数量,避免...
2. **创建多线程**:为了提高扫描效率,我们会为每个目标IP创建一个独立的线程。这样可以并发地进行多个连接尝试,而不是顺序执行。可以使用Java的`Thread`类或`ExecutorService`来管理这些线程。 3. **建立Socket...
单线程扫描是指程序在执行时仅使用一个执行线程,这意味着每次只能处理一个任务,直到该任务完成才会处理下一个。这种方式简单且易于理解和实现,但效率可能不高,特别是在需要扫描大量设备的大型局域网中。如果需要...
以下是一个简单的Java端口扫描程序的步骤: 1. **导入必要的库**: ```java import java.io.IOException; import java.net.InetAddress; import java.net.Socket; ``` 2. **定义主类和方法**: ```java ...
描述中的“多线程扫描IP段”意味着程序通过启动多个并发执行的线程来快速遍历指定的IP地址范围,这在局域网环境下非常实用,因为可以提高搜索效率,减少等待时间。同时,“可以控制线程数量”这一特性表明开发者考虑...
本节将深入探讨如何在Android系统中实现高效、快速地获取局域网设备的IP和MAC地址,以及如何优化这个过程。 首先,我们要明白获取局域网设备信息的基本原理。通常,我们使用ARP(Address Resolution Protocol)协议...
【Java局域网聊天程序详解】 ...总的来说,Java局域网聊天程序是一个结合了网络编程、GUI设计和多线程等技术的实践项目,通过这样的程序,开发者可以深入理解Java的网络通信机制,提升自己的编程技能。
1. **设备发现**:利用Java的网络API,程序可以扫描并发现局域网内的设备,收集IP地址、MAC地址、主机名等信息。 2. **流量监控**:通过监听网络接口,程序可以统计每台设备的上传和下载流量,这有助于识别带宽消耗...
例如,以下是一个简单的Java代码片段,用于扫描局域网内的IP和MAC地址: ```java import java.net.*; import java.util.Enumeration; public class LanDiscovery { public static void main(String[] args) ...
【描述】"JAVA实现多线程扫描多主机,可以控制线程数量。聊天"指出该程序的核心特性。首先,它利用Java的多线程机制,允许多个任务同时执行,提高程序效率。多线程在并发处理中至关重要,尤其是对于网络通信,可以...
LANScanner是一款基于Java开发的局域网IP扫描工具,它能帮助用户快速定位并获取同一网络子网内的设备IP地址和MAC地址。在现代企业环境中,网络管理是至关重要的,LANScanner这样的工具提供了便捷的方式,使得IT管理...
在本项目中,"基于Java的局域网通信——飞鸽传书源代码.zip" 提供了一种使用Java实现的局域网内文件传输的解决方案,类似于传统的“飞鸽传书”方式。这个项目旨在帮助开发者理解如何在Java环境下利用网络编程技术...
本设计主要针对局域网内的主机进行监控管理,通过JAVA语言开发的监控软件,可以实时监控局域网内的主机状态,包括主机名称、IP地址、操作系统、CPU使用率、内存使用率等信息。 设计了主机信息管理模块、主机状态监控...
总结起来,搜索同一WiFi局域网中的IP地址是通过Android的`WifiManager`服务获取网络配置,然后使用`InetAddress`的ping功能来检测活动设备。这个过程涉及网络编程、设备间通信和多线程等技术,对于开发涉及网络交互...
【JAVA局域网即时聊天软件】是一款利用JAVA编程语言与SQL Server 2005数据库技术构建的局域网内通信应用。此软件的核心功能在于提供实时、高效的文本或者多媒体消息传输,使得在同一网络环境下的用户能够快速进行...
参照superscan、nmap等端口扫描软件的运行情况,自行设计一个简单的端口扫描软件,...(4)友好地图形用户界面,扫描过程中能显示扫描进度,扫描时间,异常告警窗口(如IP地址范围出界等),在局域网段实现。 欢迎使用