免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3687 | 回复: 2
打印 上一主题 下一主题

请苹果的粉丝们救我,一个APACHE的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2004-03-22 15:05 |只看该作者 |倒序浏览
我把公司的网页想做到这个要求,大家看一下,我应怎么做?
网页上的某个链接需要设置成身份验证,即我点击该链接就会弹出一个身份验证的对话,只要通过身份验证才能继续,否则仍返回到原页面。大家帮忙出出主意。
这个周要交老板,否则死定了。望大侠们百忙中抽点空给回个贴。
能不涉及到编程最好。如果实在要编程,那也无妨。


引文:
用户授权和访问控制

你也许在访问某些网站时会遇到过这样的情况,当你点击某个连接时,你的浏览器会弹出一个身份验证的对话框,要求输入账号及密码,如果没有,就无法继续浏览了。有人会以为这是用CGI做出来的,其实不然,这是WWW服务器的用户授权和访问控制机制在发挥作用。
你是否还记得在设置Apache服务环境的过程中,有<Directory>;……..<./Directory>;这个指令,可以对不同的目录提供不同的保护。但是这样的设定,需要重新启动服务器才会生效,灵活性较差,通过AccessFile指令指定访问控制文件的方式则比较灵活,在Apache服务器中设置用户的访问控制权限步骤如下:

1、首先对httpd.conf文件进行设置如下:

<Directory /home/httpd/html>;
# AllowOverride FileInfo AuthConfig Limit
# Options MultiViews Indexes SymLinksIfOwnerMatch IncludesNoExec
Options Includes FollowSymLinks Indexes
AllowOverride All //*注意AllowOverride 一定要设置为All,这样后面的.htaccess文件才会起作用
<Limit GET POST OPTIONS PROPFIND>;
Order allow,deny
Allow from all
</Limit>;
# <Limit PUT DELETE PATCH PROPPATCH MKCOL COPY MOVE LOCK UNLOCK>;
# Order deny,allow
# Deny from all
# </Limit>;
</Directory>;
#指定配置存取控制权限的文件名称
AccessFileName .htaccess

2、创建.htaccess文件內容

要控制某目录的访问权限必须建立一访问控制文件,文件名前面指定的“.htaccess”,其内容格式如下:

AuthUserFile 用户帐号密码文件名
AuthGroupFile 群组帐号密码文件名
AuthName 画面提示文字
AuthType 验证方式
<Limit GET>;
密码验证方式
</Limit>;
用户验证方式AuthType目前提供了Basic和Digest两种。
密码检验设定方法与httpd.conf中的相关设定相同。
具体例子如下:
AuthUserFile /etc/secure.user
AuthName 安全认证中心
AuthType Basic
<Limit GET>;
require valid-user
</Limit>;

3、建立用户密码文件

如果你是第一次创建用户密码,命令格式如下:
htpasswd -c 密码文件名 用户名称
在上面的例子中,我们将用户密码文件放到了/etc/secure.user文件中,所以这里应按照如下进行操作:
htpasswd -c /etc/secure.user sword
程序会提示你输入两次用户的口令,然后用户密码文件就已经创建sword这个用户也添加完毕了。
如果要向密码文件中添加新的用户,按照如下命令格式进行操作:
htpasswd 密码文件 用户名称
这样,重新启动httpd后,进行该WEB目录时就会有一个对话框弹出,要求输入用户名及用户口令了。

4、如何减少访问控制对Apache性能的影响
频繁的使用访问控制会对Apache的性能产生较大的影响,那么,如何才能减少这种影响呢?最简单也是最有效的方法之一就是减少.htaccess文件的数目,这样可以避免Apache对每一个请求都要按照.htaccess文件的内容进行授权检查。它不仅在当前的目录中查找.htaccess文件,它还会在当前目录的父目录中查找。

/
/usr
/usr/local
/usr/local/etc
/usr/local/etc/httpd
/usr/local/etc/httpd/htdocs
/usr/local/etc/httpd/htdocs/docs
通常在根目录下没有htaccess文件,但Apache仍然会进行例行检查以确定该文件确实不存在。这是影响很影响服务器工作效率的事情。下面的方法可以消除这个讨厌的过程:将AllowOverride选设置为None,这样Apache就会检查.htaccess文件了。将/根目录的AllowOverride选项设为None,只将需要进行访问控制的目录下的AllowOverride选项设置为all,如下面的例子中将/根目录的AllowOverride 选项关闭了,只打开了/usr/local/etc/httpd/htdocs目录下的AllowOerride选项,这样,系统就只在/usr/local/etc/httpd/htdocs中检查.htaccess文件,达到的提高服务效率的目的。

<Directory />;
AllowOverride None
</Directory>;

<Directory /usr/local/etc/httpd/htdocs>;
AllowOverride All
</Directory>;


如果除了根目录以外,还有其它存放WWW文件的目录,你也可以采取同样的方法进行设置。比如:如果你使用UserDir来允许用户访问自己的目录,AllowOverride的设置如下:
<Directory /home/*/public_html>;
AllowOverride FileInfo Indexes IncludesNOEXEC
</Directory>;

5、防止用户访问指定的文件
系统中有一些文件是不适宜提供给WWW用户的,如:.htaccess、htpasswd、*.pl等,可以用<Files>;达到这个目的:
<Files .htaccess>;
order allow,deny
deny from all
</Files>;
用户访问控制三个.htaccess文件、.htpasswd和.htgroup(用于用户授权) ,为了安全起见,应该防止用户浏览其中内容,可以在httpd.conf中加入以下内容阻止用户对其进行访问:
<Files ~”/.ht”>;
Order deny, allow
Deny from all
</Files>;
这样这三个文件就不会被用户访问了。

6、限制某些用户访问特定文件
<Directory>;可以对目录进行约束,要限制某些用户对某个特定文件的访问可以使用<Location>;,比如:不允许非domain.com域内的用户对/prices/internal.html进行访问,可以用如下的设置:

<Location /prices/internal.html>;
order deny,allow
deny from all
allow from .domain.com
</Location>;
如果你要授于相应权限的机器没有公开的域名,请在你的/etc/hosts文件中,将其IP地址映射到某个指定的名称,然后在Location中对其进行设置,否则该选项是不起作用的。

7、只接受来自特定链接的访问
例如,只让所有来自 http://www.sina.com.cn/* 的链接的用户进入此目录,由其它链接来的访客都不得进入; " * "表示此网站底下所有的链接。其中的 http://www.sina.com.cn/* 也可以是:http://202.106.184.200/* 或是指定文件 http://www.sina.com.cn/news.html
.htaccess文件的内容如下:
AuthUserFile /dev/null
AuthGroupFile /dev/null
AuthName ExampleAllowFromSpecificURL
AuthType Basic
<Limit GET>;
order deny,allow
deny from all
referer allow from http://www.sina.com.cn/*
</Limit>;


_________________
我真不懒,但什么没没留下。
如果非要我留下什么,很遗憾,我只留下这些。
如果你软硬兼施,我告诉你,我有一深爱老婆和一份称职工作。
BSD智库


各位老大能不能告诉我,苹果中的APACHE的配置怎么改呀?如何去改呀,怎么改才能实现我第一行的要求,能达到身份验证的目的呀?

论坛徽章:
0
2 [报告]
发表于 2004-03-23 13:51 |只看该作者

请苹果的粉丝们救我,一个APACHE的问题

虽然不太理解为什么你要在苹果上来做这件简单的事情,如果说你需要一个把Apache应用接口(Enhanced Apache API (EAPI)),OpenSSL和mod_ssl模块都编译进去的Apache服务器。苹果电脑已经在Mac OS X上提供了必要的元素,而且你可以在Mac OS X的标准安装中找到这些产品的文档:

Apache使用手册(http://localhost/manual)。
mod_ssl用户手册 (file://localhost/Library/Documentation/Services/apache_mod_ssl/index.html)。
OpenSSL的“man”页面(在Terminal窗口中键入man openssl)。

第一件事就是加入sign.sh脚本文件,它是一个随 mod_ssl源代码一起发布的文件。

如果您知道如何启动Terminal程序,如何运行sudo,以及如何编辑Apache中的httpd.conf配置文件,那情况就非常好了。我个人喜欢使用emacs来编辑文本文件,并且已经把使用emacs所需的命令包含进这个脚本了。请随意使用pico,TextEdit,BBEdit,或者任何您知道如何使用的文本编辑器。

sudo命令可以使您临时变成一个“超级用户”。如果要使用这个命令,需要知道系统管理员组成员的密码。通过NetInfo Manager (在/groups/admin路径下),你可以查看管理员组成员信息。

最后,由于加密是一个缩写词很多的主题,在手边有一个好的加密领域的术语表,可能很有帮助。您将会碰到下面的缩写词:

RSA:一个广泛使用的,由Rivest,Shamir,和Adelman开发的公钥加密系统。
DES: 数据压缩标准(Data Encryption Standard)。一个广泛商用的密码体系。Triple DES (3DES)描述了使用两个或者三个DES密钥进行三次加密的过程。
PEM: 隐私增强邮件(Privacy Enhanced Mail)。一个来自IETF的电子邮件加密协议。

附:加密领域的术语表
http://www.visi.com/crypto/inet-crypto/glossary.html

如果你已经好配置SSL,私钥和安全证书了,那么记下以下这段操作,如果你的web服务器现在还在运行的话,请停止它。用控制面板中的共享项,或者在命令行终端执行下面的命令都可以:

        sudo apachectl stop

接着编辑/etc/httpd/httpd.conf文件。首先需要为这个文件做一个备份。请记住,这个目录是属于root用户所有,你需要用sudo来执行所有的命令。下面的命令是把当前工作目录移动到/etc/httpd目录下,并为httpd.conf文件做一个拷贝:

        cd /etc/httpd
        sudo cp httpd.conf httpd.conf.backup

现在,可以使用编辑器编辑httpd.conf文件了。我使用的是emacs编辑器,因而用下面的指令来启动编辑器:

        sudo emacs httpd.conf

首先,要把含有“Port”指示符的行注释掉,即在该行的前面输入一个“#”号。

Port 80 应该变成 #Port 80。还要在Port指示符的正下方加入下面的文本:

        ## SSL Support
        ##
        ## When we also provide SSL we have to listen to the
        ## standard HTTP port (see above) and to the HTTPS port
        ##
       
       
        <IfModule mod_ssl.c>;
                        Listen 443
                        Listen 80
        </IfModule>;

增加这些行是为了让服务器知道80端口(标准的HTTP端口)和443端口(HTTPS端口)上的通讯数据。并且告诉支持SSL(安全套接口层)的Apache服务器在80端口上提供非安全信息而在443端口上提供安全信息 。

接下来,在httpd.conf文件中找到以下文本:

#LoadModule ssl_module         libexec/httpd/libssl.so
稍微往下一点的地方还有下面所示的行:
#AddModule mod_ssl.c
删除这些行的注释标志(#),以便激活这些模块。按CTRL + s (在emacs中)键,然后键入“ssl”,可以进行快速查找。

修改后,这两行文本应如下所示:

        LoadModule ssl_module         libexec/httpd/libssl.so

        AddModule mod_ssl.c

接下来,找到“ServerName”指示符,确认这个入口的值是127.0.0.1。

ServerName 127.0.0.1
最后,在当前这个httpd.conf文件的最后一行下面,输入下文所示的信息。这些信息包含一些全局的SSL指示符和基于虚拟主机的端口专用指示符。

<IfModule mod_ssl.c>;
# Some MIME-types for downloading Certificates and CRLs
  AddType application/x-x509-ca-cert .crt
  AddType application/x-pkcs7-crl .crl

# inintial Directives for SSL

  SSLProtocol all -SSLv3
  SSLPassPhraseDialog builtin
  SSLSessionCache dbm:/var/run/ssl_scache
  SSLSessionCacheTimeout 300
  SSLMutex file:/var/run/ssl_mutex
  SSLRandomSeed startup builtin
  SSLLog /var/log/httpd/ssl_engine_log                
  SSLLogLevel info
##
## SSL Virtual Host Context
##
<VirtualHost 127.0.0.1:80>;
  #Just to keep things sane...
    DocumentRoot "/Library/WebServer/Documents"
    ServerName 127.0.0.1
    ServerAdmin bobdavis@mac.com
    SSLEngine off
</VirtualHost>;
<VirtualHost 127.0.0.1:443>;
  # General setup for the virtual host
    DocumentRoot "/Library/WebServer/Documents"
  #ServerName has to match the server you entered into the CSR
    ServerName 127.0.0.1
    ServerAdmin bobdavis@mac.com
    ErrorLog /var/log/httpd/error_log
    TransferLog /var/log/httpd/access_log
  # SSL Engine Switch:
  # Enable/Disable SSL for this virtual host.
    SSLEngine on
    SSLProtocol all -SSLv3
    SSLCipherSuite ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP:+eNULL
  # Path to your certificates and private key               
    SSLCertificateFile /etc/httpd/ssl.key/server.crt
    SSLCertificateKeyFile /etc/httpd/ssl.key/server.key
    <Files ~ "\.(cgi|shtml|phtml|php3?)$">;
      SSLOptions +StdEnvVars
    </Files>;
    <Directory "/Library/WebServer/CGI-Executables">;
      SSLOptions +StdEnvVars
    </Directory>;
# correction for browsers that don't always handle SSL connections well
    SetEnvIf User-Agent ".*MSIE.*" \
    nokeepalive ssl-unclean-shutdown \
    downgrade-1.0 force-response-1.0
# Per-Server Logging:
# The home of a custom SSL log file. Use this when you want a
# compact non-error SSL logfile on a virtual host basis.
    CustomLog /var/log/httpd/ssl_request_log \
    "%t %h %{SSL_PROTOCOL}x %{SSL_CIPHER}x \"%r\" %b"
</VirtualHost>;
</IfModule>;
现在,可以保存文件(CTRL-x CTRL-s)并关闭emacs(CTRL-x CTRL-c)了。

还有很多指示符可以添加到机器的SSL配置文件中来进行功能配置,包括使用扩展的日志功能,对使用过的密码进行限制,以及加密的级别等等。在Mac OS X提供的Apache文档(/Library/Documentation/Services/apache_mod_ssl/index.html)或者位于http://www.modssl.org/的在线文档中,都有全面的描述。

论坛徽章:
0
3 [报告]
发表于 2004-04-05 12:11 |只看该作者

请苹果的粉丝们救我,一个APACHE的问题

哇~~   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP