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

Obfuskacja kodu Pythona

Object Storage Arubacloud
+1 głos
1,401 wizyt
pytanie zadane 22 marca 2017 w Python przez __new__in__town Bywalec (2,100 p.)
Napisałem mały programik, który zostanie spakowany w exe ze względu na multiplatform. Jednak chciałbym sie dowiedzieć jak można się dodatkowo zabezpieczyć przed ciekawskimi.

Czy jest możliwość ukrycia nazwy użytkownika i hasła w pliku źródłowym, w którym są jakieś dane logowania? Tutaj chodzi zarówno o czysty plik i dodatkową warstwę zabezpieczającą w exe.

1 odpowiedź

+1 głos
odpowiedź 22 marca 2017 przez mokrowski Mędrzec (155,460 p.)
Jesteś pewien że chcesz zaciemniać kod Python'a? py2exe (lub inne podobne projekty) nie wystarczą?

No dobrze.. jeśli jesteś pewien to: https://liftoff.github.io/pyminifier/ Można ew. stosować techniki odszyfrowania w locie po podaniu klucza lub pobrania go z pliku licencji.  Jeszcze innym podejściem jest stosowanie innych interpreterów języka (pypy, IronPython czy Jython) i stosowanie technik obfuskacji dla danych platform (.NET czy JVM).

To nie jest dobry pomysł przetrzymywać hasła i loginy zapisane otwartym tekstem w pliku. Niezbędne minimum to wykonanie z nich odcisków funkcją skrótu i trzymanie w tej postaci.
komentarz 24 marca 2017 przez __new__in__town Bywalec (2,100 p.)
Dzięki. Możesz jednak rozjaśnić ostatnie zdanie? Nie bardzo zrozumiałem.

Co do samego exe, to zapewne zgodzisz się, że jest on słabiutkim zabezpieczeniem. Najlepiej by było się pobawić w assembly, ale to jeszcze nie ten poziom umiejętności. :) Głownie chodzi o zabawe i ciekawość technologi, sam programik nie jest oczywiście warty impletowania DRMa typu Denuvo . :D
komentarz 24 marca 2017 przez mokrowski Mędrzec (155,460 p.)

No cóż.. więc do do obfuskacji bajtkodu python'a baw się :-) 

Co do haseł. Nie trzymaj ich w postaci otwartego tekstu a w postaci funkcji skrótu która będzie weryfikowana na etapie uwierzytelnienia. Ewentualny atak na aplikację skończy się wtedy pozyskaniem danych które trzeba będzie łamać. To jest dla włamywacza bardzo czasochłonne. Hasła przechowuj zakodowane np. z użyciem https://docs.python.org/3.6/library/hashlib.html (sha512 jest wystarczająco dobre). Ziarno możesz uzyskać choćby tak:

import uuid
salt = uuid.uuid4().hex

 

Podobne pytania

0 głosów
0 odpowiedzi 52 wizyt
0 głosów
0 odpowiedzi 85 wizyt
pytanie zadane 19 maja 2020 w Python przez Aqua Obywatel (1,950 p.)
0 głosów
0 odpowiedzi 76 wizyt

92,555 zapytań

141,403 odpowiedzi

319,557 komentarzy

61,940 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.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...