• Django开发简单采集用户浏览器信息的小功能


    Django开发简单采集用户浏览器信息的小功能

    Centos环境准备

    yum install –y python-pip

    export http_proxy=http://10.11.0.148:808

    export https_proxy=https://10.11.0.148:808

    pip install --upgrade pip

    pip install ipython

    安装django

    Centos7环境

    [root@es01 ~]# pip install Django==1.8.2

    # 创建一个容器

    [root@es01 opt]# cd python/

    [root@es01 python]# ls

    [root@es01 python]# django-admin startproject mydevops

    # 在该容器下创建app

    [root@es01 mydevops]# python manage.py startapp scanhosts

    [root@es01 mydevops]# ls

    manage.py  mydevops  scanhosts

    windows环境

    创建工程和应用

    创建第一个devops工程,采集和获取用户浏览器信息

    功能:记录Http访问ip及用户UA信息

    对于工程的主要配置文件settings.py如果有不清楚的地方可以打印信息

    要想django工程使用到新添加的应用需要修改配置如下:

    # Application definition

    INSTALLED_APPS = (

        'django.contrib.admin',

        'django.contrib.auth',

        'django.contrib.contenttypes',

        'django.contrib.sessions',

        'django.contrib.messages',

        'django.contrib.staticfiles',

           'scanhosts',

    )

    修改数据库链接

    DATABASES = {

        'default': {

            'ENGINE': 'django.db.backends.mysql',

            'NAME': 'mydevops',

            'USER': 'admin',

            'PASSWORD': 'admin',

            'HOST': '127.0.0.1',

            'PORT': '',

            'OPTIONS': {},

            'init_command': 'SET storage_engine=INNODB,'

                            'SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED, autocommit=1, names "utf8";',

        }

    }

    Model模型

    常用数据类型

    定义用户模型

     

    因为用到了中文,需要定义编码为 utf-8

    # -*- coding:utf-8 -*-
    from django.db import models
    
    # Create your models here.
    
    class UserIPInfo(models.Model):
        ip = models.CharField(max_length=40, default='',verbose_name=u'ip地址', null=True)
        time = models.DateTimeField(verbose_name=u"更新时间", auto_now=True)
    
        class Meta:
            verbose_name = u"用户访问地址信息表"
            verbose_name_plural = verbose_name
            db_table = "useripinfo"
    
    class BrowseInfo(models.Model):
        useragent = models.CharField(max_length=100, default='', verbose_name=u'用户浏览器agent信息',null = True)
        models.CharField(max_length=256, verbose_name=u"唯一设备id", default='')
    
        userip = models.ForeignKey("UserIPInfo")
    
        class Meta:
            verbose_name = u'用户浏览器信息'
            verbose_name_plural = verbose_name
            db_table = "browseinfo"

    # 执行迁移

    先安装mysqldb依赖

    pip install mysqlclient==1.3.4

    D:pythonmydevops>python manage.py makemigrations

    转化为sql语句

    D:pythonmydevops>python manage.py migrate

    工程设计

    采集和获取信息接口

    Mydevops/scanhosts/views.py

    from django.shortcuts import render
    
    from django.http import JsonResponse, HttpResponse
    from .models import *
    import json
    
    
    def user_info(request):
        # print ".........",request.META
        ip_addr = request.META['REMOTE_ADDR']
        user_ua = request.META['HTTP_USER_AGENT']
    
        user_obj = UserIPInfo.objects.filter(ip = ip_addr)
        if not user_obj:
            res = UserIPInfo.objects.create(ip = ip_addr)
            ip_add_id = res.id
        else:
            ip_add_id = user_obj[0].id
    
        BrowseInfo.objects.create(useragent=user_ua, userip_id=ip_add_id)
    
        result = {"STATUS":"success",
                  "INFO":"User info",
                  "IP":ip_addr,
                  "UA":user_ua}
    
        return HttpResponse(json.dumps(result), content_type="application/json")
    
    
    def user_history(request):
        ip_lst = UserIPInfo.objects.all()
        infos = {}
        for item in ip_lst:
            infos[item.ip] = [ b_obj.useragent for b_obj in BrowseInfo.objects.filter(userip_id=item.id) ]
    
        result = {"STATUS":"success", "INFO":infos}
    
        return HttpResponse(json.dumps(result), content_type="application/json")

    使用不同的浏览器访问采集接口,可以看到数据库中采集到不同浏览器的信息

    获取信息的接口

  • 相关阅读:
    (29)zabbix执行远程命令
    (28)zabbix用户宏变量详解macro
    CentOS7安装Nginx及配置
    Open-Falcon 监控系统监控 MySQL/Redis/MongoDB 状态监控
    Centos7安装ansible
    Centos7部署open-falcon 0.2
    Centos7安装redis
    vim常用命令
    CentOS7安装配置Bacula yum方法
    CentOS7时间同步
  • 原文地址:https://www.cnblogs.com/reblue520/p/10871227.html
Copyright © 2020-2023  润新知