侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

Django如何开发简单的查询接口详解

框架(架构)  /  管理员 发布于 7年前   189

前言

Django处理json也是一把好手,有时候在工作中各个部门都会提供自己的相关接口,但是信息也只是单方的信息,这时候需要运维将各个部门的信息进行集成,统一出一个查询接口或页面,方便其他部门同事使用,接下来就介绍一下Django如果操作json。

首先介绍一下通过url获取json的方法:

import urllib2

我们的需求是做一个集成的信息查询系统,包括简单的IP信息查询(省份运营商等),以及设备信息(如果是登记在资产管理库中的),还有IP归属(是否是客户源站IP),以及是否为其他部门的存储IP,另外还有错误日志具体信息查询,等等功能,这些功能信息的提供分属于不同的部门,有的是给的url,有的是给的文件,如何将这些功能都揉在一起变成一个接口,确实比较考验逻辑思维,接下来通过代码来具体介绍:

首先我们要分清楚要查询的信息都有什么特征,如果信息非常类似就需要用不同的参数来区分了,如果信息差异明显可以简单通过逻辑顺序判断。

我们先从查询主机名开始写,因为主机名只在资产系统中有登记,是相对固定的数据:

url = "http://3.3.3.3/api/v1/demo..." #先定义了几个url的查询接口,配合我们后面查询来用,当然这些接口吐出的数据得是json格式。 urlks3 = "http://2.2.2.2/api/v1/demo..."...  types = ['hostname','pubip','otherinfo','isp','province','city'] # 先定义我们这个接口能吐哪些东西 if host: # 判断查询的是否为主机名  hostcheck = str(Ipinfo.objects.values('hostname','pubip','otherinfo').filter(hostname=host)) # 在数据库中查询结果  if hostcheck:    hostcheck = re.sub(r'\'', '\"', hostcheck) # 修查询出的数据改格式为json格式   maininfo = json.loads(hostcheck) # 将数据库查询出的数据导出到对象   pubip = maininfo['pubip'] # 这时就可以取出json对应的内容了   checkipurl = ...+pubip   data=urllib2.urlopen(checkipurl).read() # 读取某个url中的json内容   ipinfo = json.loads(data) # 将上一步获取的数据导出到对象   # 下面是各种赋值,就很随意了   maininfo['isp'] = ipinfo['info']['isp']    maininfo['province'] = ipinfo['info']['province']   maininfo['city'] = ipinfo['info']['city']   # 接下来判断这个请求是否查询了错误日志信息,这个是因为主机名跟错误信息内容比较接近,只能靠参数来判断了     if erres:    erres = re.sub(r' ', '%20', erres)    checkerreurl = ...    errepage = urllib2.urlopen(checkerreurl)    erredata = errepage.read()    print erredata    erreinfo = json.loads(erredata)    maininfo['ch_exp']= erreinfo['ch_exp']  # 下面是如果查询不到主机信息,就补充空信息避免程序出现异常  else:   for item in types:    maininfo[item] = '-'  return JsonResponse(maininfo,json_dumps_params={'ensure_ascii':False})

接下来我们查询IP信息:

 if ipadd:  hostcheck = str(Ipinfo.objects.values('hostname','pubip','otherinfo').filter(Q(pubip=ipadd)...)[0:1]) #多个字段查询可以用Q方法   if hostcheck:   hostcheck = re.sub(r'\'', '\"', hostcheck)   maininfo = json.loads(hostcheck)   pubip = maininfo['pubip']   checkipurl = ...+ipadd   page=urllib2.urlopen(checkipurl)   data=page.read()   ipinfo = json.loads(data)   maininfo['isp'] = ipinfo['info']['isp']   maininfo['province'] = ipinfo['info']['province']   maininfo['city'] = ipinfo['info']['city']

期间还有其他的联合查询,逻辑组合可以自行安排。

接下来介绍一下读取json文件并提供查询的方法:

我们的需求是判断IP是否属于客户源站,其中跟客户交互的两个部门都定期导出了客户源站信息文件,但仅仅是文件,而且这两个文件的格式还不太一样

我们要根据这两个文件来查询IP是否属于客户源站:

# 打开文件句柄,这部分一定要写到函数以外,如果文件很小并且要支持实时更新,可以写到函数内with open('/.../source.json','r') as file_object: # 这个文件是es直接导出的一个大的json,每个k、v都一一对应 srcinfo = file_object.read() srcjson = json.loads(srcinfo)with open('/.../total.json','r') as tot_object: # 这个文件是一个列表式的json,元素较多,元素中是键值对。 totinfo = tot_object.read() totjson = json.loads(totinfo)

接下来定义函数:

def chsrcip(request): exit_flag = [] # 给循环打个退出标签 等下有用 ip = request.GET.get('ip') maininfo = {} maininfo['hostname']= '-' # 先给个默认值 maininfo['otherinfo']= '-' if re.search('^(\d+\.\d+\.\d+.\d+)$',ip):  for item in srcjson:   for k,v in item.items():    if ip in v:     maininfo['hostname']=k     maininfo['otherinfo']= u'客户源站'      exit_flag = 'true' # 由于IP数量庞大,所以找到第一个IP时就停止循环并退出整个for循环,这时候就用到了退出标签。     break   if exit_flag:     break  for item in totjson: # 进入第二个for循环查询查询具体的客户名称   if ip in item['originAddresses']:    maininfo['hostname']= item['domain'],item['userId']    maininfo['otherinfo']= u'客户源站'    break  return JsonResponse(maininfo,json_dumps_params={'ensure_ascii':False})

以上的调用方法根据数据名称不同可自行修改。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对AIDI的支持。


  • 上一条:
    Django 多环境配置详解
    下一条:
    Django 表单模型选择框如何使用分组
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • Filament v3.1版本发布(0个评论)
    • docker + gitea搭建一个git服务器流程步骤(0个评论)
    • websocket的三种架构方式使用优缺点浅析(0个评论)
    • ubuntu20.4系统中宿主机安装nginx服务,docker容器中安装php8.2实现运行laravel10框架网站(0个评论)
    • phpstudy_pro(小皮面板)中安装最新php8.2.9版本流程步骤(0个评论)
    • 近期文章
    • 在go中实现一个常用的先进先出的缓存淘汰算法示例代码(0个评论)
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2018-05
    • 2020-02
    • 2020-03
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-11
    • 2021-03
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-08
    • 2023-08
    • 2023-10
    • 2023-12
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客