一展东、背景
1.1 背景:
- app訪問接口返回data數(shù)據(jù)進行了加密處理,測試抓包后不能直接查看結(jié)果属百,每次輸入加密內(nèi)容到IDE查看結(jié)果茬末,影響效率
1.2 解決方案:
- 使用python實現(xiàn)加解密,django搭建web實現(xiàn)網(wǎng)頁可訪問慢叨。實現(xiàn)輸入加密內(nèi)容纽匙、salt點擊解密可以直接查看解密后數(shù)據(jù)
- 后續(xù)考慮輸入接口地址和請求參數(shù),返回響應(yīng)結(jié)果拍谐。(可考慮增加一欄直接顯示解密之后的內(nèi)容)
1.3 實現(xiàn)步驟:
- 研究django web知識烛缔,參考慕課網(wǎng)免費視頻三小時帶你入門Django框架
- 課程筆記:三小時帶你入門Django框架筆記
- 使用python實現(xiàn)數(shù)據(jù)的加解密
- 搭建web解密實現(xiàn)輸入加密內(nèi)容、salt輸出解密內(nèi)容
最終實現(xiàn)效果如下:
二轩拨、模擬功能實現(xiàn)
2.1 開發(fā)環(huán)境
- pycharm
- Anaconda3
2.2 代碼實現(xiàn)
2.2.1 環(huán)境搭建
- 環(huán)境搭建參考:三小時帶你入門Django框架第一節(jié)
- 創(chuàng)建并使用虛擬環(huán)境
conda create -n testbench python=3
激活當(dāng)前環(huán)境
source activate
source deactivate
必須先進行一二步驟才可以激活環(huán)境
conda activate testbench
- 安裝django依賴
pip install -i https://pypi.douban.com/simple/ django==2.0
- 創(chuàng)建項目
cd code/python # 1. 自己創(chuàng)建的python項目目錄
django-admin startproject testbench # 2. 創(chuàng)建Django項目指令
cd testbench
python manage.py startapp decryption # 3.創(chuàng)建Django應(yīng)用指令
- 使用pycharm打開該項目
2.2.2 編碼階段
- decryption下新建templates/decryption/decryption.html
使用bootcss實現(xiàn)
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>app接口數(shù)據(jù)加解密</title>
<style>
body {
text-align: center
}
</style>
<!-- 最新版本的 Bootstrap 核心 CSS 文件 -->
<link rel="stylesheet"
integrity="sha384-BVYiiSIFeK1dGmJRAkycuHAHRg32OmUcww7on3RYdg4Va+PmSTsz/K68vbdEjh4u" crossorigin="anonymous">
<!-- 最新的 Bootstrap 核心 JavaScript 文件 -->
<script src="https://cdn.jsdelivr.net/npm/bootstrap@3.3.7/dist/js/bootstrap.min.js"
integrity="sha384-Tc5IQib027qvyjSMfHjOMaLkfuWVxZxUPnCJA7l2mCWNIpG9mGCD8wGNIcPD7Txa"
crossorigin="anonymous"></script>
</head>
<body>
<div class="container page-header">
<h1>app接口數(shù)據(jù)加解密</h1>
</div>
<div class="container body-main">
<form action="/decryption/decrypt" method="post">
{% csrf_token %}
<div class="row">
<div class="col-lg-9">
<div class="input-group">
<span class="input-group-addon" id="basic-addon1">文本</span>
<input id="input_data" type="text" class="form-control" placeholder="plain text"
aria-describedby="basic-addon1" name="input_text" value="{{ input_text }}">
</div><!-- /input-group -->
</div><!-- /.col-lg-6 -->
<div class="col-lg-3">
<div class="input-group">
<span class="input-group-addon" id="basic-addon1">鹽值</span>
<input id="input_salt" type="text" class="form-control" placeholder="salt"
aria-describedby="basic-addon1" name="salt" value="{{ salt }}">
</span>
</div><!-- /input-group -->
</div><!-- /.col-lg-6 -->
</div><!-- /.row -->
<br>
<br>
<br>
<br>
<button type="submit" class="btn btn-success" style="width: 100px">解密</button>
<button type="submit" class="btn btn-danger" style="width: 100px; margin-left: 10px"
formaction="/decryption/encrypt">加密
</button>
</form>
<br>
<br>
<br>
<br>
<div class="input-group">
<span class="input-group-addon" id="basic-addon1">結(jié)果</span>
<textarea id="result" rows="10" type="text" class="form-control" placeholder="result"
aria-describedby="basic-addon1">{{ result }}</textarea>
</div><!-- /input-group -->
</div>
</body>
</html>
- 應(yīng)用編輯視圖decryption/views.py践瓷,實際加解密邏輯根據(jù)自己項目來,這里只是模擬
from django.shortcuts import render
# Create your views here.
# 3des ecb 加密
def triple_desc_ecb_encrypt(request):
if request.method == 'POST':
input_text = request.POST.get('input_text', '')
salt = request.POST.get('salt', '')
# result = encrypt_3des_ecb(input_text, salt)
result = "加密" + input_text + salt # 模擬加密
return render(request, "decryption/decryption.html", {
'input_text': input_text,
'salt': salt,
'result': result
})
else:
return render(request, "decryption/decryption.html")
# 3des ecb 解密
def triple_desc_ecb_decrypt(request):
if request.method == 'POST':
input_text = request.POST.get('input_text', '')
salt = request.POST.get('salt', '')
print("input_text = ", input_text)
print("salt = ", salt)
# result = decrypt_3des_ecb(input_text, salt)
result = "解密" + input_text + salt # 模擬解密
return render(request, "decryption/decryption.html", {
'input_text': input_text,
'salt': salt,
'result': result
})
else:
return render(request, "decryption/decryption.html")
- 應(yīng)用編輯路由decryption/urls.py
from django.urls import path
import decryption.views
urlpatterns = [
path("", decryption.views.triple_desc_ecb_encrypt),
path("encrypt", decryption.views.triple_desc_ecb_encrypt),
path("decrypt", decryption.views.triple_desc_ecb_decrypt)
]
- 項目編輯路由testbench/urls.py
from django.contrib import admin
from django.urls import path, include
urlpatterns = [
path('admin/', admin.site.urls),
path('decryption/', include('decryption.urls')), # add this line
]
- 項目安裝應(yīng)用testbench/settings.py
INSTALLED_APPS = [
'django.contrib.admin',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
# myapp decryption
'decryption.apps.DecryptionConfig' # add this line
]
- 點擊IDE的運行按鈕
- 訪問http://127.0.0.1:8000/decryption/
三亡蓉、部署到linux服務(wù)器
3.1 部署環(huán)境
3.1.1 連接linux服務(wù)器
mac打開終端右鍵 -> 新建遠(yuǎn)程連接 -> ssh連接linux服務(wù)器
3.1.2 linux安裝Anaconda3
- 拷貝Anaconda3-2020.11-Linux-x86_64.sh
scp Anaconda3-2020.11-Linux-x86_64.sh root@serverip:/
- 添加anaconda3到環(huán)境變量
vim /etc/profile
#Anaconda
export PATH=$PATH:/root/anaconda3/bin
source /etc/profile
- 驗證anaconda3安裝成功
conda --version
3.1.3 使用anaconda3
- 拷貝代碼到linux根目錄
scp -r testbench root@serverip:/
- 創(chuàng)建testbench虛擬環(huán)境
conda create -n testbench python=3
- 激活當(dāng)前環(huán)境
source activatesource
deactivate
conda activate testbench
說明:必須先進行一二步驟才可以激活環(huán)境
- 安裝依賴
pip install -i https://pypi.douban.com/simple/django==2.0
pip install -i https://pypi.douban.com/simple/pyDes
3.1.4 部署django
- 添加ip可訪問
vim testbench/settings.py
把服務(wù)器ip添加進 ALLOW_HOST字段
- 啟動服務(wù)
python manage.py runserver serverip:8888 # 前臺啟動服務(wù)
nohup python manage.py runserver serverip:8888& # 后臺啟動服務(wù)
說明:
- 一定要寫ip晕翠,默認(rèn)127.0.01只能自己訪問,局域網(wǎng)無法訪問
- 前端啟動服務(wù)關(guān)閉服務(wù)器窗口砍濒,服務(wù)也會停止淋肾,建議后臺啟動服務(wù)
四、待辦事項
- 輸入結(jié)果json格式化
- 權(quán)限訪問控制(登錄賬號才可以訪問)
- 模擬接口訪問(直接測試app接口)