5種方法,加密你的Python代碼 !

Python越來越熱門了,2019年3月TIOBE編程語言排行榜上,Python更是罕見的擊敗了“霸榜三巨頭”之一的C++,擠進(jìn)前三。


Python優(yōu)點(diǎn)很多,比如簡(jiǎn)單易學(xué),代碼量少,能做的事很多等等,和其他語言一樣,Pyhton也有一些不可掩蓋的缺點(diǎn),版本不兼容,運(yùn)行效率不高等等。

其中一個(gè)缺點(diǎn),讓不少開發(fā)者頭疼不已,由于Python解釋器開源的關(guān)系,導(dǎo)致Python代碼無法加密,代碼的安全性得不到保障。

當(dāng)然,想要加密Python代碼,也并非無解。最常見的加密方式有4種,還有1種獨(dú)特的加密方式。

1

Python解釋器在執(zhí)行代碼的過程中,會(huì)首先生成.pyc文件,然后再解釋執(zhí)行.pyc中的內(nèi)容,當(dāng)然,解釋器也能直接執(zhí)行.pyc文件。

.pyc文件是一個(gè)二進(jìn)制的文件,是不具備可讀性的。

假如我們發(fā)到客戶環(huán)境時(shí),是.pyc文件,而不是.py,那么是不是就可以保護(hù)我們的Python代碼?

想要做到這一點(diǎn),并不難。Python標(biāo)準(zhǔn)庫(kù)就提供了一個(gè)名叫compileall的庫(kù),使用它就可以做到。

執(zhí)行如下命令,即可將目錄下的所有.py文件編譯成.pyc文件:

python -m compileall 然后刪除 目錄下所有 .py 文件就可以了。

$ find -name '*.py' -type f -print -exec rm {} ;

這一方法,可以加密我們的Python代碼,勝過代碼裸在外面。尷尬的是,因?yàn)镻ython解釋器的兼容較差,有些版本并不能運(yùn)行.pyc文件。而且已經(jīng)有現(xiàn)成的反編譯工具,可以直接破解。

比如python-uncompyle6(「鏈接」),只要執(zhí)行以下命令,就可以搞定。

$ uncompyle6 *compiled-python-file-pyc-or-pyo*



關(guān)于怎么快速學(xué)python,可以加下小編的python學(xué)習(xí)群:611+530+101,不管你是小白還是大牛,小編我都?xì)g迎,不定期分享干貨

每天晚上20:00都會(huì)開直播給大家分享python學(xué)習(xí)知識(shí)和路線方法,群里會(huì)不定期更新最新的教程和學(xué)習(xí)方法,大家都是學(xué)習(xí)python的,或是轉(zhuǎn)行,或是大學(xué)生,還有工作中想提升自己能力的,如果你是正在學(xué)習(xí)python的小伙伴可以加入學(xué)習(xí)。最后祝所有程序員都能夠走上人生巔峰,讓代碼將夢(mèng)想照進(jìn)現(xiàn)實(shí)


2

代碼混淆,也是一種常見的“加密”方式,嚴(yán)格意義上說,這一方法并不是加密,而是上代碼的可讀性變差。比如刪除注釋,添加毫無意義的注釋,添加無效代碼,對(duì)變量、函數(shù)、類進(jìn)行重命名等。

內(nèi)容不可讀,代碼就受到了保護(hù)。

代碼混淆的工具很多,一個(gè)比較好用的混淆庫(kù)是pyobfuscate(GitHub - astrand/pyobfuscate: pyobfuscate)。這個(gè)庫(kù)可以對(duì)類、函數(shù)進(jìn)行重命名,并且插入無關(guān)的代碼,甚至自動(dòng)加空格等等。

這一方法很簡(jiǎn)單,也提高了破解的門檻。但由于代碼結(jié)構(gòu)未發(fā)生變化,字節(jié)碼也能獲取,破解難度也不高。

一般而言,使用這一方式較為簡(jiǎn)單,實(shí)用。


3

如果有一款工具,可以將Python腳本打包成在某一平臺(tái)的可執(zhí)行文件,最終我們發(fā)行的,是一份打包完成的二進(jìn)制文件,那么程序就更難被破解了?

py2exe(FrontPage - py2exe.orgFrontPage - py2exe.org)就是一款很好的打包工具,可以將Python腳本打包成可在Windows上運(yùn)行的文件。

這一方式的優(yōu)點(diǎn)是進(jìn)一步提高了破解門檻。遺憾的是,你只能在windows上運(yùn)行它。


4

Python運(yùn)行速度慢何解?用Cython就可以帶來性能的提升。實(shí)際上,Cython也可以用來加密Python代碼。

Cython的原理是,將.py編譯為.c文件,再將.c文件編譯為.so或者.pyd,這樣一來,文件就變得難以破解了。

這樣做的好處是,Python代碼很難被破解,缺點(diǎn)是有時(shí)候,Cython可能不支持一小部分代碼,完善起來就比較麻煩了。


5

最后一種方法,做得比較絕。

由于Python是解釋型語言,因此在發(fā)行Python程序的時(shí)候,就必須包含一個(gè)Python解釋器,如果我們修改這個(gè)解釋器,代碼不就被保護(hù)起來了嗎?

如果我們能對(duì)最原始的Python代碼進(jìn)行加密,加密后的代碼被發(fā)行后。哪怕被別人看到了,但因?yàn)椴粫缘盟惴ㄊ窃鯓拥?,就破解不了了?/p>

這是因?yàn)镻ython解釋器本身是一個(gè)二進(jìn)制文件,自然也就無法獲得關(guān)鍵性的數(shù)據(jù),進(jìn)而保護(hù)了源碼。

雖然這一方法最為安全,可操作難度較高。你必須掌握基本的加解密算法,還要探究Python執(zhí)行代碼的方式,從而了解到從什么地方進(jìn)行加解密。最后禁用字節(jié)碼,以防通過.pyc反編譯即可。

以上五種加密方式,有利有弊,有難有易,根據(jù)需求選擇就可以了。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 愛情是一個(gè)漫長(zhǎng)的修行,因?yàn)闀r(shí)間很綿長(zhǎng)、因?yàn)槁吠竞芸部?、因?yàn)轱L(fēng)景的不確定,單說未知的跌宕就足夠讓人觸目驚心了,就更別...
    俗底閱讀 393評(píng)論 0 1
  • 時(shí)間是最好的治療師,也是最差的拯救者。
    帥氣的妳閱讀 209評(píng)論 0 0
  • 文/洛小簡(jiǎn) 這夜色怎么不美了?竟無月光,未聞蟲鳴鳥唱。這失眠一如既往。伊人又何在,誰人在她床? 待到夜深人靜,蛙鳴...
    洛小簡(jiǎn)閱讀 251評(píng)論 0 0
  • 何為成長(zhǎng),那些都是我們所不知道的。有的人說,我們?cè)诔砷L(zhǎng),我們已經(jīng)長(zhǎng)大了。其實(shí)那些都并不是真正的長(zhǎng)大。真正的長(zhǎng)大...
    陌落妃雪閱讀 224評(píng)論 0 0
  • 案例分析:一個(gè)深陷泥濘而無法自拔的人 本尼斯(世界著名的領(lǐng)導(dǎo)學(xué)家)認(rèn)為我們有必要先來看一個(gè)實(shí)例,看看一個(gè)深陷生活的...
    尹一木南閱讀 1,862評(píng)論 1 1

友情鏈接更多精彩內(nèi)容