Evgenii Legotckoi
Evgenii LegotckoiҚаз. 27, 2018, 7:36 Т.Қ.

Джанго - Сабақ 040. Әлеуметтік желілер арқылы аутентификацияны қалай қосуға болады. Facebook

Facebook арқылы сайттағы авторизацияны күшейтті.

Сонымен қатар, мен тағы бірнеше тұзақ жинадым.

Facebook-ке дейін мен VKontakte және Google әлеуметтік желілері арқылы авторизацияны бұрап алдым. Бұл жерде маған құпиялылық саясаты бетін жасау керек болды, себебі Facebook бұл бетті қажет етеді және пайдаланушы келісімін де талап етеді, бірақ мен құпиялылық саясаты бетін бердім. Сайттың өсуімен мен толыққанды пайдаланушы келісімі бетін қосамын деп ойлаймын, бірақ бұл қашан болатыны белгісіз. Дегенмен, сайт ережелері жеткілікті түрде егжей-тегжейлі сипатталған.

Сондай-ақ сайтта https болуы керек деген қатаң талапқа тап болдым. Жалпы, менде Let`s Encrypt сайтынан https бар екенін ескерсек, менде ешқандай проблема болады деп ойламадым, бірақ . белгілі болғандай, әдепкі бойынша django-social-auth HTTP протоколымен қайтару мекенжайын жасайды және HTTPS пайдалану үшін оны параметрлерде көрсету керек.

Енді оның қалай жасалғанын көрейік.


Тіркеу өтінімдері

Аутентификацияны пайдалану үшін қолданбаны тіркеу қажет. Мен қосымшаны жасаудың негізгі мәліметтеріне кірмеймін. Бірақ мен қосымшаның негізгі параметрлерін көрсетемін.

Сіз қолданба идентификаторын және қолданба құпия кілтін аласыз.

Қолданба доменін, сондай-ақ құпиялылық саясатының URL мекенжайын және пайдаланушы келісімінің URL мекенжайын көрсетіңіз.

Содан кейін OAuth арқылы тіркеуді қайта бағыттау үшін url мекенжайын көрсетіңіз.

settings.py

settings.py файлына қажетті параметрлерді қосамыз.

Қолданба идентификаторы мен құпия кілтті орнатыңыз. Сондай-ақ пайдаланушы профилінен не алғымыз келеді. Маған осы кезеңде тек электрондық пошта қажет.

SOCIAL_AUTH_FACEBOOK_KEY = 'XXXXXXXXX'
SOCIAL_AUTH_FACEBOOK_SECRET = 'XXXXXXXXX'
SOCIAL_AUTH_FACEBOOK_SCOPE = ['email']

Сондай-ақ дәл HTTPS қолданғымыз келетінін көрсетіңіз. Әйтпесе, Facebook ант береді.

SOCIAL_AUTH_REDIRECT_IS_HTTPS = True

Аутентификация үшін Backend параметрін көрсетіңіз.

AUTHENTICATION_BACKENDS = (
    ...
    'social_core.backends.facebook.FacebookOAuth2',
    ...
)

Аутентификация үшін URL мекенжайын көрсетіңіз

<a href="{% url 'social:begin' 'facebook' %}">Facebook</a>
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

AlexanderBardin
  • Наурыз 19, 2019, 8:57 Т.Ж.

Добрый день. А проверить работоспособность локально как-то можно не указывая реальнй сайт (еще в разработке)

Evgenii Legotckoi
  • Наурыз 20, 2019, 5:45 Т.Ж.

Добрый день.

Поппробуйте домен localhost, а url соответственно http://localhost

Возможно, потребуется указать порт. Например, так http://localhost:8000

АБ
  • Наурыз 21, 2019, 5:35 Т.Ж.
  • (өңделген)

как быть с такой ошибкой: конечный uri не внесен в белый список в разделе Клиентские настройки OAuth?

Evgenii Legotckoi
  • Наурыз 21, 2019, 5:45 Т.Ж.

FaceBook по умолчанию направляет на https, у вас видимо http протокол. Исправьте протокол в настройках.

АБ
  • Наурыз 21, 2019, 6:06 Т.Ж.

данная строчка у меня есть: SOCIAL_AUTH_REDIRECT_IS_HTTPS = True

АБ
  • Наурыз 21, 2019, 6:07 Т.Ж.

адрес сайта uri перенасправления пишу так: https://мойсайт.site/

АБ
  • Наурыз 21, 2019, 6:17 Т.Ж.

где брать действительный uri перенаправления?

Evgenii Legotckoi
  • Наурыз 21, 2019, 6:46 Т.Ж.

Вы у себя urls прописывали?

urlpatterns = [
    ...
    path('', include('social_django.urls')),
]

В статье по настройке авторизации для ВКонтакте есть базовый мануал .

АБ
  • Наурыз 21, 2019, 7:02 Т.Ж.
  • (өңделген)

Да, конечно VK работает, настраивал по вашему мануалу, а тут прям какойто ступор: https://amadowshop.site/auth/register/

Evgenii Legotckoi
  • Наурыз 21, 2019, 7:04 Т.Ж.
  • (өңделген)

Вы прописывали url в действительные uri перенаправления так?

https://amadowshop.site/complete/facebook/

АБ
  • Наурыз 21, 2019, 7:15 Т.Ж.

прописал, та же ошибка ...(((

Evgenii Legotckoi
  • Наурыз 21, 2019, 7:25 Т.Ж.

ох тыж, как глубоко запихали авторизацию.

У вас по ходу такой url формируется

https://amadowshop.site/auth/verify/vk/oauth2/complete/facebook/

АБ
  • Наурыз 21, 2019, 7:35 Т.Ж.

да, спасибо, этот урл зарабтал, методом перебеора в итоге поймал )))
https://amadowshop.site/auth/verify/vk/oauth2/complete/facebook/

Evgenii Legotckoi
  • Наурыз 21, 2019, 7:38 Т.Ж.

ну я просто глянул у вас страницу авторизации и обнаружил, что вы очень глубоко запихали include('social_django.urls')

А вообще, вот эта часть выглядит некрасиво в вашем url auth/verify/vk/oauth2/ . Наличие упоминания vk там вообще ни к чему

АБ
  • Наурыз 21, 2019, 8:26 Т.Ж.

url подкорректировал, но теперь ошибка и адрес сменился на https://amadowshop.site/auth/verify/login/facebook/

Evgenii Legotckoi
  • Наурыз 21, 2019, 8:47 Т.Ж.

не вижу здесь проблемы, поменяйте url для callback в приложения oauth в социальных сетях

https://amadowshop.site/auth/verify/complete/facebook/

АБ
  • Наурыз 21, 2019, 11 Т.Ж.

а это где? сейчас ошибка в debag такая:
Page not found (404)
Request Method: GET
Request URL: http://amadowshop.site/accounts/profile/

Evgenii Legotckoi
  • Наурыз 21, 2019, 11:49 Т.Ж.

серьезно? Эта ошибка 404 уже даже не относится к данному вопросу.

В каких-то urls в вашем проекте.

Вопросы, которые не относятся непосредственно к статье, задавайте, пожалуйста на форуме . Оффтопы не нужно делать.

Пікірлер

Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
Кіріңіз немесе Тіркеліңіз
Г

C++ - Тест 001. Первая программа и типы данных

  • Нәтиже:66ұпай,
  • Бағалау ұпайлары-1
t

C++ - Тест 001. Первая программа и типы данных

  • Нәтиже:33ұпай,
  • Бағалау ұпайлары-10
t

Qt - Тест 001. Сигналы и слоты

  • Нәтиже:52ұпай,
  • Бағалау ұпайлары-4
Соңғы пікірлер
G
GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
d
dblas5Шілде 5, 2024, 11:02 Т.Ж.
QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssrАқп. 8, 2024, 6:43 Т.Қ.
Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
АК
Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Енді форумда талқылаңыз
Evgenii Legotckoi
Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
F
FynjyШілде 22, 2024, 4:15 Т.Ж.
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
BlinCT
BlinCTМаусым 25, 2024, 1 Т.Ж.
Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
BlinCT
BlinCTМамыр 5, 2024, 5:46 Т.Ж.
Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
Evgenii Legotckoi
Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

Бізді әлеуметтік желілерде бақылаңыз