Я использую nginx в своей MacOS для тестирования сторонних аутентификаций, таких как Google и Twitter, на локальном хосте. В результате на моем локальном сайте https://локальный:8000/...
, я мог бы заниматься с www.funfun.io
для сторонних аутентификаций.
Вот файл конфигурации nginx:
рабочие_процессы 1;
События {
worker_connections 1024;
}
http {
включить mime.types;
default_type application/octet-stream;
отправить файл включен;
keepalive_timeout 65;
log_format my_log '{ "время": "$time_iso8601", '
'"remote_addr": "$remote_addr", '
'"статус": "$статус", '
'"запрос": "$запрос", '
'"request_method": "$request_method", '
'"http_referrer": "$http_referer", '
'"http_x_forwarded_for": "$http_x_forwarded_for", '
'"хост": "$хост", '
'"имя_сервера": "имя_сервера$", '
'"upstream_address": "$upstream_addr", '
'"upstream_status": "$upstream_status", }';
access_log /usr/local/var/log/nginx/my_log_access.log my_log;
веселье вверх по течению {
сервер 178.62.87.72:443;
}
сервер {
слушать 443 ssl;
имя_сервера локальный хост;
ssl_certificate /etc/ssl/localhost/localhost.crt;
ssl_certificate_key /etc/ssl/localhost/localhost.key;
ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
ssl_prefer_server_ciphers включен;
ssl_session_timeout 1 д;
ssl_stapling выключен;
ssl_stapling_verify выключен;
add_header Strict-Transport-Security max-age=15768000;
add_header X-Frame-Options "";
proxy_ssl_name "www.funfun.io";
proxy_ssl_server_name включено;
местоположение ~ /socialLoginSuccess {
переписать ^ '/#/socialLoginSuccess' перенаправить;
}
расположение ~ /auth/(.*) {
proxy_pass https://funfun/10studio/auth/$1?$query_string;
proxy_set_header Хост localhost;
}
}
включить серверы/*;
}
Вот логи регистрации.
{ "time": "2021-11-11T01:02:47+01:00", "remote_addr": "127.0.0.1", "status": "302", "request": "GET /10studio/auth/ google HTTP/1.1", "request_method": "GET", "http_referrer": "https://localhost:8000/", "http_x_forwarded_for": "-", "host": "localhost", "server_name": " localhost", "upstream_address": "178.62.87.72:443", "upstream_status": "302" }
{ "time": "2021-11-11T01:02:50+01:00", "remote_addr": "127.0.0.1", "status": "302", "request": "GET /auth/google/ callback?code=4%2F0AX4XfWihw3erIiZok3Yk8jZ5hjcg4sT35YLuZAp5h3qIDZvC_BuHSlvbRiTSh4Sobo_Wbw&scope=email+profile+https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fuserinfo.profile+https%3A%2F%2Fwww.googleapis.com%2Fauth%2Fuserinfo.email+openid&authuser= 0&prompt=consent HTTP/1.1", "request_method": "GET", "http_referrer": "https://accounts.google.com/", "http_x_forwarded_for": "-", "host": "localhost", " server_name": "localhost", "upstream_address": "178.62.87.72:443", "upstream_status": "302" }
{ "time": "2021-11-11T01:02:50+01:00", "remote_addr": "127.0.0.1", "status": "302", "request": "GET /auth/signinSuccess HTTP /1.1", "request_method": "GET", "http_referrer": "https://accounts.google.com/", "http_x_forwarded_for": "-", "host": "localhost", "server_name": " localhost", "upstream_address": "178.62.87.72:443", "upstream_status": "302" }
{ "time": "2021-11-11T01:02:50+01:00", "remote_addr": "127.0.0.1", "status": "302", "request": "GET /socialLoginSuccess HTTP/1.1 ", "request_method": "GET", "http_referrer": "https://accounts.google.com/", "http_x_forwarded_for": "-", "host": "localhost", "server_name": "localhost" , "upstream_address": "-", "upstream_status": "-" }
Процесс входа в систему выглядит следующим образом:
- Я начинаю с веб-страницы
https://локальный:8000/#/старт
, где есть кнопка для входа через Google.
- Я нажимаю на ту кнопку, чей адрес
https://localhost/10studio/auth/google
.
- Веб-страница
https://accounts.google.com/...
отображается, где мы могли бы выбрать учетную запись Google
- После успешного входа веб-страница
https://localhost/#/socialLoginSuccess
отображается.
Все шаги работают нормально, кроме последнего; финал https://localhost/#/socialLoginSuccess
отображает веб-страницу Добро пожаловать в Nginx!
. Правильный URL должен быть https://localhost:8000/#/socialLoginSuccess
.
Кто-нибудь знает, как я могу изменить файл конфигурации nginx, чтобы конечный URL-адрес приводил к https://localhost:8000/#/socialLoginSuccess
?
Редактировать 1:
Вот код funfun.io:
(* под app.js *)
var _10studio = require('./routes/10studio');
app.use('/10studio', _10studio);
(* под маршрутами/10studio.js *)
router.get('/auth/google', паспорт.authenticate('10studio-google', {
область действия: ['https://www.googleapis.com/auth/userinfo.profile',
'https://www.googleapis.com/auth/userinfo.email']
}));
router.get('/auth/google/callback', паспорт.authenticate('10studio-google', {
SuccessRedirect: '/auth/signinSuccess',
failureRedirect: '/auth/signinFailure',
сбойFlash: правда
}))
router.get('/auth/signinSuccess', function (req, res, next) {
res.redirect("/socialLoginSuccess");
})