![PermissionError: [Errno 13] Permission denied は、CGI でスクリプトを開始するとスローされますが、bash ではスローされません。](https://rvso.com/image/1596118/PermissionError%3A%20%5BErrno%2013%5D%20Permission%20denied%20%E3%81%AF%E3%80%81CGI%20%E3%81%A7%E3%82%B9%E3%82%AF%E3%83%AA%E3%83%97%E3%83%88%E3%82%92%E9%96%8B%E5%A7%8B%E3%81%99%E3%82%8B%E3%81%A8%E3%82%B9%E3%83%AD%E3%83%BC%E3%81%95%E3%82%8C%E3%81%BE%E3%81%99%E3%81%8C%E3%80%81bash%20%E3%81%A7%E3%81%AF%E3%82%B9%E3%83%AD%E3%83%BC%E3%81%95%E3%82%8C%E3%81%BE%E3%81%9B%E3%82%93%E3%80%82.png)
HTTP サーバー (CentOS 7) にクライアント ブラウザーへの応答を担当する Python スクリプトがあります。これは bash では正常に動作しますが、cgi 経由でアクセスしようとするとエラーが発生します。Ubuntu では正常に動作します (HTTP とシェルの両方で)。スクリプトは次のとおりです。
import socket
HOST = '127.0.0.1'
PORT = 4345
print("Content-type: text/html; charset=utf-8\n\n")
sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
sock.connect((HOST, PORT))
query = 'foobar'
sock.sendall(bytes(query, 'utf-8'))
buffer = sock.recv(1024)
responce = str(buffer, "UTF-8")
print(responce)
CGI 経由でスクリプトを実行すると、次のエラーが発生します。
PermissionError: [Errno 13] Permission denied
Traceback (most recent call last):
File "/var/www/cgi-bin/script.py", line 8, in <module>
sock.connect((HOST, PORT))
PermissionError: [Errno 13] Permission denied
「getsebool -a | grep httpd」の出力は次のとおりです。
httpd_anon_write --> off
httpd_builtin_scripting --> on
httpd_can_check_spam --> off
httpd_can_connect_ftp --> off
httpd_can_connect_ldap --> off
httpd_can_connect_mythtv --> off
httpd_can_connect_zabbix --> off
httpd_can_network_connect --> off
httpd_can_network_connect_cobbler --> off
httpd_can_network_connect_db --> off
httpd_can_network_memcache --> off
httpd_can_network_relay --> off
httpd_can_sendmail --> off
httpd_dbus_avahi --> off
httpd_dbus_sssd --> off
httpd_dontaudit_search_dirs --> off
httpd_enable_cgi --> on
httpd_enable_ftp_server --> off
httpd_enable_homedirs --> off
httpd_execmem --> off
httpd_graceful_shutdown --> on
httpd_manage_ipa --> off
httpd_mod_auth_ntlm_winbind --> off
httpd_mod_auth_pam --> off
httpd_read_user_content --> off
httpd_run_ipa --> off
httpd_run_preupgrade --> off
httpd_run_stickshift --> off
httpd_serve_cobbler_files --> off
httpd_setrlimit --> off
httpd_ssi_exec --> off
httpd_sys_script_anon_write --> off
httpd_tmp_exec --> off
httpd_tty_comm --> off
httpd_unified --> off
httpd_use_cifs --> off
httpd_use_fusefs --> off
httpd_use_gpg --> off
httpd_use_nfs --> off
httpd_use_openstack --> off
httpd_use_sasl --> off
httpd_verify_dns --> off
答え1
解決策は、httpd がネットワークに接続できるようにすることでした。を にhttpd_can_network_connect
設定したところ、動作するようになりました。解決策を永続的にするには、スイッチも使用する必要があることに注意してください。on
setsebool
-P