Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stefanwichmann/lanscan
Blazing fast, local network scanning in Go
https://github.com/stefanwichmann/lanscan
Last synced: 4 months ago
JSON representation
Blazing fast, local network scanning in Go
- Host: GitHub
- URL: https://github.com/stefanwichmann/lanscan
- Owner: stefanwichmann
- License: mit
- Created: 2017-04-08T14:47:39.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2019-03-24T15:43:22.000Z (almost 6 years ago)
- Last Synced: 2024-08-02T05:12:11.304Z (7 months ago)
- Language: Go
- Homepage:
- Size: 16.6 KB
- Stars: 34
- Watchers: 3
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-blazingly-fast - lanscan - Blazing fast, local network scanning in Go (Go)
README
# **Lanscan** - Blazing fast, local network scanning in Go
[](https://travis-ci.org/stefanwichmann/lanscan)
[](https://goreportcard.com/report/github.com/stefanwichmann/lanscan)
[](https://github.com/stefanwichmann/lanscan/blob/master/LICENSE)# Introduction
Lanscan is a small, blazing fast and easy to use golang library to scan for hosts in your local network. It's job is to identify hosts nearby that are listening on a specified port. The goal is to make scans like these as fast and simple as possible. Just provide a port, the number of parallel threads and a timeout. Lanscan will take care of the rest...# Features
- [x] Automatic restriction to your link local network
- [x] Automatic prioritization of nearby IPs
- [x] Automatic scan on all network interfaces
- [x] Automatic adaption to your network latency
- [x] Full support for parallel scanning
- [x] Ability to stop after a timeout# Getting started
```go
package mainimport "github.com/stefanwichmann/lanscan"
import "time"
import "log"func main() {
// Scan for hosts listening on tcp port 80.
// Use 20 threads and timeout after 5 seconds.
hosts, err := lanscan.ScanLinkLocal("tcp4", 80, 20, 5*time.Second)
if err != nil {
log.Fatal(err)
}
for _, host := range hosts {
log.Printf("Host %v responded.", host)
}
}```
# Status
Lanscan is still work in progress and far from done! Right now it's working stable in an IPv4 environment when scanning for TCP services. Once a TCP handshake is successfully completed Lanscan considers the host reachable. Open tasks right now are:- [ ] IPv6 discovery
- [ ] UDP discovery
- [ ] Provide a proper command line tool for scanning