Dr. Dobb's is part of the Informa Tech Division of Informa PLC

This site is operated by a business or businesses owned by Informa PLC and all copyright resides with them. Informa PLC's registered office is 5 Howick Place, London SW1P 1WG. Registered in England and Wales. Number 8860726.


Channels ▼
RSS

Internal Security: Rules and Risks (Web Techniques, July 2001)


Web Techniques: Sidebar


Configuring mod_access in Apache

You can use Apache's mod_access module to restrict access to information on the server based on client hostname, IP address, or other client information that can be captured using environment variables. To configure mod_access, you must set Apache server directives in the httpd.conf file.

There are two directives used for mod_access: allow and deny. Deny is expressed using the following syntax:

Deny from host

Where host can be any one of the following:

  • All
    Does not allow any host to have access to the specified resource. May be used in combination with allow to create fine-grained security policies.
    <code>Deny from all</code>

  • Hostname
    Restricts access from a particular host or Internet domain. Note that this requires Apache to do a DNS lookup every time it processes this directive, potentially slowing the system down considerably.

    Deny from mail.spam.com
    Deny from evil.com
    Deny from .gov
    

  • IP Address
    Like the hostname directive, denies access to a particular computer or a particular network of computers. However, Apache can process access control using IP address information much more rapidly than with hostname information. IP addresses can also be restricted according to subnet mask.
    Deny from 63.206.192.87
    Deny from 192.168.
    Deny from 10.
    Deny from 10.0.1.0/255.255.0.0
    

The opposite of deny is allow. Using the allow directive lets you configure which hosts are to be allowed access to the intranet. The arguments used are identical to those of the deny directive.

The deny and allow directives are not mutually exclusive. In fact, for most access control applications, you'll probably want to use both. To make this work, you must tell Apache whether to process deny directives before allow, or vice versa. That's where the Order directive comes in:

  • Order deny,allow
    Process the deny directive first, then allow directive
  • Order allow,deny
    Process the allow directive first, then deny

For example, if I had a directory on the paulsholtz.com Web server called "paul," and I wanted to allow only users from the paulsholtz.com domain access to this directory, I could add the following directive to the httpd.conf file:

<Directory /paul>
Order deny,allow
    Deny from all
    Allow from paulsholtz.com
</Directory>

This lets me set a default deny access control policy, and allow only users from hosts attached to the paulsholtz.com domain.

--PS



Related Reading


More Insights






Currently we allow the following HTML tags in comments:

Single tags

These tags can be used alone and don't need an ending tag.

<br> Defines a single line break

<hr> Defines a horizontal line

Matching tags

These require an ending tag - e.g. <i>italic text</i>

<a> Defines an anchor

<b> Defines bold text

<big> Defines big text

<blockquote> Defines a long quotation

<caption> Defines a table caption

<cite> Defines a citation

<code> Defines computer code text

<em> Defines emphasized text

<fieldset> Defines a border around elements in a form

<h1> This is heading 1

<h2> This is heading 2

<h3> This is heading 3

<h4> This is heading 4

<h5> This is heading 5

<h6> This is heading 6

<i> Defines italic text

<p> Defines a paragraph

<pre> Defines preformatted text

<q> Defines a short quotation

<samp> Defines sample computer code text

<small> Defines small text

<span> Defines a section in a document

<s> Defines strikethrough text

<strike> Defines strikethrough text

<strong> Defines strong text

<sub> Defines subscripted text

<sup> Defines superscripted text

<u> Defines underlined text

Dr. Dobb's encourages readers to engage in spirited, healthy debate, including taking us to task. However, Dr. Dobb's moderates all comments posted to our site, and reserves the right to modify or remove any content that it determines to be derogatory, offensive, inflammatory, vulgar, irrelevant/off-topic, racist or obvious marketing or spam. Dr. Dobb's further reserves the right to disable the profile of any commenter participating in said activities.

 
Disqus Tips To upload an avatar photo, first complete your Disqus profile. | View the list of supported HTML tags you can use to style comments. | Please read our commenting policy.