如何跟踪用户执行的操作,甚至是使用AJAX执行的操作?

如何跟踪用户执行的操作,甚至是使用AJAX执行的操作?,ajax,django,analytics,django-urls,Ajax,Django,Analytics,Django Urls,在我的网站上,我跟踪用户所做的任何操作,一个接一个地查看页面 在某些视图中,我执行一些ajax请求,如: def books_list(request): books_list = Book.objects.filter(published=True).order_by('-timestamp') if request.method == 'POST' and request.is_ajax(): id_book = request.POST.get('id_b

在我的网站上,我跟踪用户所做的任何操作,一个接一个地查看页面

在某些视图中,我执行一些ajax请求,如:

def books_list(request):
    books_list = Book.objects.filter(published=True).order_by('-timestamp')
    if request.method == 'POST' and request.is_ajax():
         id_book = request.POST.get('id_book')
         try:
              book = books_list.get(id=id_book)
              book.delete()
         except Book.DoesNotExist:
              return JsonResponse({'error':True,'msg':'Book not found'})
    render(request,'book/books-list.html',context={'books_list':books_list})
下面是它的外观的快速视图:

*# analytics *
- / # the home page
- /books/ # visits list of books
- /books/ # He deletes a book
- /books/ # back to list of books
正如您所看到的,当用户删除一本书时,跟踪会保持相同的URL/books/显然,我怎样才能拥有它呢

*# analytics *
- / # the home page
- /books/ # visits list of books
- /books/delete # He deletes a book
- /books/ # back to list of books

我是否需要为简单的删除操作创建新的视图/url?

您有两种方法记录用户正在做的事情 它是基于跟踪的目的,只是为了记录日志,还是在您的数据库中,但是第一个可以解析为db no_sql或sql 根据您的业务需求和项目需要,您可以接受这个抽象答案并对其进行优化

第一条路

views.py utils.py views.py 您还可以在管理器本身添加日志记录

class BookManager(models.Manager):
    def delete(self):
        # you logging as mentioned above
        super(BookManager).delete()
class Book(models.Model):
    .....
    ....
    objects = BookManager()

你的答案真的很有帮助,坦率地说,这是项目中应该有的东西!实际上,我想跟踪查看的页面,在我的问题中,你可以看到我看不到当用户用你的答案删除一个对象时,这是可能的,但我想实现我的问题中所示的相同功能,你也可以在对象管理器中跟踪,这样会更有条理,写得更好
def get_client_ip(request):
    """
    to get client ip request
    :param request:
    :return: ip <str>
    """
    x_forwarded_for = request.META.get('HTTP_X_FORWARDED_FOR')
    if x_forwarded_for:
        ip = x_forwarded_for.split(',')[0]
    else:
        ip = request.META.get('REMOTE_ADDR')
    return ip
from django.contrib.admin.models import LogEntry as AbstractLogEntry


class LogEntry(AbstractLogEntry):
    class Meta:
        proxy = True
        app_label = 'data'
        verbose_name_plural = 'Log Entries'
        permissions = (("add_log", "add log entry"),
                       ("delete_log", "delete log entry"),
                       ("change_log", "change log entry"),
                       )

    def __str__(self):
        if self.action_flag == 5:
            return ugettext('Download "%(object)s."') % {'object': self.object_repr}
        if self.action_flag == 4:
            return ugettext('Uploaded "%(object)s."') % {'object': self.object_repr}
        elif self.is_addition():
            return ugettext('Added "%(object)s".') % {'object': self.object_repr}
        elif self.is_change():
            return ugettext('Changed "%(object)s" - %(changes)s') % {
                'object': self.object_repr,
                'changes': self.change_message,
            }
        elif self.is_deletion():
            return ugettext('Deleted "%(object)s."') % {'object': self.object_repr}
def books_list(request):
books_list = Book.objects.filter(published=True).order_by('-timestamp')
if request.method == 'POST' and request.is_ajax():
     id_book = request.POST.get('id_book')
     try:
          book = books_list.get(id=id_book)

          book.delete()
          LogEntry.objects.log_action(user_id=request.user.id,
                                        change_message='Upload %s for category %s' % (
                                            book.filename(), book.category),
                                        content_type_id=ContentType.objects.get(model__exact='book').id,
                                        object_id=book.id,
                                        object_repr=request.user.username,
                                        action_flag=4
                                        )

     except Book.DoesNotExist:
          return JsonResponse({'error':True,'msg':'Book not found'})
render(request,'book/books-list.html',context={'books_list':books_list})
class BookManager(models.Manager):
    def delete(self):
        # you logging as mentioned above
        super(BookManager).delete()
class Book(models.Model):
    .....
    ....
    objects = BookManager()