A Http File Server Written By Golang and Reactjs

A Http File Server Written By Golang and Reactjs

A http file server written by golang and reactjs .HTTP file server written by golang + reactjs, not maintained, move to

gohttp

A http file server written by golang and reactjs.

Not maintained any more. Move to https://github.com/codeskyblue/gohttpserver

Binary can be download from gobuild.io

Usage

# basic usage
gohttp --port 8000 --root /your/workdir

Usage: gohttp [<flags>]

Flags:
  -h, --help               Show context-sensitive help (also try --help-long and --help-man).
      --version            Show application version.
      --port=8000          Port to listen
      --root="."           File root directory
      --private            Only listen on loopback address
      --httpauth=HTTPAUTH  HTTP basic auth (ex: user:pass)
      --cert=CERT          TLS cert.pem
      --key=KEY            TLS key.pem
      --gzip               Enable Gzip support
      --upload             Enable upload support
      --zipable            Enable archieve folder into zip

Warning

ftp feature has a serious cpu usage problem. Be careful with that.

There are python scripts of which use pyftpdlib can do ftp server job.

screenshot screenshot

Features

  1. Support QRCode code generate
  2. All assets package to Standalone binary
  3. Different file type different icon
  4. Support show or hide hidden files
  5. Upload support
  6. README.md preview
  7. HTTP Basic Auth
  8. Gzip support
  9. When only one dir under dir, path will combine two together
  10. Directory zip download
  11. Code preview
  12. Apple ipa auto generate .plist file, qrcode can be recognized by iphone (Require https)
  13. Add ftp support(beta)
  14. Support modify the index page
  15. Download count statistics
  16. CORS enabled

About https

There is a Chinese doc about how to set up nginx and generate self signed keys

If there is a directory templates exists. The program will use templates under this dir instead use html resource inside the binary file.

Build

Suggest install node through nvm

go get -u github.com/jteeuwen/go-bindata/...
npm install -g webpack
npm install
make prod

Develop

Your need to know what is react, and golang. In develop mode, Support react hot reload

npm install
make dev

Open another terminal

go build && ./gohttp

API

Upload

POST /upload-dir

upload-dir is just a name which you can change it easily.

Field name Description Example
file Upload file [email protected]
path Upload path(optional) path=/tmp/
name Save name (optional, need version set) name=foo
version Upload version version=1.2.0

Use CURL

# Normal upload
curl -F [email protected] ${SERVER}

# Versioned upload
curl -F [email protected] -F [email protected] -F name=foo -F version=1.0.1 ${SERVER}

# will create dir structure
foo/
  |- foo-latest(symlink) -> foo-1.0.1
  `- foo-1.0.1/
      |- foo-windows.txt
      `- foo-mac.txt

Thanks

  1. https://github.com/shenfeng/http-watcher
  2. http://segmentfault.com/a/1190000002551952
  3. update package.json dependencies
  4. react hot reload QA
  5. https://github.com/evilstreak/markdown-js

Download Details:

Author: codeskyblue

Source Code: https://github.com/codeskyblue/gohttp

react reactjs javascript golang

Bootstrap 5 Complete Course with Examples

Bootstrap 5 Tutorial - Bootstrap 5 Crash Course for Beginners

Nest.JS Tutorial for Beginners

Hello Vue 3: A First Look at Vue 3 and the Composition API

Building a simple Applications with Vue 3

Deno Crash Course: Explore Deno and Create a full REST API with Deno

How to Build a Real-time Chat App with Deno and WebSockets

Convert HTML to Markdown Online

HTML entity encoder decoder Online

How native is React Native? | React Native vs Native App Development

Article covers: How native is react native?, React Native vs (Ionic, Cordova), Similarities and difference between React Native and Native App Development.

Increase Performance of React Applications Via Array JavaScript Methods

Increase Performance of React Applications Via Array JavaScript Methods. We will create a simple event management application in the react to add, update, and delete an event.

Routing in React without React-Router

I have been using React JS in my projects for quite some time now and am used to managing routing in my app using the react-router package. I have always been keen on having as little dependencies in my apps as possible, so, I always felt perturbed by the use of this particular package in simpler apps which did not have complex routes.

The Ugly Side of React Hooks

In this post, I will share my own point of view about React Hooks, and as the title of this post implies, I am not a big fan.

ReactJS: The Javascript Developer’s Guide

This article will walk you through the concepts you would need to know to step into the world of widely used ReactJS.