HPKP - HTTP Public Key Pinning (RFC7469) with persistent database
TCP Fast Open for plain text and for HTTPS
TLS Session Resumption including persistent session data cache
TLS False Start (with GnuTLS >= 3.5.0)
HTTP2 support via nghttp2 and GnuTLS ALPN including streaming/pipelining
OCSP stapling + OCSP server querying as a fallback (experimental, needs GnuTLS >= 3.3.11)
Use libpsl for cookie domain checking (using Public Suffix List)
Support link conversion (-k/–convert-links and -K/–backup-converted)
Support for RFC 6266 compliant Content-Disposition
RFC 6797 HSTS (HTTP Strict Transport Security)
Support for bzip2 Content-Encoding / Accept-Encoding compression type
New Year 2014 gimmick: added support for XZ Content-Encoding / Accept-Encoding compression type
Character encoding of input files may be specified despite from local and remote encoding (–input-encoding)
Support scanning RSS 2.0 feeds from local files (--force-rss -i <filename>)
Support scanning RSS 2.0 feeds.
Support scanning Atom 1.0 feeds from local files (--force-atom -i <filename>)
Support scanning Atom 1.0 feeds.
Support scanning URLs from local Sitemap XML file (--force-sitemap -i <filename>)
Support scanning sitemap files given in robots.txt (Sitemap XML, gzipped Sitemap XML, plain text) including
sitemap index files.
Support arbitrary number of proxies for parallel downloads
Multithreaded download of single files (option –chunk-size)
Internationalized Domain Names in Applications (compile-selectable IDNA2008 or IDNA2003)
ICEcast / SHOUTcast support via library (see examples/getstream.c)
respect /robots.txt “Robot Exclusion Standard” and <META name="robots" ...>
new option –secure-protocol=PFS to have TLS only plus forcing Perfect Forward Secrecy (PFS)
IDN support for international domains
autotools support
proxy support
cookies (session/non-session), detection of supercookies via Mozilla Public Suffix List
(use the new option --cookie-suffixes <filename>, better: put it into ~/.wgetrc)
recursive download of websites with or without spanning hosts
libz >= 1.2.3 (the distribution may call the package zlib*, eg. zlib1g on Debian)
liblzma >= 5.1.1alpha (optional, if you want HTTP lzma decompression)
libbz2 >= 1.0.6 (optional, if you want HTTP bzip2 decompression)
libbrotlidec/libbrotli >= 1.0.0 (optional, if you want HTTP brotli decompression)
libzstd >= 1.3.0 (optional, if you want HTTP zstd decompression)
libgnutls (3.3, 3.5 or 3.6)
libidn2 >= 0.14 (libidn >= 1.25 if you don’t have libidn2)
flex >= 2.5.35
libpsl >= 0.5.0
libnghttp2 >= 1.3.0 (optional, if you want HTTP/2 support)
libmicrohttpd >= 0.9.51 (optional, if you want to run the test suite)
lzip (optional, if you want to build distribution tarballs)
lcov (optional, for coverage reports)
libgpgme >= 0.4.2 (optional, for automatic signature verification)
libpcre | libpcre2 (optional, for filtering by PCRE|PCRE2 regex)
libhsts (optional, to support HSTS preload lists)
libwolfssl (optional, to support WolfSSL instead of GnuTLS)
The versions are recommended, but older versions may also work.
Downloading and building from tarball
wget https://gnuwget.gitlab.io/wget2/wget2-latest.tar.gz
tar xf wget2-latest.tar.gz
cd wget2-*
./configure
make
make check
sudo make install
Building from git
Download project and prepare sources with
git clone https://gitlab.com/gnuwget/wget2.git
cd wget2
./bootstrap
# on shell failure try 'bash ./bootstrap'
Build Wget2 with
./configure
make
In Haiku build Wget2 with
setarch x86
./configure --prefix=/boot/home/config/non-packaged
rm /boot/home/config/non-packaged/wget2 && mv /boot/home/config/non-packaged/wget2_noinstall /boot/home/config/non-packaged/wget2
Test the functionality
make check
Install Wget2 and libwget
sudo make install (or su -c "make install")
Build static wget2.exe on GNU/Linux for Windows
(cd contrib; docker build -t wget2/win32/static -f Dockerfile.win32.static .)
docker run --rm -v $PWD:/tmp wget2/win32/static cp /usr/local/wget2/src/wget2.exe /tmp
sudo chown $USER: wget2.exe
# now you have `wget2.exe` with debug symbols in your current directory
# optional: remove debug symbols with
# strip wget2.exe # (needs mingw64 version of `strip`)
# optional: pack executable
upx wget2.exe
Build static wget2 on GNU/Linux for Linux/amd64
(cd contrib; docker build -t wget2/static/amd64 -f Dockerfile.musl.static.amd64 .)
docker run --rm -v $PWD:/tmp wget2/static/amd64 cp /usr/local/wget2/src/wget2 /tmp
sudo chown $USER: wget2
# now you have `wget2.exe` with debug symbols in your current directory
# optional: remove debug symbols with
strip wget2
# optional: pack executable
upx wget2
License
Copyright (C) 2015-2026 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
A copy of the GNU General Public License can be found in the file LICENSE
in the top directory of the official source distribution. The license is
also available in several formats through the World Wide Web, or
via http://www.gnu.org/licenses/licenses.html#GPL .
Table of Content
GNU Wget2 - Introduction
GNU Wget2 is the successor of GNU Wget, a file and recursive website downloader.
Designed and written from scratch it wraps around libwget, that provides the basic functions needed by a web client.
Wget2 works multi-threaded and uses many features to allow fast operation.
In many cases Wget2 downloads much faster than Wget1.x due to HTTP2, HTTP compression, parallel connections and use of If-Modified-Since HTTP header.
GNU Wget2 is licensed under GPLv3+.
Libwget is licensed under LGPLv3+.
Features
A non-exhaustive list of features
--force-rss -i <filename>)--force-atom -i <filename>)--force-sitemap -i <filename>)<META name="robots" ...>--cookie-suffixes <filename>, better: put it into ~/.wgetrc)Links
Online Docs
Mailing List
Bug Tracker
Development
Code Coverage
Fuzz Code Coverage
Build Requirements
The following packages are needed to build the software
The versions are recommended, but older versions may also work.
Downloading and building from tarball
Building from git
Download project and prepare sources with
Build Wget2 with
In Haiku build Wget2 with
Test the functionality
Install Wget2 and libwget
Build static wget2.exe on GNU/Linux for Windows
Build static wget2 on GNU/Linux for Linux/amd64
License
Copyright (C) 2015-2026 Free Software Foundation, Inc.
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
A copy of the GNU General Public License can be found in the file LICENSE in the top directory of the official source distribution. The license is also available in several formats through the World Wide Web, or via http://www.gnu.org/licenses/licenses.html#GPL .