<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
	<id>https://wiki.skripov.com/mediawiki/index.php?action=history&amp;feed=atom&amp;title=Appmaster_%D0%90%D0%B2%D1%82%D0%BE%D1%80%D0%B8%D0%B7%D0%B0%D1%86%D0%B8%D1%8F_%D0%B8_%D0%B0%D1%83%D1%82%D0%B5%D0%BD%D1%82%D0%B8%D1%84%D0%B8%D0%BA%D0%B0%D1%86%D0%B8%D1%8F</id>
	<title>Appmaster Авторизация и аутентификация - История изменений</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.skripov.com/mediawiki/index.php?action=history&amp;feed=atom&amp;title=Appmaster_%D0%90%D0%B2%D1%82%D0%BE%D1%80%D0%B8%D0%B7%D0%B0%D1%86%D0%B8%D1%8F_%D0%B8_%D0%B0%D1%83%D1%82%D0%B5%D0%BD%D1%82%D0%B8%D1%84%D0%B8%D0%BA%D0%B0%D1%86%D0%B8%D1%8F"/>
	<link rel="alternate" type="text/html" href="https://wiki.skripov.com/mediawiki/index.php?title=Appmaster_%D0%90%D0%B2%D1%82%D0%BE%D1%80%D0%B8%D0%B7%D0%B0%D1%86%D0%B8%D1%8F_%D0%B8_%D0%B0%D1%83%D1%82%D0%B5%D0%BD%D1%82%D0%B8%D1%84%D0%B8%D0%BA%D0%B0%D1%86%D0%B8%D1%8F&amp;action=history"/>
	<updated>2026-05-13T12:29:12Z</updated>
	<subtitle>История изменений этой страницы в вики</subtitle>
	<generator>MediaWiki 1.42.1</generator>
	<entry>
		<id>https://wiki.skripov.com/mediawiki/index.php?title=Appmaster_%D0%90%D0%B2%D1%82%D0%BE%D1%80%D0%B8%D0%B7%D0%B0%D1%86%D0%B8%D1%8F_%D0%B8_%D0%B0%D1%83%D1%82%D0%B5%D0%BD%D1%82%D0%B8%D1%84%D0%B8%D0%BA%D0%B0%D1%86%D0%B8%D1%8F&amp;diff=39&amp;oldid=prev</id>
		<title>SergeySkripov: Новая страница: «Для того, чтобы пользователи приложения получали данные которые предназначаются только для них и не могли получить доступ к чужим данным и тем более изменить их нужно удостоверится, что пользователь, который прислал запрос не выдает себя за другого.  &#039;&#039;...»</title>
		<link rel="alternate" type="text/html" href="https://wiki.skripov.com/mediawiki/index.php?title=Appmaster_%D0%90%D0%B2%D1%82%D0%BE%D1%80%D0%B8%D0%B7%D0%B0%D1%86%D0%B8%D1%8F_%D0%B8_%D0%B0%D1%83%D1%82%D0%B5%D0%BD%D1%82%D0%B8%D1%84%D0%B8%D0%BA%D0%B0%D1%86%D0%B8%D1%8F&amp;diff=39&amp;oldid=prev"/>
		<updated>2024-10-18T17:33:21Z</updated>

		<summary type="html">&lt;p&gt;Новая страница: «Для того, чтобы пользователи приложения получали данные которые предназначаются только для них и не могли получить доступ к чужим данным и тем более изменить их нужно удостоверится, что пользователь, который прислал запрос не выдает себя за другого.  &amp;#039;&amp;#039;...»&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Для того, чтобы пользователи приложения получали данные которые предназначаются только для них и не могли получить доступ к чужим данным и тем более изменить их нужно удостоверится, что пользователь, который прислал запрос не выдает себя за другого.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Аутентификация&amp;#039;&amp;#039;&amp;#039; - это процесс который подтверждает пользователя - кто он. Обычно для подтверждения используются логин и пароль, но может быть например код отправленный на телефон или электронную почту.&lt;br /&gt;
&lt;br /&gt;
После того как мы выяснили, что пользователь себя подтвердил, нам надо как-то это запомнить, чтобы при следующих запросах уже не требовать от него логин и пароль, т.е. каждый раз когда пользователь отправляет запрос для сервера он выглядит как анонимный запрос от неизвестного пользователя, даже если он только что уже отправлял его.&lt;br /&gt;
&lt;br /&gt;
Есть много механизмов запомнить пользователя, один из самых простых, после аутентификации выдать пользователю в ответ &amp;quot;талончик&amp;quot; с уникальным кодом, который он будет предъявлять при каждом запросе, а мы будем проверять в базе какому пользователю соответствует код из &amp;quot;талончика&amp;quot; - это называется &amp;quot;токен сессии&amp;quot;.&lt;br /&gt;
&lt;br /&gt;
В чем смысл - логин и пароль имеют не ограниченный срок жизни и если пользователь будет при каждом запросе передавать свой логин и пароль, то увеличиваются шансы на их перехват или утечку. И если кто-то получит к ним доступ, то сможет бесконечно долго ими пользоваться. Вместо этого в БД записывается &amp;quot;сессия&amp;quot; пользователя с уникальным кодом &amp;quot;токеном&amp;quot;, который может быть отозван в любое время и имеет ограниченный срок жизни. Также в сессию можно записать любые дополнительные данные такие как браузер, ip адрес, приложение через которое пользователь зашел или любые другие которые могут быть полезны для работы.&lt;br /&gt;
&lt;br /&gt;
Пример работы таких &amp;quot;сессий&amp;quot; можно увидеть в мессенджерах, соцсетях или банковских приложениях - они показывают с какого устройства кто и когда заходил и позволяют прервать это соединение.&lt;br /&gt;
[[Файл:Appmaster Auth UserSession.png|центр|безрамки|1000x1000пкс]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
В AppMaster есть готовые БП которые помогают зарегистрировать пользователя и аутентифицировать.&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Регистрация&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
На вход БП передаются обязательно логин и пароль, а также имя и фамилия пользователя. Публичный ключ обычно не используется, но повышает безопасность при передаче данных.&lt;br /&gt;
&lt;br /&gt;
На выходе БП мы получаем профиль зарегистрированного пользователя (User) и токен сессии который нужно сохранить на клиентской стороне и использовать для дальнейших запросов.&lt;br /&gt;
[[Файл:Appmaster BP User Sign-up.png|центр|безрамки|1000x1000пкс]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Аутентификация&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Очень похожа на регистрацию выше, но не создает нового пользователя, а проверяет есть ли существующий с таким логином и паролем и если есть то возвращает профиль (User) и токен сессии.&lt;br /&gt;
[[Файл:Appmaster BP User Sign In.png|центр|безрамки|1000x1000пкс]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&amp;#039;&amp;#039;&amp;#039;Выход&amp;#039;&amp;#039;&amp;#039;&lt;br /&gt;
&lt;br /&gt;
Когда пользователь заканчивает работу в приложении или хочет войти под другим пользователем он должен прервать текущую сессию. Для это также есть отдельный БП. Он проверяет, какой пользователь вызвал этот БП, получает текущую сессию и завершает ее.&lt;br /&gt;
[[Файл:Appmaster BP User Logout.png|центр|безрамки|1000x1000пкс]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
По умолчанию вышеописанные БП уже привязаны к своим эндпоинтам и можно их сразу использовать.&lt;br /&gt;
[[Файл:Appmaster Endpoints User Auth.png|центр|безрамки|1000x1000пкс]]&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
Для тестирования можно использовать Swagger консоль в которой можно видеть какие запросы к серверу отправляются.&lt;br /&gt;
[[Категория:Appmaster]]&lt;/div&gt;</summary>
		<author><name>SergeySkripov</name></author>
	</entry>
</feed>