Python制作釘釘加密/解密工具
又是很久沒有寫技術博客了,蓋因最近都在學習知識,也沒有總結出什么值得分享的內容,所以一直停筆至今。最近的工作和釘釘?shù)拈_發(fā)打上了交到,官方并沒有提供任何Python的SDK,于是只能全部自己寫。現(xiàn)在我將其中實現(xiàn)起來相對費時間的“加密/解密/簽名”部分分享出來,希望能幫助到一些人。
加密/解密的具體機制,可以參考 官方文檔 。
在你的項目中安裝這個擴展,可以使用: pip install dingtalk_crypto
安裝。
使用方法,可以參考下面的測試代碼:
# -*- coding: utf-8 -*- import json from dingtalk_crypto import DingTalkCrypto # 這個是釘釘官方給的測試數(shù)據(jù) # @see https://open-doc.dingtalk.com/doc2/detail.htm?treeId=175&articleId=104945&docType=1#s14 encrypt_text = '1a3NBxmCFwkCJvfoQ7WhJHB+iX3qHPsc9JbaDznE1i03peOk1LaOQoRz3+nlyGNhwmwJ3vDMG' \ '+OzrHMeiZI7gTRWVdUBmfxjZ8Ej23JVYa9VrYeJ5as7XM/ZpulX8NEQis44w53h1qAgnC3PRzM7Zc' \ '/D6Ibr0rgUathB6zRHP8PYrfgnNOS9PhSBdHlegK+AGGanfwjXuQ9+0pZcy0w9lQ==' crypto = DingTalkCrypto( '4g5j64qlyl3zvetqxz5jiocdr586fn2zvjpa8zls3ij', '123456', 'suite4xxxxxxxxxxxxxxx' ) signature = '5a65ceeef9aab2d149439f82dc191dd6c5cbe2c0' timestamp = '1445827045067' nonce = 'nEXhMP4r' class TestCrypto: def test_decrypt(self): randstr, length, msg, suite_key = crypto.decrypt(encrypt_text) msg = json.loads(msg) assert msg['EventType'] == 'check_create_suite_url' assert msg['Random'] == 'LPIdSnlF' assert suite_key == 'suite4xxxxxxxxxxxxxxx' def test_encode(self): encrypt_msg = crypto.encrypt('hello world') randstr, length, msg, suite_key = crypto.decrypt(encrypt_msg) assert msg == 'hello world' def test_check_signature(self): assert crypto.check_signature(encrypt_text, timestamp, nonce, signature) def test_sign(self): msg = crypto.encrypt('hello world') actual_sig, actual_time, actual_nonce = crypto.sign(msg) assert True
最后,貼出項目的 源碼地址 ,希望能一些交流。
- 在Python中使用M2Crypto模塊實現(xiàn)AES加密的教程
- Python實現(xiàn)對字符串的加密解密方法示例
- python rsa 加密解密
- python實現(xiàn)DES加密解密方法實例詳解
- Python基于DES算法加密解密實例
- python中base64加密解密方法實例分析
- python有證書的加密解密實現(xiàn)方法
- python實現(xiàn)無證書加密解密實例
- python字符串加密解密的三種方法分享(base64 win32com)
- python基于pyDes庫實現(xiàn)des加密的方法
- Python使用Pycrypto庫進行RSA加密的方法詳解
- python實現(xiàn)的AES雙向對稱加密解密與用法分析
相關文章
Python使用xlrd和xlwt實現(xiàn)自動化操作Excel
這篇文章主要介紹了Python使用xlrd和xlwt實現(xiàn)自動化操作Excel,xlwt只能對Excel進行寫操作。xlwt和xlrd不光名字像,連很多函數(shù)和操作格式也是完全相2022-08-08Keras之fit_generator與train_on_batch用法
這篇文章主要介紹了Keras之fit_generator與train_on_batch用法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-06-06Python中表達式x += y和x = x+y 的區(qū)別詳解
這篇文章主要跟大家介紹了關于Python中x += y和x = x+y 的區(qū)別的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-06-06Python開發(fā)寶典CSV JSON數(shù)據(jù)處理技巧詳解
在Python中處理CSV和JSON數(shù)據(jù)時,需要深入了解這兩種數(shù)據(jù)格式的讀取、寫入、處理和轉換方法,下面將詳細介紹如何在Python中處理CSV和JSON數(shù)據(jù),并提供一些示例和最佳實踐2023-11-11Python Django Vue 項目創(chuàng)建過程詳解
這篇文章主要介紹了Python Django Vue 項目創(chuàng)建過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07