ftp/README.md

64 lines
1.6 KiB
Markdown
Raw Permalink Normal View History

2013-07-08 20:34:49 +02:00
# goftp #
[![Units tests](https://github.com/jlaffaye/ftp/actions/workflows/unit_tests.yaml/badge.svg)](https://github.com/jlaffaye/ftp/actions/workflows/unit_tests.yaml)
[![Coverage Status](https://coveralls.io/repos/jlaffaye/ftp/badge.svg?branch=master&service=github)](https://coveralls.io/github/jlaffaye/ftp?branch=master)
2022-09-08 00:02:26 +02:00
[![golangci-lint](https://github.com/jlaffaye/ftp/actions/workflows/golangci-lint.yaml/badge.svg)](https://github.com/jlaffaye/ftp/actions/workflows/golangci-lint.yaml)
[![CodeQL](https://github.com/jlaffaye/ftp/actions/workflows/codeql-analysis.yml/badge.svg)](https://github.com/jlaffaye/ftp/actions/workflows/codeql-analysis.yml)
[![Go ReportCard](https://goreportcard.com/badge/jlaffaye/ftp)](http://goreportcard.com/report/jlaffaye/ftp)
2021-03-05 16:52:22 +01:00
[![Go Reference](https://pkg.go.dev/badge/github.com/jlaffaye/ftp.svg)](https://pkg.go.dev/github.com/jlaffaye/ftp)
2015-08-18 19:34:22 +02:00
2013-07-08 20:34:49 +02:00
A FTP client package for Go
2016-02-10 19:38:39 +01:00
## Install ##
```
go get -u github.com/jlaffaye/ftp
```
## Documentation ##
2021-03-05 16:52:22 +01:00
https://pkg.go.dev/github.com/jlaffaye/ftp
## Example ##
2013-07-08 20:34:49 +02:00
```go
c, err := ftp.Dial("ftp.example.org:21", ftp.DialWithTimeout(5*time.Second))
if err != nil {
2019-04-15 18:34:29 +02:00
log.Fatal(err)
}
err = c.Login("anonymous", "anonymous")
if err != nil {
2019-04-15 18:34:29 +02:00
log.Fatal(err)
}
// Do something with the FTP conn
2019-04-15 18:34:29 +02:00
if err := c.Quit(); err != nil {
log.Fatal(err)
}
```
## Store a file example ##
```go
data := bytes.NewBufferString("Hello World")
err = c.Stor("test-file.txt", data)
if err != nil {
panic(err)
}
```
## Read a file example ##
```go
r, err := c.Retr("test-file.txt")
if err != nil {
panic(err)
}
2020-03-31 16:49:19 +02:00
defer r.Close()
buf, err := ioutil.ReadAll(r)
println(string(buf))
```