1 DATABASES = { 2 ‘default‘: { 3 ‘ENGINE‘: ‘django.db.backends.mysql‘, 4 ‘NAME‘: ‘netdevops‘, 5 ‘USER‘: ‘forgeek‘, 6 ‘PASSWORD‘: ‘xxxxxx‘, 7 ‘HOST‘: ‘172.16.127.128‘, 8 ‘PORT‘: ‘3306‘, 9 ‘OPTIONS‘: {}, 10 ‘init_command‘: ‘SET storage_engine=INNODB,‘ 11 ‘SESSION TRANSACTION ISOLATION LEVEL READ COMMITTED, autocommit=1, names "utf8";‘, 12 } 13 }
# 创建mysql帐号(这里的帐号信息要与settings配置文件中连接数据库的配置信息保持一致)mysql> alter user ‘forgeek‘@‘%‘ identified with mysql_native_password by ‘xxxx‘;# 设置forgeek帐号密码永不过期
mysql> alter user ‘forgeek‘@‘%‘ identified by ‘xxxx‘ password expire never;# 授权(这里由于测试环境我这边分配权限比较大,大家可以根据自己情况设置)grant all privileges on *.* to ‘forgeek‘@‘%‘;# 刷新权限mysql> flush privileges;
# 验证用户的创建是否成功
mysql> select host,user,authentication_string from mysql.user;# 创建名为netdevops的数据库mysql> create database netdevops;
定义简介:
- 每个模型都是一个python类,它是django.db.models.Model的子类
- 模型的每个属性都代表一个数据库字段
- 综上所述,Django为您提供了一个自动生成的数据库访问API,详细见官方文档。
model与数据库结构对应关系图如下:
这个小功能中我们需要建立两张表,一个保存用户信息另一个保存浏览器信息。考虑到一个用户可能会有多个浏览器,因此需要建立一个一对多的关系。我这里直接贴源码好了,有不懂的直接留言好了。
1 # coding=utf-8 2 from django.db import models 3 4 5 class UserIpInfo(models.Model): 6 ip = models.CharField(max_length=40, default=‘‘, verbose_name=u‘IP地址‘, null=True) 7 time = models.DateTimeField(verbose_name=u‘更新时间‘, auto_now=True) 8 9 class Meta: 10 verbose_name = u"用户访问IP地址表" 11 verbose_name_plural = verbose_name 12 db_table = "useripinfo" 13 14 15 class BrowseInfo(models.Model): 16 useragent = models.CharField(max_length=200, default=‘‘, verbose_name=u‘用户浏览器信息‘, null=True) 17 models.CharField(max_length=256, verbose_name=u‘设备唯一ID‘, default=‘‘) 18 user_ip = models.ForeignKey("UserIpInfo", on_delete=models.CASCADE) 19 20 class Meta: 21 verbose_name = u"用户浏览器信息表" 22 verbose_name_plural = verbose_name 23 db_table = "browseinfo"
1 # from django.shortcuts import render 2 from django.http import HttpResponse 3 from .models import * 4 import json 5 6 7 def user_ip_info(request): 8 # print(‘-----------------test/n‘, request.META) 9 ip_addr = request.META[‘REMOTE_ADDR‘] 10 user_ua = request.META[‘HTTP_USER_AGENT‘] 11 print(len(user_ua)) 12 13 user_obj = UserIpInfo.objects.filter(ip=ip_addr) 14 if not user_obj: 15 res = UserIpInfo.objects.create(ip=ip_addr) 16 ip_addr_id = res.id 17 else: 18 ip_addr_id = user_obj[0].id 19 20 BrowseInfo.objects.create(useragent=user_ua, user_ip=UserIpInfo.objects.get(id=ip_addr_id)) 21 22 result = { 23 "状态": "Success!", 24 "信息": "User info", 25 "IP": ip_addr, 26 "浏览器": user_ua 27 } 28 29 return HttpResponse(json.dumps(result), content_type="application/json", charset="utf-8") 30 31 32 def user_infos(request): 33 ip_list = UserIpInfo.objects.all() 34 infos = {} 35 for item in ip_list: 36 infos[item.ip] = [b_obj.useragent for b_obj in BrowseInfo.objects.filter(user_ip_id=item.id)] 37 38 result = {"状态": "Success!", "信息": infos} 39 40 return HttpResponse(json.dumps(result), content_type="application/json", charset="utf-8")
1 from django.urls import path 2 from . import views 3 4 urlpatterns = [ 5 path(‘send/‘, views.user_ip_info), 6 path(‘get/‘, views.user_infos), 7 8 ]
2、User 应用中urls.py:
1 from django.urls import path 2 from . import views 3 4 urlpatterns = [ 5 path(‘send/‘, views.user_ip_info), 6 path(‘get/‘, views.user_infos), 7 8 ]
原文:https://www.cnblogs.com/4geek/p/11414020.html