我的 django 应用程序(让我称之为partlysecureapp
)有一个对所有人可见的索引页面。所有其他页面(可从索引页面上的链接访问)需要用户登录。我想在 apache2 中使用带有 SSL 的应用程序。
我已经有一个mysecureapp
使用 SSL 部署在 apache 上的应用程序(比如),它包含所有需要用户登录的页面。我为此设置了如下配置。
我的 apache2 所在/etc/apache2
的目录结构如下。
/etc/apache2/
|--conf.d---*charset,security,localized-error-pages*
|---mods-available---...
|---mods-enabled---...
|---sites-available---default,default-ssl,ssl
|---sites-enabled---shortcut to ssl
|---apach2.conf
|---httpd.conf
|---ports.conf
|---magic
|---envvars
对于secureapp
,我已经在文件中设置了这个sites-available/ssl
<VirtualHost *:443>
ServerAdmin webmaster@localhost
DocumentRoot /home/dev/python/django/mysecureapp
SSLEngine on
SSLOptions +StrictRequire
SSLCertificateFile /etc/ssl/certs/server.crt
SSLCertificateKeyFile /etc/ssl/private/server.key
...
WSGIScriptAlias /mysecureapp /home/dev/python/django/mysecureapp/mysecureapp.wsgi
Alias /site_media/ /home/dev/python/django/mysecureapp/media/
</VirtualHost>
这完美..
要部署我的partlysecureapp
,
http://127.0.0.1:8080/partlysecureapp/
需要显示所有人都可以访问的索引页面。但
../partlysecureapp/link1/
../partlysecureapp/link2/
../partlysecureapp/link3/
需要登录并且应该通过 ssl 提供。
我想,我需要WSGIScriptAlias
为我的partlysecureapp
. 我需要添加另一个DocumentRoot
吗partlysecureapp
?如何告诉apache8080
通过ssl端口从端口和其他人提供索引页面?
截至目前/etc/apache2/httpd.conf
为空白。只有sites-available/ssl
文件有一个VirtualHost
元素。