我已经关注本教程parse-server
在 DigitalOcean Ubuntu droplet 上安装。我还安装了parse-dashboard
。
除了我不能curl
使用之外,一切都运行良好SSL
。常规HTTP
工作正常。即:
curl -H "X-Parse-Application-Id: AppID" https://mywebsite/parse/classes/GameScore
返回Cannot GET /classes/GameScore
。
我也无法访问parse-dashboard
,SSL
但HTTP
工作正常(这意味着我的密钥可能会泄露)。
POST 请求返回一个Cannot POST
。
我尝试启用/禁用防火墙(ufw
),但没有任何改变。
我可以使用 SDK 保存数据,尽管速度很慢。我的 nginx 配置文件与教程中的相同。
有任何想法吗?
编辑:
Nginx 配置:
# HTTP - redirect all requests to HTTPS
server {
listen 80;
listen [::]:80 default_server ipv6only=on;
return 301 https://$host$request_uri;
}
# HTTPS - serve HTML from /usr/share/nginx/html, proxy requests to /parse/
# through to Parse Server
server {
listen 443;
server_name your_domain_name;
root /usr/share/nginx/html;
index index.html index.htm;
ssl on;
# Use certificate and key provided by Let's Encrypt:
ssl_certificate /etc/letsencrypt/live/domain.com/fullchain.pem;
ssl_certificate_key /etc/letsencrypt/live/domain.com/privkey.pem;
ssl_session_timeout 5m;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers on;
ssl_ciphers 'EECDH+AESGCM:EDH+AESGCM:AES256+EECDH:AES256+EDH';
# Pass requests for /parse/ to Parse Server instance at localhost:1337
location /parse/ {
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://localhost:1337/;
proxy_ssl_session_reuse off;
proxy_set_header Host $http_host;
proxy_redirect off;
}
location / {
try_files $uri $uri/ =404;
}
}
netstat -anlp |复制代码 443:
netstat -anlp | grep 443
(No info could be read for "-p": geteuid()=1000 but you should be root.)
tcp 0 0 0.0.0.0:443 0.0.0.0:* LISTEN
-
答案1
HTTPS 指南中有错误,请将 proxy_pass 设置为
proxy_pass http://localhost:1337/parse/;
并且 curl 请求必须在没有端口 1337 的情况下进行,就像这样
curl -H "X-Parse-Application-Id: appID" https://example.com/parse/classes/SomeClassName
仪表板
我解决了SSH 隧道到服务器并以本地主机的身份连接到仪表板,这意味着您不需要任何凭据,它将在本地主机上的 http 上运行,因为您将通过 SSH 隧道得到保护,我也只在需要时才打开仪表板...如何设置 SSH 隧道