溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

python代碼的加密方法

發(fā)布時(shí)間:2020-07-02 10:30:38 來源:億速云 閱讀:211 作者:清晨 欄目:編程語言

不懂python代碼的加密方法?其實(shí)想解決這個(gè)問題也不難,下面讓小編帶著大家一起學(xué)習(xí)怎么去解決,希望大家閱讀完這篇文章后大所收獲。

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

python學(xué)習(xí)網(wǎng),大量的免費(fèi)python視頻教程,歡迎在線學(xué)習(xí)!

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

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

第一種

Python解釋器在執(zhí)行代碼的過程中,會首先生成.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)庫就提供了一個(gè)名叫compileall的庫,使用它就可以做到。

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

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

$ find <src> -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*

第二種

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

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

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

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

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

第三種

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

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

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

第四種

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

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

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

第五種

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

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

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

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

python代碼的加密方法

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

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

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享python代碼的加密方法內(nèi)容對大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,遇到問題就找億速云,詳細(xì)的解決方法等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI