本节目标

审核写到数据库,我就单独写一个如下的 页面

单机go后就跳转到如下图界面,我们这节课的目标就是写一个这样的页面

asset\admin.py部分代码 注释如下:

class NewAssetApprovalZoneAdmin(admin.ModelAdmin):
list_display = ('sn','asset_type','manufactory','model','cpu_model','cpu_count','cpu_core_count','ram_size','os_distribution','os_release','date','approved','approved_by','approved_date')
actions = ['approve_selected_objects'] def approve_selected_objects(modeladmin, request, queryset):
selected = request.POST.getlist(admin.ACTION_CHECKBOX_NAME)
print("----select",selectd) '''
ACTION_CHECKBOX_NAME 是获取选中的id
两个的id都打印出来?为什么是2,checkbox在后台获取的就不是一个了,是一个列表
获取的是一个列表 getlist 4,2 是什么?
就是那个自增ID
''' ct = ContentType.objects.get_for_model(queryset.model)
return HttpResponseRedirect("/asset/new_assets/approval/?ct=%s&ids=%s" % (ct.pk, ",".join(selected)))
approve_selected_objects.short_description = "批准入库" '''在菜单下拉框中显示"批准入库"'''

ACTION_CHECKBOX_NAME是什么?

 两个的id都打印出来?为什么是2,checkbox在后台获取的就不是一个了,是一个列表

checkbox在后台获取方式

getlist 4,2 是什么?

获取的就是那个自增ID

为什么要获取这两个东西?

你要跳到一个新的页面,跳转了一个url,你没有办法把对象传过去,所以你要获取这两个东西

数据回报到哪里呢?

1、asset\admin.py文件下的

return HttpResponseRedirect("/asset/new_assets/approval/?ct=%s&ids=%s" % (ct.pk, ",".join(selected)))

2、asset\url.py下的

 url(r'^new_assets/approval/$', views.new_assets_approval, name="new_assets_approval"),

3、asset\views.py文件下的

 def new_assets_approval(request):
'''是以get还是以post跳转过去的?是以get方式跳转过去的,所以以下代码我们就不用看post代码了,直接看get方法"'''
if request.method == 'POST':
request.POST = request.POST.copy()
approved_asset_list = request.POST.getlist('approved_asset_list')
approved_asset_list = models.NewAssetApprovalZone.objects.filter(id__in=approved_asset_list) response_dic = {}
for obj in approved_asset_list:
request.POST['asset_data'] = obj.data
ass_handler = core.Asset(request)
if ass_handler.data_is_valid_without_id():
ass_handler.data_inject()
obj.approved = True
obj.save() response_dic[obj.id] = ass_handler.response
return render(request, 'assets/new_assets_approval.html',
{'new_assets': approved_asset_list, 'response_dic': response_dic})
else:
ids = request.GET.get('ids')
'''获取到ids,ids是那?是我们刚选中的那几条数据'''
id_list = ids.split(',')
new_assets = models.NewAssetApprovalZone.objects.filter(id__in=id_list) return render(request, 'assets/new_assets_approval.html', {'new_assets': new_assets})
'''
从待批准区里把这几条数据过滤出来返回到这个new_assets_approval.html地址,
另外一个页面就是列出要批准的资产,问你要不要批准

前端页面代码

{% extends 'base.html' %}

{% block page-container %}
<div class="eq-height"> <div class="col-sm-4 eq-box-sm"> <!--Panel with Header-->
<!--===================================================-->
<div class="panel">
<div class="panel-heading">
<h3 class="panel-title" style="color: red; ">确认要将下列资产存入数据库么?</h3>
</div>
<div class="panel-body">
<form method="post" action="{% url 'new_assets_approval' %}">{% csrf_token %}
<table class="table table-hover">
<tr>
<th>#</th>
<th>SN</th>
<th>资产类型</th>
<th>厂商</th>
<th>型号</th>
<th>CPU型号</th>
<th>CPU颗数</th>
<th>CPU核数</th>
<th>内存大小</th>
<th>汇报日期</th> </tr>
{% for new_asset in new_assets %}
<tr data-set="{{ new_asset.id }}">
<td>{{ forloop.counter }}</td>
<td>{{ new_asset.sn }}</td>
<td>{{ new_asset.asset_type }}</td>
<td>{{ new_asset.manufactory }}</td>
<td>{{ new_asset.model }}</td>
<td>{{ new_asset.cpu_model}}</td>
<td>{{ new_asset.cpu_count}}</td>
<td>{{ new_asset.cpu_core_count}}</td>
<td>{{ new_asset.ram_size}}</td>
<td>{{ new_asset.date }}</td>
{% if new_asset.id in response_dic %}
<td><a href="#asset_{{ new_asset.id }}">执行结果</a></td>
{% endif %} </tr>
{% endfor %} </table>
<select name="approved_asset_list" class="hide" multiple>
{% for new_asset in new_assets %}
<option value="{{ new_asset.id }}" selected>{{ new_asset.sn }}</option>
{% endfor %}
</select>
<input type="submit" value="Yes, I'm sure" class="btn btn-danger"> </form> <div >
{% for key,msg in response_dic.items %}
<div>
{% for asset in new_assets %}
{% if asset.id == key %}
<h4 id="asset_{{ asset.id }}"><a style="color:deepskyblue" href="/admin/assets/asset/?q={{ asset.sn }}" target="_blank">{{ asset.sn }} </a> | {{ asset.manufactory }} {{ asset.model }} | {{ asset.cpu_model }} </h4>
{% endif %}
{% endfor %}
<p style="color: green">
{% for item in msg.info %}
{{ item |safe}}
<br/>
{% endfor %}
</p>
<p style="color: red">
{% for item in msg.error %} {% if 'Warning' in item.keys.0 %}
<span style="color:orange;">{{ item }}</span>
{% else %}
{{ item }}
{% endif %}
<br/>
{% endfor %}
</p>
</div>
<hr/>
{% endfor %}
</div> </div> </div>
<!--===================================================-->
<!--End Panel with Header-->
<button id="scroll-top" class="btn"><i class="fa fa-chevron-up"></i></button> </div> </div> {% endblock %}

测试效果截图

一、选中要批准的资产,下拉框选择批准入库,单机go提交

二、确认要将下列资产存入数据库吗?YES

三、 绿色代表资产已创建了,红色的是磁盘数据缺失

四、 看看资产表已经写入成功

CMDB资产管理系统开发【day26】:admin action的更多相关文章

  1. CMDB资产管理系统开发【day26】:Django admin

    想实现的是一个表里面的字段 选择性的出现在菜单栏 1.如何自定义菜单 自定义菜单前 在asset\admin.py里添加如下代码: class NewAssetApprovalZoneAdmin(ad ...

  2. CMDB资产管理系统开发【day26】:数据正式存入待存区

    1.from表单提交 1.数据提交到哪里呢? 提交到assets/new_assets_approval.html这了 2.Yes, I'm sure提交了什么?          为什么没有下拉框了 ...

  3. CMDB资产管理系统开发【day26】:实现资产自动更新

    1.需求分析 1.比对分析 比对的时候以那个数据源为主? old [1,2,3 ] db数据库 new [2,3,4 ] 客户端汇报过来的 当然以客户端汇报过来的数据为主 2.更新分析 不同的表到底拿 ...

  4. CMDB资产管理系统开发【day26】:批准资产入库

    刚才都是一条像内存,硬盘,网卡.多条的话如何操作 只有一条数据 下面的是有多条数据的 硬盘必须字段的验证 def __create_disk_component(self): disk_info = ...

  5. CMDB资产管理系统开发【day26】:CMDB上节回顾

    一.上节知识点回顾 服务器设计了一个表结构 开发了一个客户端 二.后台创建缓存区表 客户端连接服务器,在服务器的下面看报错信息 因为URL都没有写,所以我找不到呀 1.在MadKing\url.py ...

  6. CMDB资产管理系统开发【day26】:02-数据写入待存区

    一.资产自动回报数据及个更新流程图 二.表结构注释(NewAssetApprovalZone) class NewAssetApprovalZone(models.Model): "&quo ...

  7. CMDB资产管理系统开发【day26】:linux客户端开发

    客户端疑难点及获取流程 1.linux客户端支持2就可以,python3就是很麻烦 难道你要求所有的客户端都上pytho3吗? 现在从bin的入口进去 HouseStark.ArgvHandler(s ...

  8. CMDB资产管理系统开发【day25】:需求分析

    本节内容 浅谈ITIL CMDB介绍 Django自定义用户认证 Restful 规范 资产管理功能开发 浅谈ITIL TIL即IT基础架构库(Information Technology Infra ...

  9. CMDB资产管理系统开发【day25】:表结构设计1

    资产表 # _*_coding:utf-8_*_ __author__ = 'jieli' from assets.myauth import UserProfile from django.db i ...

随机推荐

  1. Cherrypy文件上传非ASCII文件名乱码问题解决

    Cherrypy 版本: 18.0.1 由于某些特殊原因(可能是与标准兼容的问题),Cherrypy对上传文件的原文件名使用 ISO-8859-1 编码方式解码,导致非 ASCII 的文件名显示为乱码 ...

  2. mysql 从一个表中查询,插入到另一个表中

    insert into table1(field1) select field1 from table2; ;

  3. Linux 下必备的性能检测工具 合集

    有些工具,值得学习学习: 网络 iftop IO  iotop 系统  top htop 保持更新,转载请注明出处. https://www.cnblogs.com/xuyaowen/p/linux- ...

  4. jQuery根据radio来控制texteara

    最近遇到一个问题:需要通过点击radio来控制texteara的属性变化. 这里主要有两个知识点:1,给texteara设置属性:2,给texteara设置背景颜色. 在这里,假设texteara的i ...

  5. Boosting Static Representation Robustness for Binary Clone Search against Code Obfuscation and Compiler Optimization

    用于理解恶意软件的内部工作原理,并发现系统中的漏洞,逆向工程是一种耗费人工的却很重要的技术.汇编克隆搜索引擎是通过识别那些重复的或者已知的部件来帮助逆向工程师的工作,要想设计健壮的克隆搜索引擎是一项挑 ...

  6. audio

    // media.cpp : 定义控制台应用程序的入口点. // https://wenku.baidu.com/view/e910c474c5da50e2524d7fb4.html https:// ...

  7. 一探究竟:Namenode、SecondaryNamenode、NamenodeHA关系

    NameNode与Secondary NameNode 很多人都认为,Secondary NameNode是NameNode的备份,是为了防止NameNode的单点失败的,其实并不是在这样.文章Sec ...

  8. kafka实战kerberos

    more /etc/krb5.conf [logging] default = FILE:/var/log/krb5libs.log kdc = FILE:/var/log/krb5kdc.log a ...

  9. 解析Object.defineProperty的作用

    对象是由多个名/值对组成的无序的集合.对象中每个属性对应任意类型的值. 定义对象可以使用构造函数或字面量的形式: 除了以上添加属性的方式,还可以使用Object.defineProperty定义新属性 ...

  10. Spring Security(二十九):9.4.1 ExceptionTranslationFilter

    ExceptionTranslationFilter is a Spring Security filter that has responsibility for detecting any Spr ...