array(2) { ["docs"]=> array(10) { [0]=> array(10) { ["id"]=> string(9) "308660876" ["text"]=> string(45) "安全测试前置实践1-白盒&黑盒扫描" ["intro"]=> string(411) "本文我们将以围绕系统安全质量提升为目标,讲述在安全前置扫描上实践开展过程。希望通过此篇文章,帮助大家更深入、透彻地了解安全测试,能快速开展安全测试。 作者:京东物流 陈维 一、引言 G.J.Myers在《软件测试的艺术》中提出:从心理学角度来说,测试是一个为了寻找错误而运行程序的过程。 " ["username"]=> string(12) "jingdongkeji" ["tagsname"]=> string(39) "前端|安全|黑盒测试|白盒测试" ["tagsid"]=> string(29) "["160","2823","14120","5741"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1681206002" ["_id"]=> string(9) "308660876" } [1]=> array(10) { ["id"]=> string(9) "308660875" ["text"]=> string(24) "vulnhub靶场之ORASI: 1" ["intro"]=> string(256) "准备: 攻击机:虚拟机kali、本机win10。 靶机:Orasi: 1,下载地址:https://download.vulnhub.com/orasi/Orasi.ova,下载后直接vbox打开即可。 知识点:hex编码、ida逆向、AndroidKiller逆向、ffuf爆破、ssti漏洞、s" ["username"]=> string(6) "upfine" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1681204802" ["_id"]=> string(9) "308660875" } [2]=> array(10) { ["id"]=> string(9) "308660874" ["text"]=> string(92) "C# Kafka重置到最新的偏移量,即从指定的Partition订阅消息使用Assign方法" ["intro"]=> string(428) "在使用Kafka的过程中,消费者断掉之后,再次开始消费时,消费者会从断掉时的位置重新开始消费。 场景再现:比如昨天消费者晚上断掉了,今天上午我们会发现kafka消费的数据不是最新的,而是昨天晚上的数据,由于数据量比较多,也不会及时的消费到今天上午的数据,这个时候就需要我们对偏移量进行重置为最新的,以" ["username"]=> string(15) "Poetwithapistol" ["tagsname"]=> string(10) ".NET|Kafka" ["tagsid"]=> string(13) "["300","440"]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1681203303" ["_id"]=> string(9) "308660874" } [3]=> array(10) { ["id"]=> string(9) "308660873" ["text"]=> string(129) "迁移学习()《Attract, Perturb, and Explore: Learning a Feature Alignment Network for Semi-supervised Domain Adaptation》" ["intro"]=> string(194) "论文信息 论文标题:Attract, Perturb, and Explore: Learning a Feature Alignment Network for Semi-supervised Domain Adaptation论文作者:Taekyung Kim论文来源:2020 ECCV论文地" ["username"]=> string(12) "BlairGrowing" ["tagsname"]=> string(0) "" ["tagsid"]=> string(2) "[]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1681203302" ["_id"]=> string(9) "308660873" } [4]=> array(10) { ["id"]=> string(9) "308660872" ["text"]=> string(92) "C# Kafka重置到最新的偏移量,即从指定的Partition订阅消息使用Assign方法" ["intro"]=> string(428) "在使用Kafka的过程中,消费者断掉之后,再次开始消费时,消费者会从断掉时的位置重新开始消费。 场景再现:比如昨天消费者晚上断掉了,今天上午我们会发现kafka消费的数据不是最新的,而是昨天晚上的数据,由于数据量比较多,也不会及时的消费到今天上午的数据,这个时候就需要我们对偏移量进行重置为最新的,以" ["username"]=> string(10) "goodboydcc" ["tagsname"]=> string(10) ".NET|Kafka" ["tagsid"]=> string(13) "["300","440"]" ["catesname"]=> string(4) ".NET" ["catesid"]=> string(7) "["119"]" ["createtime"]=> string(10) "1681202402" ["_id"]=> string(9) "308660872" } [5]=> array(10) { ["id"]=> string(9) "308660870" ["text"]=> string(42) "Django怎么使用原生SQL查询数据库" ["intro"]=> string(392) "这篇文章主要介绍“Django怎么使用原生SQL查询数据库”,在日常操作中,相信很多人在Django怎么使用原生SQL查询数据库问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Django怎么使用原生SQL查询数据库”的疑惑有所帮助!接下来,请跟着小编一起来学习吧! D" ["username"]=> NULL ["tagsname"]=> string(20) "django|sql|数据库" ["tagsid"]=> NULL ["catesname"]=> string(0) "" ["catesid"]=> NULL ["createtime"]=> string(10) "1681201981" ["_id"]=> string(9) "308660870" } [6]=> array(10) { ["id"]=> string(9) "308660871" ["text"]=> string(37) "Express怎么实现定时发送邮件" ["intro"]=> string(432) "今天小编给大家分享一下Express怎么实现定时发送邮件的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。 在开发中我们有时候需要每隔 一段时间发送一次电子邮件,或者在某个特定的时间进行发" ["username"]=> NULL ["tagsname"]=> string(7) "express" ["tagsid"]=> NULL ["catesname"]=> string(0) "" ["catesid"]=> NULL ["createtime"]=> string(10) "1681201981" ["_id"]=> string(9) "308660871" } [7]=> array(10) { ["id"]=> string(9) "308660869" ["text"]=> string(29) "mysql运维------分库分表" ["intro"]=> string(412) "1. 介绍 问题分析: 随着互联网以及移动互联网的发展,应用系统的数据量也是成指数式增长,若采用单数据库进行数据存储,存在以下性能瓶颈: IO瓶颈:热点数据太多,数据库缓存不足,产生大量磁盘IO,效率较低。请求数据太多,带宽不够,网络IO瓶颈。CPU瓶颈:排序、分组、连接查询、聚合统计等SQL会耗费" ["username"]=> string(13) "qds1401744017" ["tagsname"]=> string(5) "mysql" ["tagsid"]=> string(7) "["237"]" ["catesname"]=> string(0) "" ["catesid"]=> string(2) "[]" ["createtime"]=> string(10) "1681200304" ["_id"]=> string(9) "308660869" } [8]=> array(10) { ["id"]=> string(9) "308660868" ["text"]=> string(41) "ASP.NET Core - 缓存之内存缓存(下)" ["intro"]=> string(292) "话接上篇 [ASP.NET Core - 缓存之内存缓存(上)],所以这里的目录从 2.4 开始。 2.4 MemoryCacheEntryOptions MemoryCacheEntryOptions 是内存缓存配置类,可以通过它配置缓存相关的策略。除了上面讲到的过期时间,我们还能够设置下面这些" ["username"]=> string(6) "wewant" ["tagsname"]=> string(12) "asp.net core" ["tagsid"]=> string(7) "["179"]" ["catesname"]=> string(25) "APS.NET Core 系列总结" ["catesid"]=> string(9) "["15288"]" ["createtime"]=> string(10) "1681200302" ["_id"]=> string(9) "308660868" } [9]=> array(10) { ["id"]=> string(9) "308660867" ["text"]=> string(9) "SPI协议" ["intro"]=> string(334) "SPI协议是由摩托罗拉公司提出的通讯协议(Serial Peripheral Interface),即串行外设接口。广泛用在ADC、LCD等设备与MCU间,要求通讯速率较高的场合。区分它与I2C协议差异以及FLASH存储器与EEPROM存储器的区别。下面我们分别对SPI协议的物理层及协议层进行讲解。" ["username"]=> string(8) "Kaelthas" ["tagsname"]=> string(5) "STM32" ["tagsid"]=> string(8) "["1311"]" ["catesname"]=> string(5) "STM32" ["catesid"]=> string(8) "["1139"]" ["createtime"]=> string(10) "1681199702" ["_id"]=> string(9) "308660867" } } ["count"]=> int(5621682) } ATM机设计类图 - 爱码网

ATM机问题域及词汇表:https://blog.csdn.net/ashdkl/article/details/80510951

ATM机用况图:https://blog.csdn.net/ashdkl/article/details/80511045

ATM机领域类图:https://blog.csdn.net/ashdkl/article/details/80511191

ATM机顺序图:https://blog.csdn.net/ashdkl/article/details/80511253

ATM机设计类图

一.文字说明

1.     类图综述

类图是对系统所抽象出来的实体的属性行为的描述以及实体与实体间的关联关系。该设计类图主要描述了ATM机的实体类与操作类之间的关系,说明了ATM机的一些基本功能,如登录操作,转账,存款,取款,打印凭条,查询余额及银行职员对ATM机的维护等功能。

2.类描述

2.1Client_Cardinfo类是银行用户卡信息的实体类,存储着有关用户账号内的一些基本信息,用于客户登录ATM机进行账户上的操作。

类名:Client_Cardinfo

属性:IDStringpublic),Passwordlongprivate

多重性:都为(1..1

操作:setPasswordlong):修改密码;

          getPassword():long获取密码以便登录表进行数据更新及校验

关系:与BankClerk_Cardinfo聚合成Cardinfo_form类,与ATM_Client为二元关联

2.2BankClerk_Cardinfo类是银行工作人员的卡信息的实体类,存储着工作人员的登录信息

类名:BankClerk_Cardinfo

属性:IDStringpublic),Passwordlongprivate

多重性:都为(1..1

操作:setPasswordlong):修改密码;

          getPassword():long获取密码以便登录表进行数据更新及校验

关系:与Client_Cardinfo聚合成Cardinfo_form类,与ATM_bankclerk为二元关联

2.3Cardinfo_form类为登录信息表,存储着客户和工作人员卡信息的账户和密码

类名:Cardinfo_form

属性:IDStringpublic),Passwordlongprivate

多重性:都为(1..1

操作:setPasswordlong):修改密码;

          getPassword():long获取密码以便登录表进行数据更新及校验

          login:boolean :进行账户和密码的匹对校验,看是否成功登录;

关系:由Client_CardinfoBankClerk_Cardinfo类聚合成

2.4ATM_Client类是客户成功登录后进行功能操作的界面,可以进行查询余额,取款,存款,转账,打印凭条的功能选择。

类名:ATM_Client

属性:balanceintpublic),dateStringpublic

多重性:都为(1..1

操作:getbalance():int:查询余额;

          transfer():boolean:进入转账的操作界面

          remove():boolean :进入取款的操作界面;

         deposit():boolean:进入存款的操作界面

          print_reciept():boolean :进入打印凭条的操作界面;

关系:与Client_Cardinfo类、transfer类、remove类,deposit类,print_reciept类各为二元关联关系

2.5transfer类是客户进行转账的操作界面类,进行转账的操作及操作信息的记录

类名:transfer

属性:newIDStringpublic

多重性:1..1

操作:setNewID():输入需要转账的账户;

          transfer_money():boolean:进行转账操作

          record():记录本次操作的信息及修改相关账户余额;

关系:与ATM_Client类、bankDB类各为二元关联关系

2.6remove类是客户进行取款界面操作的类,判断操作合法性及修改记录操作后的账户信息

类名:remove

属性:balanceintpublic

多重性:1..1

操作:Ifenough():判断账户内是否有足够本次操作的余额,若不合法就直接结束;

          remove_money():进行取款操作

          record():记录本次操作的信息及修改相关账户余额;

关系:与ATM_Client类、bankDB类各为二元关联关系

2.7deposit类是客户进行款界面操作的类,判断操作合法性及修改记录操作后的账户信息

类名:deposit

属性:balanceintpublic

多重性:1..1

操作:openentry():打开入钞口进行入钞,判断钞票的合法性及入钞口正常与否         

deposit_money():进行款操作

          record():记录本次操作的信息及修改相关账户余额;

关系:与ATM_Client类、bankDB类各为二元关联关系

2.8print_reciept类是客户进行打印凭条界面操作的类

类名:print_reciept

属性:无

操作:export():输出客户的操作凭条

2.9BankDB类是银行数据库的实体类,记录使用者的相关操作,日期及账户余额等信息。

类名:BankDB

属性:IDStringpublicPasswordlongprivate),dateStringprivate),balanceintpublic),opertaionStringpublic

操作:getdate():获取相关操作的时间

关系:与print_reciept类、depositremovetransferATM_bankclerk类各为二元关联

2.10ATM_bankclerk类是银行工作人员进行ATM机的硬件维护操作时的控制类

类名:ATM_bankclerk

属性:dateStringpublic),countintpublic

操作:Maintenance():进行硬件维护

      record():记录本次操作的信息及修改相关纸币数目

关系:与BankClerk_Cardinfo类和BankDB类为二元关联











相关文章:

  • 2021-04-20
  • 2021-06-27
  • 2021-06-03
  • 2021-09-03
  • 2021-10-29
  • 2021-12-25
  • 2021-08-14
猜你喜欢
  • 2021-05-28
  • 2022-01-12
  • 2021-04-05
  • 2021-05-15
  • 2021-11-03
  • 2021-05-05
相关资源
相似解决方案