我在SSL问题上苦苦挣扎。我尝试连接到Web应用程序以获取Python应用程序但每次执行请求时都会出现此错误:
RestClient::SSLCertificateNotVerified: SSL_connect returned=1 errno=0 state=error: certificate verify failed:
python code to launch the server如下:
http_server = WSGIServer(('',int(port)),app,log = nylas_logger,
handler_class = NylasWSGIHandler,
keyfile =' /vagrant/server.key' ;, certfile =' /vagrant/server.crt')
rvm osx-ssl-certs update all
最令人惊讶的是,我实际上可以使用相同的证书在另一种类型的服务器上执行请求,因此似乎问题可能出在Python Web服务器上。
答案 0 :(得分:0)
事实证明gevent.pywsgi服务器没有正确处理SSL证书。 我安装了Nginx并在localhost Python gevent.pywsgi服务器上执行了反向代理,并在Nginx部分进行了SSL处理,并立即工作。
有关信息,我的nginx conf:
server{
listen 80;
return 301 https://$host$request_uri;
}
server{
listen 443;
server_name subdomain.domain.com;
ssl on;
ssl_certificate /etc/nginx/ssl/cert.pem;
ssl_certificate_key /etc/nginx/ssl/cert.key;
location / {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proro $scheme;
proxy_pass http://localhost:5555;
proxy_read_timeout 90;
proxy_pass_request_headers on;
proxy_redirect http://localhost:5555 https://subdomain.domain.com;
}
}
我限制python服务器只监听localhost请求。