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 в вашем проекте.

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

Пікірлер

Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
Кіріңіз немесе Тіркеліңіз
OI
  • Ora Iro
  • Жел. 24, 2024, 6:38 Т.Ж.

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

  • Нәтиже:40ұпай,
  • Бағалау ұпайлары-8
AD

C++ - Тест 004. Указатели, Массивы и Циклы

  • Нәтиже:50ұпай,
  • Бағалау ұпайлары-4
m
  • molni99
  • Қаз. 26, 2024, 1:37 Т.Ж.

C++ - Тест 004. Указатели, Массивы и Циклы

  • Нәтиже:80ұпай,
  • Бағалау ұпайлары4
Соңғы пікірлер
ИМ
Игорь МаксимовҚар. 22, 2024, 11:51 Т.Ж.
Django - Оқулық 017. Теңшелген Django кіру беті Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii LegotckoiҚаз. 31, 2024, 2:37 Т.Қ.
Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZEҚаз. 19, 2024, 8:19 Т.Ж.
Qt Creator көмегімен fb3 файл оқу құралы Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь МаксимовҚаз. 5, 2024, 7:51 Т.Ж.
Django - Сабақ 064. Python Markdown кеңейтімін қалай жазуға болады Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas5Шілде 5, 2024, 11:02 Т.Ж.
QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Енді форумда талқылаңыз
Evgenii Legotckoi
Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
t
tonypeachey1Қар. 15, 2024, 6:04 Т.Ж.
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
NSProject
NSProjectМаусым 4, 2022, 3:49 Т.Ж.
Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
9
9AnonimҚаз. 25, 2024, 9:10 Т.Ж.
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

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