代码如下
Control:
from django.conf.urls import patterns, include, url from django.contrib import admin admin.autodiscover() urlpatterns = patterns('', # Examples: # url(r'^$', 'simplecmdb.views.home', name='home'), # url(r'^blog/', include('blog.urls')), url(r'^admin/', include(admin.site.urls)), url(r'^hostinfo/collect/$','hostinfo.views.collect'), url(r'^hostinfo/getjson/$','hostinfo.views.getjson'), url(r'^hostinfo/gettxt/$','hostinfo.views.gettxt'), )
View:
from django.shortcuts import render from django.http import HttpResponse from hostinfo.models import Host,HostGroup import pickle import json # Create your views here. def collect(req): if req.POST: #dic = pickle.loads(req.body) dic = json.loads(req.body) hostname = dic['hostname'] ip = dic['ip'] product = dic['product'] sn = dic['sn'] vendor = dic['vendor'] cpu_model = dic['cpu_model'] cpu_num = dic['cpu_num'] memory = dic['memory'] osver = dic['osver'] try: host = Host.objects.get(sn=sn) except: host = Host() host.hostname = hostname host.ip = ip host.product = product host.sn = sn host.vendor = vendor host.cpu_model = cpu_model host.cpu_num = cpu_num host.memory = memory host.osver = osver host.save() return HttpResponse('data have save into DB') else: return HttpResponse('there is no data from POST method') def getjson(req): ret_list = [] hg = HostGroup.objects.all() for g in hg: ret = {'groupname':g.groupname,'members':[]} for h in g.members.all(): ret_h = {'hostname':h.hostname,'ip':h.ip} ret['members'].append(ret_h) ret_list.append(ret) return HttpResponse(json.dumps(ret_list)) def gettxt(req): res = '' hg = HostGroup.objects.all() for g in hg: groupname = g.groupname for h in g.members.all(): hostname = h.hostname ip = h.ip res += groupname+' '+hostname+' '+ip+'\n' return HttpResponse(res)
Model:
from django.db import models # Create your models here. class Host(models.Model): hostname = models.CharField(max_length=50) ip = models.IPAddressField() vendor = models.CharField(max_length=50) product = models.CharField(max_length=50) sn = models.CharField(max_length=50) cpu_model = models.CharField(max_length=50) cpu_num = models.IntegerField() memory = models.CharField(max_length=50) osver = models.CharField(max_length=50) def __unicode__(self): return self.hostname class HostGroup(models.Model): groupname = models.CharField(max_length=50) members = models.ManyToManyField(Host)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
更多面试题总结请看:【面试题】技术面试题汇总 前言 本文通过在 Docker 容器中执行命令,来深入了解两台主机之间的通信过程。阅读完本文,我们将熟悉以下内容: Docker 的基本操作 创建 socket 并发送 HTTP 请求 路由表、路由决策过程 ARP 协议、ARP 表更新过程 本文也是输入一个 URL 到页面加载完成的另一个角度的回答,我们将解决以下两个问题: 不同局域网的两台主机之间的
本文向大家介绍django通过ajax发起请求返回JSON格式数据的方法,包括了django通过ajax发起请求返回JSON格式数据的方法的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了django通过ajax发起请求返回JSON格式数据的方法。分享给大家供大家参考。具体实现方法如下: 这是后台处理的: 这是AJAX部分: URL的配置是: 希望本文所述对大家的Python程序设计有所帮助
在本节中,我们将讨论使用Whois Lookup,Netcraft和Robtex收集客户信息的各种技术。然后,我们将看到如何通过定位该服务器上托管的网站来攻击服务器。在信息收集部分,我们将了解子域以及它们如何对执行攻击有用。稍后在目标系统上查找文件以收集一些信息并分析该数据。 现在,我们将在开始尝试利用之前收集信息。因此,我们将尽可能多地收集有关目标IP,网站上使用的技术,域名信息,使用哪种编程语
讲师:gh0stkey 整理:飞龙 协议:CC BY-NC-SA 4.0 收集什么? Whois信息 注册人名字、邮箱等 IP信息(服务器的IP) 判断是否为CDN节点,查询同IP网站,端口扫描 目录信息 判断WEB应用,获取网站后台目录,获取其他 服务信息 判断服务,例如:IIS、Apache 脚本信息 ASP、PHP、aspx(asp.net) 框架信息 ThinkPHP、Struts等 应用
信息收集测试包含下列内容: 搜索引擎信息发现和侦察 (OTG-INFO-001) 识别web服务器 (OTG-INFO-002) web服务器元文件信息发现 (OTG-INFO-003) 服务器应用应用枚举 (OTG-INFO-004) 评论信息发现 (OTG-INFO-005) 应用入口识别 (OTG-INFO-006) 识别应用工作流程 (OTG-INFO-007) 识别web应用框架 (OT
问题内容: 第一次海报,长期的读者。我花了很长时间寻找答案,这使我认为这是我所缺少的基本知识。 我试图提取保存在数据库表中的数据,并将其传递通过,以显示在Highcharts图中。在检查源代码时,我没有从Django或客户端收到任何错误。 使用:Django 1.7和Python 3.4 views.py: get_data()函数: 模板: 最后的网址: 一切似乎都在运行,但Highchart图