推荐学习书目
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
0.01D
V2EX  ›  Python

django 实现后台系统日志管理

  •  1
     
  •   jiangbingo · Jun 29, 2016 · 8090 views
    This topic created in 3609 days ago, the information mentioned may be changed or developed.
    python+django 实现后台用户登录 注销 对应模块的增删改操作日志。
    请教如何实现?
    17 replies    2016-08-24 17:47:32 +08:00
    georgema1982
        1
    georgema1982  
       Jun 30, 2016
    台用户登录、注销是现成的。但是你说的“对应模块的增删改操作日志”又是什么?
    chaegumi
        2
    chaegumi  
       Jun 30, 2016
    这有啥好说的,就是建个记录表,插入记录数据呗
    FingerLiu
        3
    FingerLiu  
       Jun 30, 2016   ❤️ 2
    捕获所有 model 的 post_save 和 post_delete signal, 然后在 handler 中判断 instance 和 操作类型,然后存入自己建的日志表。 增、改都会触发 post_save, 删会触发 post_delete
    jiangbingo
        4
    jiangbingo  
    OP
       Jun 30, 2016
    @FingerLiu 想想也是这样,是在 create delete update 等方法加装饰器的方式?
    jiangbingo
        5
    jiangbingo  
    OP
       Jun 30, 2016
    django 自带的 logging 不知能应用得上不?
    jiangbingo
        8
    jiangbingo  
    OP
       Jun 30, 2016
    @FingerLiu 感谢,正是需要的, django 信号模块可以实现。
    xsseroot
        9
    xsseroot  
       Jun 30, 2016
    你是打算记到数据库中还是文件里?文件可以使用 python 自带的 logging
    jiangbingo
        10
    jiangbingo  
    OP
       Jul 1, 2016
    @xsseroot 要用表单显示 用户对指定模块的增删改操作。
    jiangbingo
        11
    jiangbingo  
    OP
       Jul 1, 2016
    上面有朋友提出 django 的 signal 模块,不知道该如何实现?
    jiangbingo
        12
    jiangbingo  
    OP
       Jul 1, 2016
    @georgema1982 django 做的后台管理系统,是多个表单。需要对各个表单里的 CUD 操作进行记录。
    harmy
        13
    harmy  
       Jul 1, 2016 via iPhone
    楼主看看 django-reversion , http://django-reversion.readthedocs.io/en/stable/
    jiangbingo
        14
    jiangbingo  
    OP
       Jul 1, 2016
    jiangbingo
        15
    jiangbingo  
    OP
       Jul 1, 2016
    @chaegumi 模块太多了,在每个操作里写数据库加入操作记录是不是不符合设计原则哟?
    jiangbingo
        16
    jiangbingo  
    OP
       Jul 4, 2016
    前来回复,解决方案是在每个API里直接写数据库。
    wangycc
        17
    wangycc  
       Aug 24, 2016
    @jiangbingo 直接写数据库啥意思?能再明白点吗
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1059 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 41ms · UTC 17:56 · PVG 01:56 · LAX 10:56 · JFK 13:56
    ♥ Do have faith in what you're doing.