When a user requests a resource that is protected, the browser will prompt the user for a username and password if they have not already supplied one. If the proper credentials are present in the Authorization header, the server will grant access to the resource and set the to the value of the username. If the header is missing or the credentials are incorrect, the server will respond with HTTP 401 Unauthorized.

    This directive allows use of .htpasswd files by prefixing the password argument with htpasswd= and the path to the .htpasswd file to use. Support for .htpasswd is for legacy sites only and may be removed in the future; do not use .htpasswd with new sites.

    Note that basicauth does not protect requests. This is so that clients can know whether to prompt for authentication in cross-origin contexts. We emphasize that servers violate RFC 2616 if they respond to OPTIONS with a resource retrieval (i.e. if they respond with secret content to OPTIONS requests).

    • path is the file or directory to protect
    • username is the username
    • password is the password

    This syntax is convenient for protecting a single file or base path/directory with the default realm “Restricted”. To protect multiple resources or to specify a realm, use the following variation:

    • password is the password.
    • realm identifies the protection partition; it is optional and cannot be repeated. Realms are used to specify the space in which the protection applies. This can be convenient for user agents that are configured to remember authentication details (which is most browsers).
    • resources is a list of files/directories to protect, one per line.

    Protect all files in /secret so only Bob can access them with the password “hiccup”:

    Protect multiple files and directories in the realm “Mary Lou’s documents” so Mary Lou has access with her password “milkshakes”:

    Join us in the Caddy forum, where the open source community gathers to share their knowledge.