Sometimes you are required to deliver data to your customers. What if you do not possess a beautiful CMS system such as WordPress? Of course, you could just set up a FTP server and provide your customers with login credentials. These who are technical aware will use a proper program to access the data (and thus won’t care for beauty), but those who do not know how to use such a tool will be prompted with something like that:
- Setting Up Apache Web Server
- Setting Up Apache Web Server
- Setting Up Apache Web Server On Ubuntu
- Setting Up Apache Web Server On Windows 10
Setting Up an Apache Container One of the amazing things about the Docker ecosystem is that there are tens of standard containers that you can easily download and use. In the following example we will instantiate an Apache 2.4 container named tecmint-web, detached from the current terminal. This section describes how to set up a single-instance Apache HTTP Server to serve static HTML content. Follow the procedure in this section if the web server should provide the same content for all domains associated with the server. If you want to provide different content for different domains, set up name-based virtual hosts.
A real beauty, isn’t she? We can do much better than that. This time the idea is to create a download server for many customers – where each customer would need to receive individual files (imagine you providing 50 customers with 50 different PDF files). The restrictions? No FTP and – more important – no database. And no programming involved. Sounds impossible? Well no, thanks to the directory listing and the fancyindexing feature of the Apache web server you can create a quite beautiful download site for each individual customer. Results first:
The results can be quite stunning when you know your way around with HTML and CSS, but the more important fact is: we did use the Apache webserver for the result only. No database, no(t too much) coding, no FTP server involved. I promise.
The diagram above pretty much explains all the magic involved (simplified, of course).
- A user tries to access a folder on your site, for example: www.loremipsula.com/14522
- The Apache web server checks first if the user name provided may access this directory
- If the name matches, the web server check if the password provided by the user matches the password in the htpasswd file
- If the authentication was fine, the user can access the files provided in the directory.
The only thing that is VITAL is that the htpasswd file is not accessible to the general public (usually it is not).
The next step is to tell the Apache web server that Indexing should be allowed for a certain directory. This setting usually resides in the httpd.conf file of the web server (note: on OS X systems there is a separate file called {username}.conf in the directory /private/etc/apache2/users which overrules the settings from the httpd.conf!).
Let’s say I want to enable indexes, my directory tag could look like this – AllowOverride is set to All:
Setting Up Apache Web Server
Note that there is a separate switch Indexes only. You may find more detailled information here. Now a separate .htaccess file will be accepted by the web server in my directories!
Let’s say I’ve got five different users: each user is assigned a unique number. Each user is assigned a password. For testing purposes, you can use this tool to generate several passwords for your users. If you have to create more users, you should either use the command line tool or use a script.
Finally, my htpasswd file looks as follows:
For testing purposes, the password for each user is ‘test’.
Now let’s create one folder per user. Within each folder, we need to place a file called .htaccess with the following content (you need to change the location of the htpasswd file):
Although most of it should be clear, here’s a more detailled explanation:
The last step is about the design. As you may have seen, the purple section contains a lot of design-related settings:
As you can see, I currently:
- Use my own header and footer files for a custom logo and custom text and
- Use my own icons for different files that reside in the directory
Setting Up Apache Web Server
All available options are explained in detail here. That’s almost it – now I just need to adjust the user in each and every .htaccess file and put it to the respective directory.
Please note that we are just using http basic authentication here which can be rather insecure if someone can access the traffic – the (hashed) passwords are transmitted base64 encoded only. If you plan to use this in combination with sensitive data, you should apply http digest authentication with apache.
If you need the sample project to give you a better start, feel free to download it here: project.
Setting Up Apache Web Server On Ubuntu
If you want to get to grips with how the web works, one of the most entertaining ways to learn is to build your own local intranet Apache web server to display simple – or even complex – internal websites.
A Raspberry Pi is an ideal Apache web server for small websites that don’t require the capacity or server-side processing power of a more powerful computer, and it’s an ideal development environment if you’re to use HTML.
It can host a personal blog or to-do list, keep a web-based calendar for the household, hold your family photo albums, or simply host a website you’re developing before you’re ready to share it with the world.
See also: Samba: Set up a Raspberry Pi as a File Sever for your local network
Set up Apache Web Server on a Raspberry Pi
Much of the world wide web is built on LAMP – Linux, Apache, MySQL, PHP – often with a content management system (CMS) on top to make it easy to create complex websites with little knowledge of HTML or PHP.
This tutorial will take you through the basics of getting your server’s environment set up. We don’t go as far as installing a CMS, but by the end of the following steps, your Pi will be ready to immediately display ordinary ‘flat’ HTML webpages. If you add the optional step of installing the MySQL database back end and PHP interpreter, you should be all set to install and configure most CMSs by following the instructions they supply.
STEP-01: Install the OS
Hook up the keyboard and mouse to the Pi and connect it to an HDMI monitor. Copy NOOBS to a FAT32-formatted micro SD card; insert it and power up the Pi. Opt to install Raspbian with the PIXEL window manager. This will take a few minutes.
See also: Beginner's Guide to NOOBs
STEP-02: Check the network address
Once the Pi has rebooted, open a Terminal window and run:
Make a note of the ‘inet addr’ value for eth0. This will be the IP address of your web server. It’s a good idea to assign the Pi a static DHCP reservation on your router so the Pi will keep that address permanently.
STEP-03: Update your Pi and install Apache
Run the following commands in the Terminal to make sure Raspbian is up to date. Adding -y to the end of apt-get commands instructs the program to automatically answer yes to any questions rather than waiting for you to type Y or N.
Once this is complete, it’s time to install your new Apache web server:Apache is the main piece of software you need to serve webpages to client PCs.
STEP-04: Add PHP and MySQL (optional)
Many websites use content management systems, such as WordPress. These require PHP and MySQL, so if you want to experiment with CMS-driven sites further down the line, this is an ideal time to add the software you’ll need to render them. You can install both at once using the following command:
Chose a strong password for the MySQL ‘root’ user and note it down somewhere safe.
STEP-05: Test Apache
Open your web browser of choice, either on the Pi or on another PC on your local network, and enter the IP address from step 2 into the address bar. You should see the Apache 2 Debian default page, with a red banner and the words ‘It Works!’ across it.
STEP-06: Start building your site
Your website’s files are located in the /var/www/html
Setting Up Apache Web Server On Windows 10
directory. Run the following to make this folder accessible to the default user, pi.
Delete the index.html file found there and upload your new intranet site to that folder. Your new site should now be accessible from your local network on the address you used in step 5.
Your Pi is an ideal environment for web development, so you can simply drop the HTML files you’re working on into your web server directory. If you want to experiment with more advanced options, you can enable FTP and SSH for remote access to your web server from other computers on your local network. You can also install a CMS such as WordPress, which you’ll be able to access from a browser on your local network to create content-rich websites.
While this is strictly a local web server project, the same software and processes go into an internet-facing server, although that will require firewall configuration and extra security measures that are beyond the scope of this tutorial.