如何跟踪用户执行的操作,甚至是使用AJAX执行的操作?
在我的网站上,我跟踪用户所做的任何操作,一个接一个地查看页面 在某些视图中,我执行一些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
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()