Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mattbostock/go-ldpreload-backdoor
LD_PRELOAD libc hooking using Go
https://github.com/mattbostock/go-ldpreload-backdoor
cgo go golang ldpreload shell
Last synced: 2 months ago
JSON representation
LD_PRELOAD libc hooking using Go
- Host: GitHub
- URL: https://github.com/mattbostock/go-ldpreload-backdoor
- Owner: mattbostock
- License: mit
- Created: 2015-08-25T22:06:05.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2015-12-09T01:28:34.000Z (about 9 years ago)
- Last Synced: 2024-06-20T15:55:53.400Z (7 months ago)
- Topics: cgo, go, golang, ldpreload, shell
- Language: Go
- Homepage:
- Size: 20.5 KB
- Stars: 152
- Watchers: 10
- Forks: 29
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# LD_PRELOAD libc hooking using Go
This is an experiment to use Go in a shared library to wrap a libc function and
start a TCP server (a 'backdoor') allowing arbitrary commands to be
run from a client such as telnet or netcat.This is a toy intended for educational purposes to demonstrate some of
Go's capabilities.Works on Linux only and requires Go version 1.5 or above in order to build the
shared library.## Rationale
In writing this, I have four aims:
- to try out [Go's new build modes][], which allow Go to be compiled to a
shared library that can be called from C- to experiment with `LD_PRELOAD` exploits
- to experiment with calling C from Go
- to learn some C ;)
[Go's new build modes]: https://docs.google.com/document/d/1nr-TQHw_er6GOQRsF6T43GGhFDelrAP0NqSS_00RgZQ
## Usage
As this is an experiment, the backdoor will only listen on localhost.
GO15VENDOREXPERIMENT=1 go build -buildmode=c-shared -o backdoor.so main.go
LD_PRELOAD=./backdoor.so topIn a separate console, while `top` is running:
nc localhost 4444
[...type your commands here...]## Limitations
- Only works on Linux
- Only works with binaries that call libc's `strrchr` function. I'd ideally
like to hook `__libc_start_main` instead. The binaries I tested with are `ps`
and `top` as provided by Ubuntu Trusty LTS.