欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Django如何開(kāi)發(fā)簡(jiǎn)單的查詢(xún)接口詳解

 更新時(shí)間:2019年05月17日 08:50:37   作者:628 財(cái)經(jīng)  
這篇文章主要給大家介紹了使用Django如何開(kāi)發(fā)簡(jiǎn)單的查詢(xún)接口的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Django具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

前言

Django處理json也是一把好手,有時(shí)候在工作中各個(gè)部門(mén)都會(huì)提供自己的相關(guān)接口,但是信息也只是單方的信息,這時(shí)候需要運(yùn)維將各個(gè)部門(mén)的信息進(jìn)行集成,統(tǒng)一出一個(gè)查詢(xún)接口或頁(yè)面,方便其他部門(mén)同事使用,接下來(lái)就介紹一下Django如果操作json。

首先介紹一下通過(guò)url獲取json的方法:

import urllib2

我們的需求是做一個(gè)集成的信息查詢(xún)系統(tǒng),包括簡(jiǎn)單的IP信息查詢(xún)(省份運(yùn)營(yíng)商等),以及設(shè)備信息(如果是登記在資產(chǎn)管理庫(kù)中的),還有IP歸屬(是否是客戶源站IP),以及是否為其他部門(mén)的存儲(chǔ)IP,另外還有錯(cuò)誤日志具體信息查詢(xún),等等功能,這些功能信息的提供分屬于不同的部門(mén),有的是給的url,有的是給的文件,如何將這些功能都揉在一起變成一個(gè)接口,確實(shí)比較考驗(yàn)邏輯思維,接下來(lái)通過(guò)代碼來(lái)具體介紹:

首先我們要分清楚要查詢(xún)的信息都有什么特征,如果信息非常類(lèi)似就需要用不同的參數(shù)來(lái)區(qū)分了,如果信息差異明顯可以簡(jiǎn)單通過(guò)邏輯順序判斷。

我們先從查詢(xún)主機(jī)名開(kāi)始寫(xiě),因?yàn)橹鳈C(jī)名只在資產(chǎn)系統(tǒng)中有登記,是相對(duì)固定的數(shù)據(jù):

url = "http://3.3.3.3/api/v1/demo..." #先定義了幾個(gè)url的查詢(xún)接口,配合我們后面查詢(xún)來(lái)用,當(dāng)然這些接口吐出的數(shù)據(jù)得是json格式。 
urlks3 = "http://2.2.2.2/api/v1/demo..."
...
 
 types = ['hostname','pubip','otherinfo','isp','province','city'] # 先定義我們這個(gè)接口能吐哪些東西
 if host: # 判斷查詢(xún)的是否為主機(jī)名
  hostcheck = str(Ipinfo.objects.values('hostname','pubip','otherinfo').filter(hostname=host)) # 在數(shù)據(jù)庫(kù)中查詢(xún)結(jié)果
  if hostcheck: 
   hostcheck = re.sub(r'\'', '\"', hostcheck) # 修查詢(xún)出的數(shù)據(jù)改格式為json格式
   maininfo = json.loads(hostcheck) # 將數(shù)據(jù)庫(kù)查詢(xún)出的數(shù)據(jù)導(dǎo)出到對(duì)象
   pubip = maininfo['pubip'] # 這時(shí)就可以取出json對(duì)應(yīng)的內(nèi)容了
   checkipurl = ...+pubip
   data=urllib2.urlopen(checkipurl).read() # 讀取某個(gè)url中的json內(nèi)容
   ipinfo = json.loads(data) # 將上一步獲取的數(shù)據(jù)導(dǎo)出到對(duì)象
   # 下面是各種賦值,就很隨意了
   maininfo['isp'] = ipinfo['info']['isp'] 
   maininfo['province'] = ipinfo['info']['province']
   maininfo['city'] = ipinfo['info']['city']
   # 接下來(lái)判斷這個(gè)請(qǐng)求是否查詢(xún)了錯(cuò)誤日志信息,這個(gè)是因?yàn)橹鳈C(jī)名跟錯(cuò)誤信息內(nèi)容比較接近,只能靠參數(shù)來(lái)判斷了  
   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']
  # 下面是如果查詢(xún)不到主機(jī)信息,就補(bǔ)充空信息避免程序出現(xiàn)異常
  else:
   for item in types:
    maininfo[item] = '-'
  return JsonResponse(maininfo,json_dumps_params={'ensure_ascii':False})

接下來(lái)我們查詢(xún)IP信息:

 if ipadd:
  hostcheck = str(Ipinfo.objects.values('hostname','pubip','otherinfo').filter(Q(pubip=ipadd)...)[0:1]) #多個(gè)字段查詢(xún)可以用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']

期間還有其他的聯(lián)合查詢(xún),邏輯組合可以自行安排。

接下來(lái)介紹一下讀取json文件并提供查詢(xún)的方法:

我們的需求是判斷IP是否屬于客戶源站,其中跟客戶交互的兩個(gè)部門(mén)都定期導(dǎo)出了客戶源站信息文件,但僅僅是文件,而且這兩個(gè)文件的格式還不太一樣

我們要根據(jù)這兩個(gè)文件來(lái)查詢(xún)IP是否屬于客戶源站:

# 打開(kāi)文件句柄,這部分一定要寫(xiě)到函數(shù)以外,如果文件很小并且要支持實(shí)時(shí)更新,可以寫(xiě)到函數(shù)內(nèi)
with open('/.../source.json','r') as file_object: # 這個(gè)文件是es直接導(dǎo)出的一個(gè)大的json,每個(gè)k、v都一一對(duì)應(yīng)
 srcinfo = file_object.read()
 srcjson = json.loads(srcinfo)
with open('/.../total.json','r') as tot_object: # 這個(gè)文件是一個(gè)列表式的json,元素較多,元素中是鍵值對(duì)。
 totinfo = tot_object.read()
 totjson = json.loads(totinfo)

接下來(lái)定義函數(shù):

def chsrcip(request):
 exit_flag = [] # 給循環(huán)打個(gè)退出標(biāo)簽 等下有用
 ip = request.GET.get('ip')
 maininfo = {}
 maininfo['hostname']= '-' # 先給個(gè)默認(rèn)值
 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數(shù)量龐大,所以找到第一個(gè)IP時(shí)就停止循環(huán)并退出整個(gè)for循環(huán),這時(shí)候就用到了退出標(biāo)簽。
     break
   if exit_flag: 
    break
  for item in totjson: # 進(jìn)入第二個(gè)for循環(huán)查詢(xún)查詢(xún)具體的客戶名稱(chēng)
   if ip in item['originAddresses']:
    maininfo['hostname']= item['domain'],item['userId']
    maininfo['otherinfo']= u'客戶源站'
    break
  return JsonResponse(maininfo,json_dumps_params={'ensure_ascii':False})

以上的調(diào)用方法根據(jù)數(shù)據(jù)名稱(chēng)不同可自行修改。

總結(jié)

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。

相關(guān)文章

最新評(píng)論