• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Sanityzacja po stronie servera - Node.js z socket.io

42 Warsaw Coding Academy
0 głosów
606 wizyt
pytanie zadane 31 maja 2020 w JavaScript przez boneoflive Użytkownik (930 p.)

Witam, pisze chat al'a grę, mam problem odpowiednią sanityzacją.

 

Na ten moment to wygląda tak:

1. Server z wiadomości kasuje wszelkie tagi i inne niebezpieczne rzeczy (bez kodowania encji).

2. Jako iż jest to gra, wiadomość zostaje odpowiednio zmodyfikowana,

np. litera a zostaje zamieniona na b.

Gwiazdki * zostają zamienione na tagi [b] i druga na [/b].

3. skrypt po sanityzacji i obróbce zostaje wyslany do klienta i wykonany za pomocą innerHTML.

 

Problem leży w tym że do sanityzacji uzywam skryptu sanitize-html, ktory dosłownie kasuje podejrzane rzeczy, w tym wypadku nie mozna wyslac na chacie nawet serduszka "<3" bo zostaje zatomizowane :(

Zamiast kasować z sanitize-html, próbowalem kodować encje, ale punkt drugi modyfikujący znaki, wpływa także na encje modyfikując je.

Jak poprawnie sanityzować wiadomość nie naruszając jej, aby móc ją w podanym w 2 przykładzie sposób przerobić, nie powodując jej uszkodzenia ani dziur w bezpieczeństwie?

Zaloguj lub zarejestruj się, aby odpowiedzieć na to pytanie.

Podobne pytania

+1 głos
1 odpowiedź 348 wizyt
pytanie zadane 7 stycznia 2022 w PHP przez Avernis Nałogowiec (27,400 p.)
0 głosów
0 odpowiedzi 1,235 wizyt
pytanie zadane 29 marca 2019 w PHP przez MrxCI Dyskutant (8,260 p.)
0 głosów
2 odpowiedzi 2,837 wizyt
pytanie zadane 26 listopada 2016 w PHP przez gipsy222 Nowicjusz (120 p.)

93,377 zapytań

142,380 odpowiedzi

322,532 komentarzy

62,727 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

VMware Cloud PRO - przenieś swoją infrastrukturę IT do chmury
...