SETTING UP HTTP BASIC AUTHENTICATION
- Layout for this exercise:
data:image/s3,"s3://crabby-images/65983/6598347d886b47dbe90e0b0fefa4f5737ef1744b" alt=""
- Web applications may provide their own access control methods, but a web server can also restrict access by using two types of authentications that are part of the HTTP standard: Basic and Digest authentication.
- HTTP Basic Authentication (BA) is the simplest way to enforce access control to web resources. When making a request, the user agent provides credentials (username and password) to the web server.
- BA uses standard fields in the HTTP header, not providing confidentiality because the credentials are sent just encoded with Base64, but not encrypted or hashed at all.
- For further information about HTTP Basic Authentication:
https://en.wikipedia.org/wiki/Basic_access_authentication
- To implement Basic Authentication on an Apache web server, first of all a password file must be created, so that Apache can read it whenever the web page is requested.
- The utility htpasswd (part of the apache2-utils package) manages user files for basic authentication. As an example, let's take:
username: admin (very common as default username in many devices)
password: ababa (simple, for the purpose of ease in this exercise)
data:image/s3,"s3://crabby-images/4f3a1/4f3a1db59e351acc51ac6530a351bea7a11350fc" alt=""
- The hidden file .htpasswd has been created and stored encrypted on the server side:
data:image/s3,"s3://crabby-images/5026d/5026d7d51cd2c4f9ce955de774625b42bf042594" alt=""
- The default encryption format to store the credentials is "$apr1$" + the result of an Apache-specific algorithm using an iterated (1,000 times) MD5 digest of various combinations of a random 32-bit salt and the password.
https://httpd.apache.org/docs/2.4/misc/password_encryptions.html
- See source file apr_md5.c for the details of the algorithm:
http://svn.apache.org/viewvc/apr/apr/trunk/crypto/apr_md5.c?view=markup
- Editing the Ubuntu default virtual host file (000-default.conf):
data:image/s3,"s3://crabby-images/d82d1/d82d107d6a396165231848be7da7e0396520c54c" alt=""
- Adding the HTTP BA restriction for the directory called "basicauth", where the web page is contained. The <Directory> block specifies that the type of authentication is Basic, the name of the realm (the realm name defines a protection space for a web resource in combination with the canonical root URL of the server being accessed), the path to the .htpasswd file, and the requirement of "valid-user" credentials:
data:image/s3,"s3://crabby-images/cde2d/cde2d853b44a3d4700446d5883a6e60a22ac7d34" alt=""
data:image/s3,"s3://crabby-images/78f85/78f8595c534879dea80b25d16fc33e9a643badeb" alt=""
- In this way, we have established a per-directory basis HTTP BA specific for the directory "basicauth" that we are interested in.
- After editing the virtual host file, let's restart the web server:
data:image/s3,"s3://crabby-images/946c7/946c78821dc0a2ca43fdb1511953a8adcbfdbd37" alt=""
- Configtest command checks that the syntax of the configuration file is correct:
- Reviewing the status of the web server:
data:image/s3,"s3://crabby-images/cbb6b/cbb6b4d574f6521526fa5d654d1b3969da4efedd" alt=""
- Now, a user is prompted to enter credentials when trying to access the web resources contained in the directory "basicauth".
- In case of introducing bad credentials, the server answers with the default "Unauthorized" message:
data:image/s3,"s3://crabby-images/d3c58/d3c589fa69f6f39fd7bdbca96efe1111ef61bc8c" alt=""
data:image/s3,"s3://crabby-images/23651/23651de41aa3ac0b2240643508121392ba5836fb" alt=""
- Introducing the correct credentials, the web resources are finally available:
data:image/s3,"s3://crabby-images/d895e/d895ebe4688836e6deb393a7b03039acae089686" alt=""
data:image/s3,"s3://crabby-images/7cbf2/7cbf24f22a913a49f2959659e965bec8b7a36650" alt=""