- All Implemented Interfaces:
AutoCloseable
- Direct Known Subclasses:
Pcap.Linux
- Enclosing class:
Pcap
-
Nested Class Summary
Nested classes/interfaces inherited from class org.jnetpcap.Pcap0_9
Pcap0_9.Linux0_9
Nested classes/interfaces inherited from class org.jnetpcap.Pcap0_8
Pcap0_8.Unix0_8
Nested classes/interfaces inherited from class org.jnetpcap.Pcap0_4
Pcap0_4.PcapSupplier<T extends Pcap>
Nested classes/interfaces inherited from class org.jnetpcap.Pcap
Pcap.LibraryPolicy, Pcap.Linux, Pcap.Unix
-
Field Summary
Fields inherited from class org.jnetpcap.Pcap0_4
dispatcher
Fields inherited from class org.jnetpcap.Pcap
closed, pcapHeaderABI, POINTER_TO_POINTER1, POINTER_TO_POINTER2, POINTER_TO_POINTER3, VERSION
-
Method Summary
Modifier and TypeMethodDescriptionstatic Pcap.Unix
Create a live capture handle.final int
Gets the selectable fd.static boolean
Checks if thePcap
subclass at a specific libpcap API version is natively supported.static Pcap.Unix
Open a fake pcap_t for compiling filters or opening a capture for output.static Pcap.Unix
openDeadWithTstampPrecision
(PcapDlt linktype, int snaplen, PcapTStampPrecision precision) Open a fake pcap_t for compiling filters or opening a capture for output.static Pcap.Unix
Open a device for capturing.static Pcap.Unix
openOffline
(String fname) Open a saved capture file for reading.Methods inherited from class org.jnetpcap.Pcap1_5
getTstampPrecision, openDeadWithTstampPrecision, setImmediateMode, setTstampPrecision
Methods inherited from class org.jnetpcap.Pcap1_2
listTstampTypes, setTstampType
Methods inherited from class org.jnetpcap.Pcap1_0
activate, canSetRfmon, create, dataLinkExt, init, offlineFilter, setBufferSize, setPromisc, setPromisc, setRfmon, setRfmon, setSnaplen, setTimeout, statusToStr
Methods inherited from class org.jnetpcap.Pcap0_9
inject, setDirection, setProtocolLinux
Methods inherited from class org.jnetpcap.Pcap0_8
breakloop, datalinkNameToVal, dataLinkValToDescription, dataLinkValToName, libVersion, listDataLinks, nextEx, sendPacket, setDatalink
Methods inherited from class org.jnetpcap.Pcap0_7
findAllDevs, getNonBlock, setNonBlock
Methods inherited from class org.jnetpcap.Pcap0_5
compileNoPcap
Methods inherited from class org.jnetpcap.Pcap0_4
close, compile, datalink, datalinkGetAsInt, dispatch, dispatch, dispatch, dispatch, dumpOpen, file, fileno, getDispatcher, geterr, isInitialized, isSwapped, lookupDev, lookupNet, loop, loop, loop, loop, majorVersion, minorVersion, next, openLive, openOffline, perror, setDispatcher, setFilter, setUncaughtExceptionHandler, snapshot, stats, strerror
Methods inherited from class org.jnetpcap.Pcap
checkPcapVersion, compile, create, datalinkValToDescription, datalinkValToName, findAllDevsEx, getErrorString, getName, getPcapHandle, getPcapHeaderABI, init, inject, inject, inject, listAllPcapIf, loadNativePcapLibrary, lookupErrorString, lookupNet, newArena, openLive, openLive, openOffline, order, sendPacket, sendPacket, sendPacket, setDatalink, setDatalink, setDirection, setDirection, setFilter, setUncaughtExceptionHandler, statusToStr, toString
-
Method Details
-
create
Create a live capture handle.create
is used to create a packet capture handle to look at packets on the network. source is a string that specifies the network device to open; on Linux systems with 2.2 or later kernels, a source argument of "any" or NULL can be used to capture packets from all interfaces. The returned handle must be activated with pcap_activate() before pack' ets can be captured with it; options for the capture, such as promiscu' ous mode, can be set on the handle before activating it.- Parameters:
device
- a string that specifies the network device to open; on Linux systems with 2.2 or later kernels, a source argument of "any" or NULL can be used to capture packets from all interfaces.- Returns:
- a new pcap object that needs to be activated using
Pcap1_0.activate()
call - Throws:
PcapException
- the pcap exception- Since:
- libpcap 1.0
-
isSupported
public static boolean isSupported()Checks if thePcap
subclass at a specific libpcap API version is natively supported. This is a safe method to use anytime on any platform, weather native library is present or not.For example,
Pcap1_0.isSupported()
will accurately ascertain if libpcap API version 1.0 level calls are supported by the system runtime. Also a call such asWinPcap.isSupported()
will determine if WinPcap related calls, ie. native WinPcap 4.1.3 or less, are supported and by extension if this is a Microsoft Windows platform.Due to libpcap API versioning, it is safe to assume that if
Pcap1_10.isSupported()
returnstrue
, that at least libpcap API version 1.0 is installed on this platform, and that all lower version calls such as libpcap 0.8 and 0.9 are available as well. The subclass hierarchy of jNetPcap module reflects the versioning of libpcap and its derivatives and the public releases of the native libraries. For exampleNpcap
class extendsWinPcap
class because Npcap project took over the support for WinPcap where it left off.Implementation notes: The check is performed by verifying that certain, subclass specific native symbols were linked with
Pcap
full which was introduced at a specific libpcap or related API levels.- Returns:
- true, if pcap is supported up to this specific version level, otherwise false
- See Also:
-
openDead
Open a fake pcap_t for compiling filters or opening a capture for output.openDead(org.jnetpcap.constant.PcapDlt, int)
and pcap_open_dead_with_tstamp_precision() are used for creating a pcap_t structure to use when calling the other functions in libpcap. It is typically used when just using libpcap for compiling BPF full; it can also be used if using pcap_dump_open(3PCAP), pcap_dump(3PCAP), and pcap_dump_close(3PCAP) to write a savefile if there is no pcap_t that supplies the packets to be written.When pcap_open_dead_with_tstamp_precision(), is used to create a pcap_t for use with pcap_dump_open(), precision specifies the time stamp precision for packets; PCAP_TSTAMP_PRECISION_MICRO should be specified if the packets to be written have time stamps in seconds and microseconds, and PCAP_TSTAMP_PRECISION_NANO should be specified if the packets to be written have time stamps in seconds and nanoseconds. Its value does not affect pcap_compile(3PCAP).
- Parameters:
linktype
- specifies the link-layer type for the pcap handlesnaplen
- specifies the snapshot length for the pcap handle- Returns:
- A dead pcap handle
- Throws:
PcapException
- any errors- Since:
- libpcap 0.6
-
openDeadWithTstampPrecision
public static Pcap.Unix openDeadWithTstampPrecision(PcapDlt linktype, int snaplen, PcapTStampPrecision precision) throws PcapException Open a fake pcap_t for compiling filters or opening a capture for output.openDead(PcapDlt, int)
andopenDeadWithTstampPrecision(PcapDlt, int, PcapTStampPrecision)
are used for creating a pcap_t structure to use when calling the other functions in libpcap. It is typically used when just using libpcap for compiling BPF full; it can also be used if using#dumpOpen(String)
,PcapDumper.dump(MemorySegment, MemorySegment)
, andPcapDumper.close()
to write a savefile if there is no pcap_t that supplies the packets to be written.When
openDeadWithTstampPrecision(PcapDlt, int, PcapTStampPrecision)
, is used to create aPcap
handle for use withPcap0_4.dumpOpen(String)
, precision specifies the time stamp precision for packets; PCAP_TSTAMP_PRECISION_MICRO should be specified if the packets to be written have time stamps in seconds and microseconds, and PCAP_TSTAMP_PRECISION_NANO should be specified if the packets to be written have time stamps in seconds and nanoseconds. Its value does not affect pcap_compile(3PCAP).- Parameters:
linktype
- specifies the link-layer type for the pcap handlesnaplen
- specifies the snapshot length for the pcap handleprecision
- the requested timestamp precision- Returns:
- A dead pcap handle
- Throws:
PcapException
- any errors- Since:
- libpcap 1.5.1
-
openLive
public static Pcap.Unix openLive(String device, int snaplen, boolean promisc, long timeout, TimeUnit unit) throws PcapException Open a device for capturing.openLive
is used to obtain a packet capture handle to look at packets on the network. device is a string that specifies the network device to open; on Linux systems with 2.2 or later kernels, a device argument of "any" or NULL can be used to capture packets from all interfaces.- Parameters:
device
- the device namesnaplen
- specifies the snapshot length to be set on the handlepromisc
- specifies whether the interface is to be put into promiscuous mode. If promisc is non-zero, promiscuous mode will be set, otherwise it will not be settimeout
- the packet buffer timeout, as a non-negative value, in unitsunit
- time timeout unit- Returns:
- the pcap handle
- Throws:
PcapException
- any errors- Since:
- libpcap 0.4
-
openOffline
Open a saved capture file for reading.pcap_open_offline() and pcap_open_offline_with_tstamp_precision() are called to open a ``savefile'' for reading.
- Parameters:
fname
- specifies the name of the file to open. The file can have the pcap file format as described in pcap-savefile(5), which is the file format used by, among other programs, tcpdump(1) and tcpslice(1), or can have the pcapng file format, although not all pcapng files can be read- Returns:
- the pcap handle
- Throws:
PcapException
- any errors- Since:
- libpcap 0.4
-
getSelectableFd
Gets the selectable fd.- Overrides:
getSelectableFd
in classPcap0_8
- Returns:
- the selectable fd
- Throws:
PcapException
- the pcap exception- See Also:
-