V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
jiangbingo
V2EX  ›  Python

django 实现后台系统日志管理

  •  1
     
  •   jiangbingo · 2016-06-29 19:03:49 +08:00 · 7240 次点击
    这是一个创建于 2829 天前的主题,其中的信息可能已经有所发展或是发生改变。
    python+django 实现后台用户登录 注销 对应模块的增删改操作日志。
    请教如何实现?
    17 条回复    2016-08-24 17:47:32 +08:00
    georgema1982
        1
    georgema1982  
       2016-06-30 05:36:34 +08:00
    台用户登录、注销是现成的。但是你说的“对应模块的增删改操作日志”又是什么?
    chaegumi
        2
    chaegumi  
       2016-06-30 08:28:25 +08:00
    这有啥好说的,就是建个记录表,插入记录数据呗
    FingerLiu
        3
    FingerLiu  
       2016-06-30 09:36:43 +08:00   ❤️ 2
    捕获所有 model 的 post_save 和 post_delete signal, 然后在 handler 中判断 instance 和 操作类型,然后存入自己建的日志表。 增、改都会触发 post_save, 删会触发 post_delete
    jiangbingo
        4
    jiangbingo  
    OP
       2016-06-30 10:32:18 +08:00
    @FingerLiu 想想也是这样,是在 create delete update 等方法加装饰器的方式?
    jiangbingo
        5
    jiangbingo  
    OP
       2016-06-30 10:32:56 +08:00
    django 自带的 logging 不知能应用得上不?
    FingerLiu
        6
    FingerLiu  
       2016-06-30 10:46:16 +08:00
    jiangbingo
        8
    jiangbingo  
    OP
       2016-06-30 10:59:24 +08:00
    @FingerLiu 感谢,正是需要的, django 信号模块可以实现。
    xsseroot
        9
    xsseroot  
       2016-06-30 17:23:55 +08:00
    你是打算记到数据库中还是文件里?文件可以使用 python 自带的 logging
    jiangbingo
        10
    jiangbingo  
    OP
       2016-07-01 09:43:39 +08:00
    @xsseroot 要用表单显示 用户对指定模块的增删改操作。
    jiangbingo
        11
    jiangbingo  
    OP
       2016-07-01 09:45:28 +08:00
    上面有朋友提出 django 的 signal 模块,不知道该如何实现?
    jiangbingo
        12
    jiangbingo  
    OP
       2016-07-01 09:47:08 +08:00
    @georgema1982 django 做的后台管理系统,是多个表单。需要对各个表单里的 CUD 操作进行记录。
    harmy
        13
    harmy  
       2016-07-01 09:53:41 +08:00 via iPhone
    楼主看看 django-reversion , http://django-reversion.readthedocs.io/en/stable/
    jiangbingo
        14
    jiangbingo  
    OP
       2016-07-01 10:22:01 +08:00
    jiangbingo
        15
    jiangbingo  
    OP
       2016-07-01 16:07:50 +08:00
    @chaegumi 模块太多了,在每个操作里写数据库加入操作记录是不是不符合设计原则哟?
    jiangbingo
        16
    jiangbingo  
    OP
       2016-07-04 14:36:25 +08:00
    前来回复,解决方案是在每个API里直接写数据库。
    wangycc
        17
    wangycc  
       2016-08-24 17:47:32 +08:00
    @jiangbingo 直接写数据库啥意思?能再明白点吗
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1939 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 31ms · UTC 16:24 · PVG 00:24 · LAX 09:24 · JFK 12:24
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.