Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: oauth, authorization, security

Как работает авторизация через OAuth?

Этот вопрос проверяет понимание протокола OAuth, который позволяет приложениям получать ограниченный доступ к данным пользователя без передачи пароля.

Короткий ответ

OAuth позволяет пользователю дать доступ к своим данным на другом сервисе (например, Google) без раскрытия пароля. Приложение получает токен доступа, который можно использовать для запросов от имени пользователя. Процесс включает в себя перенаправление на сервис авторизации и получение токена.

Длинный ответ

1. Основные участники OAuth

  • Клиент (Client) — приложение, запрашивающее доступ (например, сайт).

  • Ресурсный сервер (Resource Server) — сервис с данными пользователя (Google, GitHub).

  • Сервер авторизации (Authorization Server) — выдаёт токены.

  • Владелец ресурса (Resource Owner) — пользователь.

2. Типичный сценарий (Authorization Code Flow)

  1. Перенаправление
    Клиент отправляет пользователя на сервер авторизации с параметрами:

    • client_id (идентификатор приложения)

    • redirect_uri (куда вернуть код)

    • scope (запрашиваемые права)

  2. Согласие пользователя
    Пользователь входит в аккаунт и разрешает доступ.

  3. Получение кода
    Сервер авторизации перенаправляет обратно с code в URL.

  4. Обмен кода на токен
    Клиент отправляет code + client_secret на сервер и получает:

    • access_token (для доступа к API)

    • refresh_token (для обновления токена)

3. Пример запроса на обмен кода

POST /token HTTP/1.1
Host: oauth-server.com
Content-Type: application/x-www-form-urlencoded

grant_type=authorization_code
&code=AUTH_CODE
&redirect_uri=https://client.com/callback
&client_id=CLIENT_ID
&client_secret=CLIENT_SECRET

Когда использовать:

  • Вход через соцсети (Google, Facebook).

  • Доступ к API (GitHub, Twitter).

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    2

  • Сложность:

    6

Навыки

  • Golang

    Golang

Ключевые слова

#oauth

#authorization

#security

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.