知りたいこと
ローカルの環境とサーバー環境で挙動が違う点があり調べています。
カレントの階層を移動させるプログラムを実行すると、サーバー環境では移動が初回実行時しか成功せず、二度目はエラーが返ってきます。ローカル環境では問題なく成功します。
環境
windows10
apache2.4
python3.8
flask
ソースコード
python
1from flask import Flask,render_template 2import os 3 4app = Flask(__name__) 5 6@app.route("/") 7def sample(): 8 os.chdir("C:/Users/USERNAME/Documents/ディレクトリ名") 9 return render_template("sample.html") 10 11if __name__ == "__main__": 12 app.run(debug=True)
エラーメッセージ(apache)
apache
1[Thu Dec 31 07:34:43.863129 2020] [authz_core:error] [pid 16632:tid 1256] [client ::1:64153] AH01630: client denied by server configuration: C:/Users/USERNAME/Documents/ディレクトリ名/htdocs
httpd.conf
httpd
1 2Define SRVROOT "c:/Apache24" 3ServerRoot "${SRVROOT}" 4 5Listen 80 6Listen 1001 7Listen 2001 8Listen 3001 9Listen 4001 10Listen 5001 11 12LoadModule actions_module modules/mod_actions.so 13LoadModule alias_module modules/mod_alias.so 14LoadModule allowmethods_module modules/mod_allowmethods.so 15LoadModule asis_module modules/mod_asis.so 16LoadModule auth_basic_module modules/mod_auth_basic.so 17LoadModule authn_core_module modules/mod_authn_core.so 18LoadModule authn_file_module modules/mod_authn_file.so 19LoadModule authz_core_module modules/mod_authz_core.so 20LoadModule authz_groupfile_module modules/mod_authz_groupfile.so 21LoadModule authz_host_module modules/mod_authz_host.so 22LoadModule authz_user_module modules/mod_authz_user.so 23LoadModule autoindex_module modules/mod_autoindex.so 24LoadModule cgi_module modules/mod_cgi.so 25LoadModule dir_module modules/mod_dir.so 26LoadModule env_module modules/mod_env.so 27LoadModule include_module modules/mod_include.so 28LoadModule isapi_module modules/mod_isapi.so 29LoadModule log_config_module modules/mod_log_config.so 30LoadModule mime_module modules/mod_mime.so 31LoadModule negotiation_module modules/mod_negotiation.so 32LoadModule setenvif_module modules/mod_setenvif.so 33 34<IfModule unixd_module> 35User daemon 36Group daemon 37</IfModule> 38 39ServerAdmin admin@example.com 40 41ServerName localhost:80 42 43<Directory /> 44 AllowOverride none 45 Require all denied 46</Directory> 47 48DocumentRoot "${SRVROOT}/htdocs" 49<Directory "${SRVROOT}/htdocs"> 50 Options Indexes FollowSymLinks ExecCGI 51 AllowOverride None 52 Require all granted 53</Directory> 54 55<IfModule dir_module> 56 DirectoryIndex index.html 57</IfModule> 58 59<Files ".ht*"> 60 Require all denied 61</Files> 62 63ErrorLog "logs/error.log" 64 65LogLevel warn 66 67<IfModule log_config_module> 68 LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined 69 LogFormat "%h %l %u %t \"%r\" %>s %b" common 70 71 <IfModule logio_module> 72 LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio 73 </IfModule> 74 75 CustomLog "logs/access.log" common 76 77</IfModule> 78 79<IfModule alias_module> 80 ScriptAlias /cgi-bin/ "${SRVROOT}/cgi-bin/" 81</IfModule> 82 83<IfModule cgid_module> 84</IfModule> 85 86<Directory "${SRVROOT}/cgi-bin"> 87 AllowOverride None 88 Options None 89 Require all granted 90</Directory> 91 92<IfModule headers_module> 93 RequestHeader unset Proxy early 94</IfModule> 95 96<IfModule mime_module> 97 TypesConfig conf/mime.types 98 AddType application/x-compress .Z 99 AddType application/x-gzip .gz .tgz 100 AddHandler cgi-script .cgi .py 101</IfModule> 102 103<IfModule proxy_html_module> 104Include conf/extra/proxy-html.conf 105</IfModule> 106 107<IfModule ssl_module> 108SSLRandomSeed startup builtin 109SSLRandomSeed connect builtin 110</IfModule> 111 112LoadFile "c:/users/USERNAME/appdata/local/programs/python/python38/python38.dll" 113LoadModule wsgi_module "c:/users/USERNAME/appdata/local/programs/python/python38/lib/site-packages/mod_wsgi/server/mod_wsgi.cp38-win_amd64.pyd" 114WSGIPythonHome "c:/users/USERNAME/appdata/local/programs/python/python38" 115 116<VirtualHost *:1001> 117 DocumentRoot "htdocs/app/APP1" 118 WSGIScriptAlias / "htdocs/app/APP1/main.wsgi" 119 <Directory "htdocs/app/APP1"> 120 Require all granted 121 </Directory> 122</VirtualHost> 123 124<VirtualHost *:2001> 125 DocumentRoot "htdocs/app/APP2" 126 WSGIScriptAlias / "htdocs/app/APP2/main.wsgi" 127 <Directory "htdocs/app/APP2"> 128 <Files main.wsgi> 129 Require all granted 130 </Files> 131 </Directory> 132</VirtualHost> 133 134<VirtualHost *:3001> 135 DocumentRoot "htdocs/app/APP3" 136 WSGIScriptAlias / "htdocs/app/APP3/main.wsgi" 137 <Directory "htdocs/app/APP3"> 138 Require all granted 139 </Directory> 140</VirtualHost> 141 142<VirtualHost *:4001> 143 DocumentRoot "htdocs/app/APP4" 144 WSGIScriptAlias / "htdocs/app/APP4/main.wsgi" 145 WSGIApplicationGroup %{GLOBAL} 146 <Directory "htdocs/app/APP4"> 147 <Files main.wsgi> 148 Require all granted 149 </Files> 150 </Directory> 151</VirtualHost> 152 153<VirtualHost *:5001> 154 DocumentRoot "htdocs/app/sample" 155 WSGIScriptAlias / "htdocs/app/sample/main.wsgi" 156 <Directory "htdocs/app/sample"> 157 Require all granted 158 </Directory> 159</VirtualHost> 160
気になるのが、エラーメッセージで返ってくるパスの末尾にhtdocsが追加されていることです。
また、その際の画面表示は
Forbidden
You don't have permission to access this resource.
です。
サーバー上ではどのような動作が行われているのでしょうか。
アドバイスいただけると助かります。よろしくお願いいたします。
回答1件
あなたの回答
tips
プレビュー