У меня есть расширение Chrome, которое должно отслеживать события вкладок для целей разработки.
Затем сервисный работник отправляет строку json.stringified, встроенную в http, в адрес PHP-код сервера, который записывает эти события в файл для немедленного чтения с помощью PhpStorm.
В браузере я могу выполнить пошаговую отладку сервисного работника, и
все работает хорошо, пока выделенное событие не создаст строку, которую strigify не может handle:
"{"name":"highlighted","payload":{"tabIds":[1875383020],"windowId":1875382695}}"
Следующий момент, когда я могу отслеживать строку, — это отладчик php сервера, который сообщает:
{"name":"highlighted","payload":{"tabIds": => Массив
Извините. Ранее я говорил, что stringify тормозит. Это неверно.
Что я имею в виду, мне нужно расширить функциональность stringify (посредством вспомогательной функции), чтобы преобразовать строку для http GET, а затем преобразовать ее обратно на принимающей стороне.Stringify работает должным образом, но квадратные скобки мешают HTTP GET, и полученный запрос на конце PHP обрезается.
Интересно, почему http GET это не нравится?
Как бы вы сформулировали Вспомогательная функция сервисного работника расширения Chrome, чтобы помочь JSON.stringify работать для HTTP-запроса GET для указанной выше строки, содержащей квадратные скобки внутри вложенного объекта?
Как вы теперь видите, это должно произойти в сервисном работнике расширения Chrome. JSON.stringify делает это с учетом хорошей строки json, но HTTP GET это не нравится.
Поэтому я хочу использовать GET здесь, а затем я должен сформулировать эту строку так, чтобы
она все еще содержала все основные поля когда оно поступает в php.
Теперь оно обрезается сразу по первой квадратной скобке.
Это начальный прослушиватель событий:
Код: Выделить всё
function handleHighlight(highlightInfo){
handleEvent("highlighted",highlightInfo);
}
chrome.tabs.onHighlighted.addListener(handleHighlight);
Это точка останова в сервисном работнике, где строка создается для GET.

Вот как бывает закодировано:

Код: Выделить всё
function handleEvent(name, payload) {
var load = JSON.stringify({name, payload})
const encoded = encodeURI(load);
fetch('http://localhost:80/tabs_report/tabs_query_report.php?'+load);
}

< /p>
И PHP выглядит (с наложением отладки) следующим образом:

И ПОЛУЧИТЬ и ЗАПРОСИТЬ:
Интересно, как вся информация содержится в $_SERVER, но она теряется при GET и ЗАПРОС.
Подробнее здесь: https://stackoverflow.com/questions/792 ... r-http-get