Как сделать статус онлайн оффлайн js
В моей базе данных я вставил столбец с именем "онлайн" со значением по умолчанию 0. Поэтому, когда пользовательский логин в этом значении обновляется до 1, теперь он говорит, что пользователь онлайн. Когда пользователь нажимает кнопку "Выйти", это значение снова обновляется до 0, так что теперь пользователь находится в автономном режиме. Но я думал, что если пользователь просто закроет браузер, не выйдя из системы, ничего не будет обновлено, и пользователь останется в сети. Можете ли вы помочь с руководством, как я могу решить это? Есть ли способ сделать это с Javascript или JQuery Ajax, который обнаруживает, когда браузер закрыт?
1 ответ
Ты можешь использовать onbeforeunload но это может оказаться противоречивым.
Может ли выполнение Javascript быть онлайн или офлайн? Я читал об общей безопасности. И я думаю, если приложение находится в автономном режиме, например, в моем случае формы, которая генерирует PDF. Зачем мне использовать сценарий онлайн? Можно ли использовать статус браузера для настройки скрипта?
Ссылка
Я ЧИТАЮ
Поставщики браузеров не могут договориться о том, как определить автономный режим. Некоторые браузеры имеют функцию "Работа в автономном режиме", которую они рассматривают отдельно от отсутствия доступа к сети, что опять-таки отличается от доступа в Интернет. Все это беспорядок. Некоторые поставщики браузеров обновляют флаг navigator.onLine, когда фактический доступ к сети теряется, другие - нет.
Возвращает false, если пользовательский агент определенно находится в автономном режиме (отключен от сети). Возвращает true, если пользовательский агент может быть в сети.
События онлайн и оффлайн запускаются, когда значение этого атрибута изменяется.
Атрибут navigator.onLine должен возвращать false, если пользовательский агент не будет связываться с сетью, когда пользователь переходит по ссылкам или когда скрипт запрашивает удаленную страницу (или знает, что такая попытка потерпит неудачу), и должен возвращать true в противном случае.
Наконец, спецификация отмечает:
Этот атрибут по своей сути ненадежен. Компьютер может быть подключен к сети без доступа к Интернету.
пример
Описание: Что происходит в каждом случае? Скрипт работает только онлайн или офлайн?
Я хотел бы изменить поведение скрипта, чтобы разрешить его запуск только в локальной сети! Цель: я думаю, что это будет больше безопасности.
Пример 1
Случай 1 1. Когда я открываю страницу с этим после этого в Интернете, если я не подключен к Интернету, ничего не происходит. Они не открываются, потому что ссылка удаленная. Правильно?
Пример 2
Случай 1 2. Если у меня есть ссылка, прямая ссылка: - Открывает и работает .css,.js! Правильно?
Безопасность 1. У меня есть сервер, и у него есть форма. 2. Форма ничего не отправляет на сервер. 3. Весь код работает на стороне клиента. 4. Сервер только отображает эту страницу. 5. Если кто-то "злонамеренный" доступ к этой странице.
Случаи а. Этот человек может "изменить страницу". Примечание 1: "Поставьте ссылку напрямую, а не удаленно. По возможности читайте о сбоях и ошибках. "
Из примера 1
Для примера 2
-
Примечание 2: если Javascript всегда работает на стороне клиента. Почему у него нет политики безопасности для возврата этого выполнения в клиентскую локальную сеть "localhost"?
Случаи а. Возможно, то, что делает javascript "небезопасным", заключается в том, что у него нет политики безопасности, чтобы возвращать свое выполнение на самом локальном хосте на стороне клиента локального хоста.
б. Успокойся, я не говорю, что так должно быть на 100%. Я думаю о том, чтобы включить определенную конфигурацию для приложений, которые не нуждаются в подключении. Эти приложения выглядели бы лучше без подключения к сети. Например, определенные игры. Это такие игры, которые не нужно выходить в интернет. И в этом случае они остаются, поэтому они "уязвимы".
Мое мышление таково:
Описание: если приложение находится в сети, оно будет возвращено на локальный хост. Если приложение находится в автономном режиме, оно также будет возвращено localhost. Где безопасность? Мы не позволим любому злоумышленнику обрабатывать JavaScript. В этом случае, по той причине, что сам javascript возвращается в вашу локальную сеть.
Мое мышление не так? Не могли бы вы мне сказать? Где я могу прочитать больше об этом?
Всё, что может пойти не так, пойдёт не так.
Об этом помнят, когда красиво оформляют страницу 404. У разработчиков нет цели показать её пользователям намеренно. Просто они понимают, что, несмотря ни на что, кто-нибудь когда-нибудь на неё попадёт.
Но бывает так, что ваша красиво свёрстанная страница 404 бесполезна. Что, если случатся перебои в работе сервера? А что, если у пользователя пропадёт сеть? Всё это может произойти и обязательно произойдёт. Почему бы не позабавить пользователя во время этих событий?
Для этого можно использовать технологию Service Worker, которая поможет пойти против закона Мёрфи в случае сбоя сети или сервера. После установки worker сможет перехватывать любые запросы к вашему домену. Если что-то пойдёт не так с запросом (что неизбежно), то можно предоставить браузеру инструкции на этот случай. Service Worker — это возможность обернуть серверный негатив в небольшой браузерный позитив. Если у вас страница 404 уже красиво оформлена, то почему бы не добавить к ней не менее привлекательную офлайн-страницу?
Сделайте офлайн-страницу
Также не забудьте поместить офлайн-страницу на подходящий URL, например, /offline.html
Позаботьтесь о предварительном кешировании офлайн-страницы
Создайте файл serviceworker.js . Этот файл будет содержать сценарий, к которому браузер будет обращаться при срабатывании определённых событий. Первое из них, которое нужно обработать — действия, когда service worker установлен на устройстве пользователя. Когда это происходит, событие install удаляется. Вы можете обработать это событие с помощью метода addEventListener() :
Убедитесь, что ваша офлайн-страница сохраняется в кеше. Можете использовать Cache API для сохранения. Можете сохранить сколько угодно страниц и назвать их как захочется. В этом примере назовём закешированную страницу Johny, так в коде на неё можно ссылаться используя JohnyCache :
Скорее всего ваша офлайн-страница связана с CSS-файлом, а также, вероятно, с парой картинок или даже с JavaScript-файлами. Это всё можно закешировать.
Убедитесь, что все URL-адреса верны. Если хотя бы один из URL’ов не будет получен, то все остальные элементы не закешируются.
Перехват запросов
Следующее событие для обработки — fetch . Это, вероятно, наиболее сильная и в то же время страшная функция service worker’а. После установки fetch worker прячется на устройстве пользователя, ожидая появления любых запросов на ваш сайт. Каждый раз, когда пользователь запрашивает веб-страницу, CSS-файл или изображение, будет срабатывать fetch . Вы можете предопределить обработку этого события:
Напишем довольно консервативный скрипт со следующей логикой:
- запрос файла;
- попытка извлечь его из сети;
- если не сработало, попробовать найти в кеше,
- если не сработало и это был запрос веб-страницы, то…
- покажите оффлайн-страницу.
Вот как это выглядит в JavaScript:
Подключение сценария service worker’а
Вы можете добавить сценарий worker’а в файл /serviceworker.js , но всё равно нужно указать браузеру, где этот сценарий искать. Это делается с помощью JavaScript. Поместите следующие строчки кода в уже существующий JS-файл, который вызываете на каждой странице сайта, или просто добавьте их через тег script в конце HTML каждой страницы.
Это сообщает браузеру о начале установки service worker’а, но предварительно убедившись, что браузер понимает, о чём идёт речь. Не забывайте отлавливать исключения.
Вероятно, у вас есть несколько JS-файлов в папке /assets/js/ , куда вы хотели бы добавить и serviceworker.js . Не делайте этого. В таком случае worker сможет обрабатывать запросы, сформированные только для файлов в папке /assets/js/ . Поместите скрипт в корневой каталог, так можете быть уверены, что любой запрос будет перехвачен.
Что дальше?
Вы можете сделать многое другое с worker’ами. Что, если каждый раз, когда вызывается страница, она могла бы потом сохраняться копией в кеше? Затем, когда пользователь перейдёт на неё, находясь не в сети, вы сможете ему её показать.
Или что, если вместо того, чтобы обратиться к серверу, вы проверили бы наличие файла в кеше. Можно выводить кешированную версию, которая явно быстрее и при этом обновлять её в фоновом режиме. Это может быть хорошим вариантом для сайта с изображениями.
Вариантов много, поэтому сложность заключается не в написании кода, а в определении алгоритма. Когда вы проработаете алгоритм, то можете спокойно переводить его в код на JavaScript.
Как сделать так, чтобы пользователь смог использовать ваш сайт, даже если пропало интернет подключение или его вообще нет? Сегодня мы об этом и поговорим.
Для чего это нужно?
Ваши пользователи больше не используют свои десктопные компьютеры, подключенные по проводам к интернету. Они посещают ваш сайт с телефона в лифте, с планшета в метро или с ноутбука, пока тесно сидят на месте 25E.
Именно по этому современные браузеры поддерживают ServiceWorkers, новую технологию, которая позволяет вам предоставлять пользователям доступ к вашему сайту, даже если они не в сети.
UpUp - это бесплатный, open source проект, который позволяет использовать эту современную магию всего лишь вызовом одной команды.
UpUp.start( 'content-url': 'offline.html' // покажет эту страницу пользователям не в сети
>);
Как это работает?
UpUp использует ServiceWorkers для определения потери соединения. ServiceWorkers - это специальный скрипт, который работает в браузере в фоновом режиме и может следить за статусом сети.
Когда пользователь посещает ваш сайт в первый раз, UpUp регистрирует ServiceWorker с вашим браузером и дает ему список файлов, которые нужно закэшировать.
Следующий раз, когда пользователь посещает ваш сайт, ServiceWorker слушает сеть на наличие ошибок. Если соединение потеряно, и ServiceWorker найдет нужные файлы в кеше, то он вернет их также, как если бы они пришли из сети.
Итак, сегодня мы рассмотрели очень интересную технологию, которой, думаю, вы сможете найти применение. Спасибо за внимание!
Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления
Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.
Порекомендуйте эту статью друзьям:
Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):
Она выглядит вот так:
Комментарии ( 3 ):
Полезная статья ребята
Здравствуйте Михаил не могли бы вы написать статью на тему WebRTC видео конференции т.д думаю многим будет интерестно спасибо
Возьмём на заметку! Спасибо!
Читайте также: