Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
gjl2004yn
jumpserver
提交
66f37061
J
jumpserver
项目概览
gjl2004yn
/
jumpserver
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
jumpserver
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
66f37061
编写于
6月 11, 2020
作者:
baltery
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
feat: 添加aes fix: 修改时区的bug
上级
4695f801
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
58 addition
and
4 deletion
+58
-4
apps/common/utils/encode.py
apps/common/utils/encode.py
+51
-0
apps/jumpserver/middleware.py
apps/jumpserver/middleware.py
+7
-4
未找到文件。
apps/common/utils/encode.py
浏览文件 @
66f37061
...
...
@@ -9,6 +9,7 @@ import time
import
hashlib
from
io
import
StringIO
from
itertools
import
chain
from
Crypto.Cipher
import
AES
import
paramiko
import
sshpubkeys
...
...
@@ -225,3 +226,53 @@ def model_to_json(instance, sort_keys=True, indent=2, cls=None):
if
cls
is
None
:
cls
=
DjangoJSONEncoder
return
json
.
dumps
(
data
,
sort_keys
=
sort_keys
,
indent
=
indent
,
cls
=
cls
)
class
AESCrypto
:
"""
AES
除了MODE_SIV模式key长度为:32, 48, or 64,
其余key长度为16, 24 or 32
详细见AES内部文档
CBC模式传入iv参数
本例使用常用的ECB模式
"""
def
__init__
(
self
,
key
):
if
len
(
key
)
>
32
:
key
=
key
[:
32
]
self
.
key
=
self
.
to_16
(
key
)
@
staticmethod
def
to_16
(
key
):
"""
转为16倍数的bytes数据
:param key:
:return:
"""
key
=
bytes
(
key
,
encoding
=
"utf8"
)
while
len
(
key
)
%
16
!=
0
:
key
+=
b
'
\0
'
return
key
# 返回bytes
def
aes
(
self
):
return
AES
.
new
(
self
.
key
,
AES
.
MODE_ECB
)
# 初始化加密器
def
encrypt
(
self
,
text
):
aes
=
self
.
aes
()
return
str
(
base64
.
encodebytes
(
aes
.
encrypt
(
self
.
to_16
(
text
))),
encoding
=
'utf8'
).
replace
(
'
\n
'
,
''
)
# 加密
def
decrypt
(
self
,
text
):
aes
=
self
.
aes
()
return
str
(
aes
.
decrypt
(
base64
.
decodebytes
(
bytes
(
text
,
encoding
=
'utf8'
))).
rstrip
(
b
'
\0
'
).
decode
(
"utf8"
))
# 解密
def
get_aes_crypto
(
key
=
None
):
if
key
is
None
:
key
=
settings
.
SECRET_KEY
a
=
AESCrypto
(
key
)
return
a
aes
=
get_aes_crypto
()
apps/jumpserver/middleware.py
浏览文件 @
66f37061
...
...
@@ -16,10 +16,13 @@ class TimezoneMiddleware:
def
__call__
(
self
,
request
):
tzname
=
request
.
META
.
get
(
'HTTP_X_TZ'
)
if
tzname
:
timezone
.
activate
(
pytz
.
timezone
(
tzname
))
else
:
timezone
.
deactivate
()
if
not
tzname
or
tzname
==
'undefined'
:
return
self
.
get_response
(
request
)
try
:
tz
=
pytz
.
timezone
(
tzname
)
timezone
.
activate
(
tz
)
except
pytz
.
UnknownTimeZoneError
:
pass
response
=
self
.
get_response
(
request
)
return
response
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录