django 实现后台系统日志管理

2016-06-29 19:03:49 +08:00
 jiangbingo
python+django 实现后台用户登录 注销 对应模块的增删改操作日志。
请教如何实现?
7279 次点击
所在节点    Python
17 条回复
georgema1982
2016-06-30 05:36:34 +08:00
台用户登录、注销是现成的。但是你说的“对应模块的增删改操作日志”又是什么?
chaegumi
2016-06-30 08:28:25 +08:00
这有啥好说的,就是建个记录表,插入记录数据呗
FingerLiu
2016-06-30 09:36:43 +08:00
捕获所有 model 的 post_save 和 post_delete signal, 然后在 handler 中判断 instance 和 操作类型,然后存入自己建的日志表。 增、改都会触发 post_save, 删会触发 post_delete
jiangbingo
2016-06-30 10:32:18 +08:00
@FingerLiu 想想也是这样,是在 create delete update 等方法加装饰器的方式?
jiangbingo
2016-06-30 10:32:56 +08:00
django 自带的 logging 不知能应用得上不?
FingerLiu
2016-06-30 10:46:16 +08:00
FingerLiu
2016-06-30 10:46:34 +08:00
jiangbingo
2016-06-30 10:59:24 +08:00
@FingerLiu 感谢,正是需要的, django 信号模块可以实现。
xsseroot
2016-06-30 17:23:55 +08:00
你是打算记到数据库中还是文件里?文件可以使用 python 自带的 logging
jiangbingo
2016-07-01 09:43:39 +08:00
@xsseroot 要用表单显示 用户对指定模块的增删改操作。
jiangbingo
2016-07-01 09:45:28 +08:00
上面有朋友提出 django 的 signal 模块,不知道该如何实现?
jiangbingo
2016-07-01 09:47:08 +08:00
@georgema1982 django 做的后台管理系统,是多个表单。需要对各个表单里的 CUD 操作进行记录。
harmy
2016-07-01 09:53:41 +08:00
楼主看看 django-reversion , http://django-reversion.readthedocs.io/en/stable/
jiangbingo
2016-07-01 10:22:01 +08:00
jiangbingo
2016-07-01 16:07:50 +08:00
@chaegumi 模块太多了,在每个操作里写数据库加入操作记录是不是不符合设计原则哟?
jiangbingo
2016-07-04 14:36:25 +08:00
前来回复,解决方案是在每个API里直接写数据库。
wangycc
2016-08-24 17:47:32 +08:00
@jiangbingo 直接写数据库啥意思?能再明白点吗

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/289185

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX