mirror von https://github.com/civetweb/civetweb.git

bel 24e7f6275e Update VS project files to use Duktape 1.5.2 8 роки тому
Qt 8e536227a4 Enable IPV6 and WEBSOCKET in Qt build 9 роки тому
VisualStudio 24e7f6275e Update VS project files to use Duktape 1.5.2 8 роки тому
ci bfba8d105d move travis tests to ci/ from test/ci_tests 10 роки тому
cmake 5d765b4984 Try Travis CI fix for OSX 8 роки тому
contrib 1dba82d582 Update version number 9 роки тому
distribution 25e7595b8f Update repository link: bel2125/civetweb --> civetweb/civetweb 10 роки тому
docs aab26ca7d7 Fixed quotes 8 роки тому
examples f6ad1878f1 Add diagnosis info if server does not start 8 роки тому
include 2c86f5dbac Rename request_info member after merge of #367 8 роки тому
resources 95aeb2705b Update to Duktape 1.5.2 8 роки тому
src 95aeb2705b Update to Duktape 1.5.2 8 роки тому
test 6b92c512f5 Rename include Windows.h to windows.h for cross-compilation from Linux to Windows 8 роки тому
.clang-format 8d901773ca Modify clang-format according to #207 (see comment) 9 роки тому
.gitattributes 54a13d3c2b Add manual language settings for github syntax highlighting 9 роки тому
.gitignore 3f9a19e7a9 Ignore cscope and ctags 'database' files 9 роки тому
.travis.yml 8b7c3b03c4 Travis build for OSX is repaired, so it is no longer optional 8 роки тому
CMakeLists.txt a076201c4d stdint.h (from C99) is no longer optional 8 роки тому
CREDITS.md 59fa55a87c Update credits and release notes after manual merge of #371 8 роки тому
LICENSE.md 72204bdc0f Experimental support for duktape (Step 2/?) 9 роки тому
Makefile 38e54ea42c Disabling code optimization flag for DEBUG build 8 роки тому
Makefile.deprecated 173b0c7214 Update Lua to 5.2.3 11 роки тому
Makefile.osx 9ba511faed Change OS X package from dmg to zip file to fix hdiutil errors in Travis 9 роки тому
README.md ffb8b4cf13 The AppVeyor build for CivetWeb works now 9 роки тому
RELEASE_NOTES.md 59fa55a87c Update credits and release notes after manual merge of #371 8 роки тому
appveyor.yml cfb714ebcb Add id to AppVeyor build 8 роки тому
build 17532cb843 Build script for Unix systems 10 роки тому
build.cmd 1a04ebe805 Fix up log_append in MinGW download script 10 роки тому
format.bat 7ec97f166a Add unit test for timers 8 роки тому
mingw.cmd 668cd8a5a9 Add powershell output to MinGW script log 10 роки тому

README.md

CivetWeb CivetWeb

The official home of CivetWeb is https://github.com/civetweb/civetweb

Continuous integration for Linux and OSX (Travis CI):

Travis Build Status

Continuous integration for Windows (AppVeyor):

Appveyor Build Status

Test coverage check (coveralls) (currently in a setup phase):

Coverage Status

Static source code analysis (Coverity):

Coverity Scan Build Status

Project Mission

Project mission is to provide easy to use, powerful, C/C++ embeddable web server with optional CGI, SSL and Lua support. CivetWeb has a MIT license so you can innovate without restrictions.

CivetWeb can be used by developers as a library, to add web server functionality to an existing application. It can also be used by end users as a stand-alone web server. It is available as single executable, no installation is required.

Where to find the official version?

End users can download CivetWeb at SourceForge https://sourceforge.net/projects/civetweb/

Developers can contribute to CivetWeb via GitHub https://github.com/civetweb/civetweb

Trouble tickets should be filed on GitHub https://github.com/civetweb/civetweb/issues

Discussion/support group and announcements are at Google Groups https://groups.google.com/d/forum/civetweb

Quick start documentation

Overview

CivetWeb keeps the balance between functionality and simplicity by a carefully selected list of features:

  • Liberal, commercial-friendly, permissive, MIT license
  • Free from copy-left licenses, like GPL, because you should innovate without restrictions.
  • Forked from Mongoose in 2013, before it changed the licence from MIT to commercial + GPL. A lot of enchancements have been added since that time, see RELEASE_NOTES.md.
  • Works on Windows, Mac, Linux, UNIX, iPhone, Android, Buildroot, and many other platforms.
  • Scripting and database support (Lua scipts, Lua Server Pages, CGI + SQLite database, Server side javascript). This provides a ready to go, powerful web development platform in a one single-click executable with no dependencies.
  • Support for CGI, HTTPS (SSL/TLS), SSI, HTTP digest (MD5) authorization, Websocket, WEbDAV.
  • Optional support for authentication using client side X.509 certificates.
  • Resumed download, URL rewrite, file blacklist, IP-based ACL, Windows service.
  • Download speed limit based on client subnet or URI pattern.
  • Simple and clean embedding API.
  • The source is in single file to make things easy.
  • Embedding examples included.
  • HTTP client capable of sending arbitrary HTTP/HTTPS requests.
  • Websocket client functionality available (WS/WSS).

Optionally included software

Lua Sqlite3 LuaFileSystem LuaSQLite3 LuaXML Duktape

Support

This project is very easy to install and use. Please read the documentation and have a look at the examples. More information may be found on the mailing list.

Contributions

Contributions are welcome provided all contributions carry the MIT license.

DO NOT APPLY fixes copied from Mongoose to this project to prevent GPL tainting. Since 2013 CivetWeb and Mongoose are developed independently. By now the code base differs, so patches cannot be safely transfered in either direction.

Some guidelines can be found in docs/Contribution.md.

Authors

CivetWeb is based on the Mongoose project. The original author of Mongoose was Sergey Lyubka (Copyright (c) 2004-2013 Sergey Lyubka, MIT license).

However, in August 16, 2013, the license of Mongoose has been changed after writing and distributing the original code this project is based on. The license change used to be described on the Mongoose Wikipedia page as well, but it's getting deleted there regularly.

CivetWeb has been forked from the last MIT version of Mongoose. Since 2013, CivetWeb has seen many improvements from various authors (Copyright (c) 2013-2016 the CivetWeb developers, MIT license). A list of authors can be found in CREDITS.md.

Using the CivetWeb project ensures the MIT licenses terms are applied and GPL cannot be imposed on any of this code as long as it is sourced from here. This code will remain free with the MIT license protection.