CN105607985B - 基于Qt图形界面软件的操作日志记录方法及系统 - Google Patents

基于Qt图形界面软件的操作日志记录方法及系统 Download PDF

Info

Publication number
CN105607985B
CN105607985B CN201510629301.5A CN201510629301A CN105607985B CN 105607985 B CN105607985 B CN 105607985B CN 201510629301 A CN201510629301 A CN 201510629301A CN 105607985 B CN105607985 B CN 105607985B
Authority
CN
China
Prior art keywords
controls
event
mouse
daily record
record data
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
CN201510629301.5A
Other languages
English (en)
Other versions
CN105607985A (zh
Inventor
潘超
鲁爱国
朱博
田华
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
709th Research Institute of CSIC
Original Assignee
709th Research Institute of CSIC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 709th Research Institute of CSIC filed Critical 709th Research Institute of CSIC
Priority to CN201510629301.5A priority Critical patent/CN105607985B/zh
Publication of CN105607985A publication Critical patent/CN105607985A/zh
Application granted granted Critical
Publication of CN105607985B publication Critical patent/CN105607985B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Landscapes

  • Debugging And Monitoring (AREA)

Abstract

本发明公开一种基于Qt图形界面软件的操作日志记录方法及系统,通过对用户在Qt图形界面上对Qt控件操作而产生的操作事件进行采集和处理,首先将Qt操作事件的类型分为鼠标事件和键盘事件;然后根据事件的信息分析用户使用鼠标或使用键盘对Qt控件的操作,获得Qt控件信息并形成鼠标操作日志数据或键盘输入日志数据;最后将鼠标操作日志数据和键盘输入日志数据压缩为日志数据包,并将日志数据包进行文件记录。因此,本发明通过采集和分析用户在操作Qt控件时Qt图形界面所产生的事件信息,获得用户在操作鼠标或键盘时所处理Qt控件的名称、类型、位置等信息,并通过Qt控件信息得到该控件实现的具体功能,从而为快速记录软件系统的用户操作日志提供了途径。

Description

基于Qt图形界面软件的操作日志记录方法及系统
技术领域
本发明涉及一种软件系统的日志记录技术,特别涉及一种基于Qt图形界面软件的操作日志记录方法及系统。
背景技术
软件操作日志是记录用户在使用软件的过程中,通过鼠标和键盘在操作界面上执行的点击和输入操作,以及执行操作所实现的功能。软件操作日志对于分析软件性能、定位操作异常、以及维护优化功能等具有重要作用。例如,通过记录用户在界面上的操作,可以统计各种界面及其控件的使用频率,为界面显示方式和控件布局的合理设计提供建议;通过记录用户对软件功能的使用,可以知道用户经常使用的功能,对软件的常用功能进行重点优化;特别是,当用户在操作中造成软件系统崩溃时,可以追踪到崩溃来源的具体操作信息。操作日志已成为软件系统日志最重要的组成部分之一。
目前,大多数成熟的软件系统都具备操作日志记录功能。例如Windows XP系统日志记录了用户安装、更新和删除程序的操作,Oracle数据库记录了用户对数据库表和字段的修改,Linux下的history命令可记录用户在终端下的键盘输入命令。另外一些软件,如Window 7自带的问题步骤记录器、按键精灵软件、键盘鼠标记录大师等,可以通过抓屏的方式记录鼠标键盘的具体操作。
Qt是一款跨平台的图形界面应用程序框架,它提供了大量成熟的Qt控件,通过事件消息的方式实现控件的人机交互。通过Qt控件的组合,可为软件系统制作出丰富的图形界面,方便用户进行复杂的软件操作。目前,国内外已经使用Qt开发了多种界面软件系统,由用户在界面上操作各种Qt控件来执行功能。然而,目前软件中针对Qt图形界面的操作日志记录尚不成熟,未出现一种简单的记录方法。
发明内容
有鉴于此,有必要提供一种仅需要分析Qt控件产生的事件,即可记录用户在Qt图形界面上进行的所有鼠标和键盘操作,并形成详细的操作日志的记录方法。
一种基于Qt图形界面软件的操作日志记录方法,所述基于Qt图形界面软件的操作日志记录方法包括如下步骤:
S1、采集用户在界面上对Qt控件操作时,Qt界面所产生的操作事件;
S2、根据事件的内容判断Qt事件的类型,Qt操作事件的类型分为鼠标事件和键盘事件;
S3、根据鼠标事件分析用户使用鼠标对Qt控件的操作,获得Qt控件信息并形成鼠标操作日志数据;
S4、根据键盘事件分析用户使用键盘对Qt控件输入指令,获得Qt控件信息并形成键盘输入日志数据;
S5、将鼠标操作日志数据和键盘输入日志数据压缩为日志数据包,并将日志数据包进行文件记录。
一种基于Qt图形界面的软件操作日志的记录系统,其包括以下模块,
事件采集模块,用于捕获和记录根据用户在界面上对Qt控件操作时界面所产生的Qt事件;
事件分类模块,用于根据事件的内容判断Qt事件信息的类型,Qt操作事件的类型分为鼠标事件和键盘事件;
鼠标日志模块,用于监控用户使用鼠标对Qt控件的操作,获得Qt控件信息并形成鼠标操作日志数据;
键盘日志模块,用于监控用户使用键盘对Qt控件输入指令,获得Qt控件信息并形成键盘输入日志数据;
文件记录模块,用于将鼠标操作日志数据和键盘输入日志数据压缩为日志数据包,并将日志数据包进行文件记录。
本发明所述基于Qt图形界面软件的操作日志记录方法,通过采集和分析用户在操作Qt控件时Qt图形界面所产生的事件,获得用户在操作鼠标或键盘时所处理Qt控件的名称、类型、位置等信息,并通过Qt控件信息得到该控件实现的具体功能,从而为快速记录软件系统的用户操作日志提供了途径。
附图说明
图1是本发明一较佳实施例的基于Qt图形界面软件的操作日志记录方法流程图;
图2是图1中步骤S1的子流程图;
图3是图1中步骤S2的一实施子流程图;
图4是图1中步骤S3的又一实施子流程图;
图5是图1中步骤S4的子流程图;
图6是图1中步骤S5的子流程图;
图7是本发明实施例中基于Qt图形界面软件的操作日志记录方法的工作流程示意图;
图8是本发明一较佳实施例的基于Qt图形界面软件的操作日志记录系统的结构框图;
图9是图8中事件产生模块的子结构框图;
图10是图8中事件分类模块的子结构框图;
图11是图8中鼠标日志模块的子结构框图;
图12是图8中键盘日志模块的子结构框图;
图13是图8中文件记录模块的子结构框图。
具体实施方式
为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明进行进一步详细说明,应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。
如图1所示,本发明实施例提供一种基于Qt图形界面软件的操作日志记录方法,所述基于Qt图形界面软件的操作日志记录方法包括如下步骤:
S1、采集用户在界面上对Qt控件操作时,Qt界面所产生的操作事件;
可选的,如图2所示,所述步骤S1包括以下子步骤:
S11、用户开始运行Qt图形界面的软件时,触发计时器计时;
S12、用户在界面上对Qt控件的操作会生成操作事件,在计时超过阈值后,对Qt操作事件进行记录监控,并停止计时;Qt操作事件包含Qt事件的操作内容和发起该Qt事件的Qt控件。
在软件刚开始运行时,由于Qt控件的应用框架尚未完全加载而运行不稳定,立刻就开始监控Qt事件可能会造成软件崩溃,所以需要在软件运行一段时间使Qt框架运行稳定后再监控Qt消息。通过使用计时器计算软件的运行时间,且设置一个稳定运行的阈值时间,当计时器到达阈值时间值时,认为Qt控件框架已运行稳定,可以开始Qt事件的监控。
具体的,在对Qt事件信息进行记录监控时,使用以下函数:
QCoreApplication::instance->installEventFilter(this),
从而将Qt图形界面产生的所有事件重定向进行记录监控。
S2、根据事件的内容判断Qt事件信息的类型,Qt操作事件的类型分为鼠标事件和键盘事件;
可选地,如图3所示,所述步骤S2包括以下子步骤:
S21、从Qt事件中记录三种类型的事件:鼠标点击事件、鼠标释放事件、键盘输入事件;
S22、将鼠标点击事件、鼠标释放事件归类为鼠标事件,将键盘输入事件归类为键盘事件;
S23、按照鼠标事件和键盘事件的划分,对发起鼠标点击事件、鼠标释放事件的Qt控件进行第一类存储,对发起键盘输入事件的Qt控件进行第二类存储。
具体的,通过对记录监控中的Qt事件信息采用以下过滤函数,获得鼠标或键盘操作事件。所述过滤函数为:
eventFilter(QObject*obj,QEvent*event),
其中,obj对象即为Qt控件;Event对象即为事件对象。
S3、分析用户使用鼠标对Qt控件的操作,获得Qt控件信息并形成鼠标操作日志数据;
可选地,如图4所示,所述步骤S3包括以下子步骤:
S31、对第一类存储的Qt控件进行解析,如果解析成功,则进入步骤S32;如果解析失败,则进入步骤S33;
S32、获取Qt控件信息,Qt控件信息包括Qt控件的类型、编码名称和Qt控件的执行功能,以及Qt控件所处的界面路径,将获得的Qt控件信息形成鼠标操作日志数据;
S33、获取Qt控件的类型和编码名称,生成鼠标操作异常日志数据。
S4、分析用户使用键盘对Qt控件输入指令,获得Qt控件信息并形成键盘输入日志数据;
可选地,如图5所示,所述步骤S4包括以下子步骤:
S41、对第二类存储的Qt控件进行解析,如果解析成功,则进入步骤S42;如果解析失败,则进入步骤S45;
S42、获取Qt控件信息,Qt控件信息包括Qt控件的类型、编码名称和Qt控件中存储的输入值,以及Qt控件所处的界面路径;
S43、将发起此次键盘输入事件的Qt控件与发起上一次键盘输入事件的Qt控件进行比较,判断两次键盘输入是否为对针对同一Qt控件的连续输入;如果是,则不将获得的Qt控件信息形成键盘输入日志数据;如果不是,则进入步骤S44;
S44、将获得的Qt控件信息形成键盘输入日志数据;
S45、获取Qt控件的类型和编码名称,生成键盘输入异常日志数据。
具体的,通过分析所记录的obj对象,获得Qt控件的类型、名称,界面路径、Qt控件的执行功能或Qt控件中存储的输入值。方法如下:
Qt控件类型的获得方法为调用函数:
控件类型=obj->metaObject()->className()。
Qt控件名称的获得方法为调用函数:
控件名称=obj->objectName()。
进一步的,针对不同类型Qt控件的操作,应该采用不同的方法获得操作结果,包括:
(1)QGroupBox控件,操作结果为该控件的标题信息;
(2)QPushButton、QRadioButton、QCheckBox和QToolBox控件,操作结果为控件的文本信息;
(3)QMenu、QComboBox、QToolButton和QTabWidget控件,操作结果为控件中所选择数据项的文本信息;
(4)QTreeWidget、QListWidget和QTableWidget控件,获取鼠标在控件上点击的数据项,操作结果为该数据项的文本信息;
(5)QInputDialog控件,操作结果为该控件的窗口标题;(6)QLineEdit,QSpinBox和QDoubleSpinBox控件,操作结果为该控件中存储的文本信息。
其中,所述Qt控件的界面路径即为Qt控件所处在的图形界面的名称;如果图形界面包含有子界面,则界面路径还包含Qt控件所在子界面的名称;如果Qt控件处于某一QGroupBox控件中,则界面路径还包含Qt控件所在QGroupBox控件的名称。
S5、将鼠标操作日志数据和键盘输入日志数据压缩为日志数据包,并将日志数据包进行文件记录。
可选地,如图6所示,所述步骤S5包括以下子步骤:
S51、将鼠标操作日志数据、鼠标操作异常日志数据、键盘输入日志数据以及键盘输入异常日志数据进行压缩,生成日志数据包;
S52、将日志数据包写入日志缓存区;
S53、当日志缓存区存储的日志数据大小超过阈值时,则将日志缓存区的数据包写入日志文件,并清空日志缓存区。
通过设置日志缓冲区,使获得的日志数据没有立刻写入磁盘文件,而是先存入内存的缓冲区中,待内存中的日志数据积累到一定程度后,再一次性将多个日志数据写入到文件并清空缓冲区,从而防止频繁的写磁盘文件造成的系统运行缓慢。
具体的,所述日志数据包中包括鼠标操作日志数据和鼠标操作异常日志数据、或键盘操作日志数据和键盘输入异常日志数据、日志数据大小、系统当前时间、计算机网络地址、操作类型、是否异常数据。
图7为本发明实施例所述的基于Qt图形界面软件的操作日志记录方法的工作流程示意图。详细流程如下所示:
步骤1.1:用户开始运行Qt图形界面的软件时,开始计时;然后进入步骤1.2。
步骤1.2:判断系统运行的时间是否超过设定阈值,如果超过;进入步骤1.3。
步骤1.3:对Qt事件进行采集,并停止计时,进入步骤1.4。
步骤1.4:从Qt事件信息中记录三种类型的事件:鼠标点击事件、鼠标释放事件、键盘输入事件;进入步骤1.5。
步骤1.5:将鼠标点击事件、鼠标释放事件归类为鼠标事件;进入步骤1.7。
步骤1.6:将键盘输入事件归类为键盘事件;进入步骤1.10。
步骤1.7:对第一类存储的Qt控件进行解析;进入步骤1.8。
步骤1.8:如果解析成功,获取Qt控件信息,Qt控件信息包括Qt控件的类型、编码名称和Qt控件的执行功能,以及Qt控件所处的界面路径,将获得的Qt控件信息形成鼠标操作日志数据;进入步骤1.15。
步骤1.9:如果解析失败,获取Qt控件的类型和编码名称,生成鼠标操作异常日志数据,进入步骤1.15。
步骤1.10:对第二类存储的Qt控件进行解析,进入步骤1.11。
步骤1.11:如果解析成功,获取Qt控件信息,Qt控件信息包括Qt控件的类型、编码名称和Qt控件中存储的输入值,以及Qt控件所处的界面路径;
步骤1.12:将发起此次键盘输入事件的Qt控件与发起上一次键盘输入事件的Qt控件进行比较,判断两次键盘输入是否为对针对同一Qt控件的连续输入;进入步骤1.13。
步骤1.13:如果是,不将获得的Qt控件信息形成键盘输入日志数据;如果不是,将获得的Qt控件信息形成键盘输入日志数据;进入步骤1.15。
步骤1.14:如果解析失败,获取Qt控件的类型和编码名称,生成键盘输入异常日志数据;进入步骤1.15。
步骤1.15:将鼠标操作日志数据、鼠标操作异常日志数据、键盘输入日志数据以及键盘输入异常日志数据进行压缩,生成日志数据包;进入步骤1.16。
步骤1.16:将日志数据包写入日志缓存区;进入步骤1.17。
步骤1.17:当日志缓存区存储的数据大小超过阈值时,则将日志缓存区的数据包写入日志文件,并清空日志缓存区;完成操作日志的记录。
本发明公开一种基于Qt图形界面软件的操作日志记录方法及系统,通过对用户在Qt图形界面上对Qt控件操作而产生的操作事件进行采集和处理,首先将Qt操作事件的类型分为鼠标事件和键盘事件;然后根据事件的信息分析用户使用鼠标对Qt控件的操作,获得Qt控件信息并形成鼠标操作日志数据;根据监控用户使用键盘对Qt控件输入指令,获得Qt控件信息并形成键盘输入日志数据;最后将鼠标操作日志数据和键盘输入日志数据压缩为日志数据包,并将日志数据包进行文件记录。因此,本发明通过采集和分析用户在操作Qt控件时Qt图形界面所产生的事件,获得用户在操作鼠标或键盘时所处理Qt控件的名称、类型、位置等信息,并通过Qt控件信息得到该控件实现的具体功能,从而为快速记录软件系统的用户操作日志提供了途径。
如图8所示,本发明还提供一种基于Qt图形界面的软件操作日志的记录系统,其包括以下模块,
事件采集模块,用于捕获和记录用户在界面上对Qt控件操作时界面产生的Qt事件,事件分类模块,用于根据事件的内容判断Qt事件信息的类型,Qt操作事件的类型分为鼠标事件和键盘事件;
鼠标日志模块,用于监控用户使用鼠标对Qt控件的操作,获得Qt控件信息并形成鼠标操作日志数据;
键盘日志模块,用于监控用户使用键盘对Qt控件输入指令,获得Qt控件信息并形成键盘输入日志数据;
文件记录模块,用于将鼠标操作日志数据和键盘输入日志数据压缩为日志数据包,并将日志数据包进行文件记录。
其中,如图9所示,事件采集模块中包含以下单元:
触发计时单元,用于在用户开始运行Qt图形界面的软件时,触发计时器计时;
记录监控单元,用于在用户在界面上对Qt控件的操作生成Qt事件,在计时超过阈值后,对Qt事件进行记录监控,并停止计时;Qt操作事件包含Qt事件的操作内容和发起该事件的Qt控件。
其中,如图10所示,事件分类模块中包含以下单元:
类型捕获单元,用于从Qt事件信息中记录三种类型的事件:鼠标点击事件、鼠标释放事件、键盘输入事件;
分类规整单元,用于将鼠标点击事件、鼠标释放事件归类为鼠标事件,将键盘输入事件归类为键盘事件;
控件存储单元,用于按照鼠标事件和键盘事件的划分,对发起鼠标点击事件、鼠标释放事件的Qt控件进行第一类存储,对发起键盘输入事件的Qt控件进行第二类存储。
其中,如图11所示,鼠标日志模块中包含以下单元:
第一类控件解析单元,用于对第一类存储的Qt控件进行解析,如果解析成功,则将信息发送给日志生成单元;如果解析失败,则将信息发送给异常日志生成单元;
鼠标日志生成单元,用于获取Qt控件信息,Qt控件信息包括Qt控件的类型、编码名称和Qt控件的执行功能,以及Qt控件所处的界面路径,将获得的Qt控件信息形成鼠标操作日志数据。
鼠标异常日志生成单元,用于获取Qt控件的类型和编码名称,生成鼠标操作异常日志数据,
其中,如图12所示,键盘日志模块中包含以下单元:
第二类控件解析单元,用于对第二类存储的Qt控件进行解析,如果解析成功,则将信息发送给信息获取单元;如果解析失败,则将信息发送给键盘异常日志生成单元;
信息获取单元,用于获取Qt控件信息,Qt控件信息包括Qt控件的类型、编码名称和Qt控件中存储的输入值,以及Qt控件所处的界面路径;
控件比较单元,用于将发起此次键盘输入事件的Qt控件与发起上一次键盘输入事件的Qt控件进行比较,判断两次键盘输入是否为对针对同一Qt控件的连续输入;如果是,则不将获得的Qt控件信息形成键盘输入日志数据;如果不是,则将信息发送给键盘日志生成单元;
键盘日志生成单元,用于将获得的Qt控件信息形成键盘输入日志数据;
键盘异常日志生成单元,用于获取Qt控件的类型和编码名称,生成键盘输入异常日志数据。
其中,如图13所示,文件记录模块中包含以下单元:
日志压缩单元,用于将鼠标操作日志数据、鼠标操作异常日志数据、键盘输入日志数据以及键盘输入异常日志数据进行压缩,生成日志数据包;
日志缓存单元,用于将日志数据包写入日志缓存区;
日志文件写入单元,用于当日志缓存区存储的日志数据大小超过阈值时,则将日志缓存区的数据包写入日志文件,并清空日志缓存区。
以上装置实施例与方法实施例是一一对应的,装置实施例简略之处,参见方法实施例即可。
本说明书中各个实施例采用递进的方式描述,每个实施例重点说明的都是与其他实施例的不同之处,各个实施例之间相同相似部分互相参见即可。
专业人员还可以进一步意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能性一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应超过本发明的范围。
结合本文中所公开的实施例描述的方法或算法的步骤可以直接用硬件、处理器执行的软件模块,或者二者的结合来实施。软件模块可以置于随机储存器、内存、只读存储器、电可编程ROM、电可檫除可编程ROM、寄存器、硬盘、可移动磁盘、CD-ROM、或技术领域内所公知的任意其他形式的存储介质中。
上面结合附图对本发明的实施例进行了描述,但是本发明并不局限于上述的具体实施方式,上述的具体实施方式仅仅是示意性的,而不是限制性的,本领域的普通技术人员在本发明的启示下,在不脱离本发明宗旨和权利要求所保护的范围情况下,还可做出很多形式,这些均属于本发明的保护之内。

Claims (8)

1.一种基于Qt图形界面软件的操作日志记录方法,其特征在于:所述基于Qt图形界面软件的操作日志记录方法包括如下步骤:
S1、采集用户在Qt图形界面上对Qt控件操作时,界面所产生的Qt操作事件;
S2、根据事件的内容判断Qt事件信息的类型,Qt操作事件的类型分为鼠标事件和键盘事件;
S3、根据鼠标事件分析用户使用鼠标对Qt控件的操作,获得Qt控件信息并形成鼠标操作日志数据;
S4、根据键盘事件分析用户使用键盘对Qt控件输入指令,获得Qt控件信息并形成键盘输入日志数据;
S5、将鼠标操作日志数据和键盘输入日志数据压缩为日志数据包,并将日志数据包进行文件记录;
其中,所述步骤S1包括以下子步骤:
S11、用户开始运行Qt图形界面的软件时,触发计时器计时;
S12、用户在界面上对Qt控件的操作会生成操作事件,在计时超过阈值后,对Qt操作事件信息进行记录监控,并停止计时;Qt操作事件包含Qt事件的操作内容和发起该事件的Qt控件。
2.根据权利要求1所述的基于Qt图形界面软件的操作日志记录方法,其特征在于,所述步骤S2包括以下子步骤:
S21、从Qt事件中记录三种类型的事件:鼠标点击事件、鼠标释放事件、键盘输入事件;
S22、将鼠标点击事件、鼠标释放事件归类为鼠标事件,将键盘输入事件归类为键盘事件;
S23、按照鼠标事件和键盘事件的划分,对发起鼠标点击事件、鼠标释放事件的Qt控件进行第一类存储,对发起键盘输入事件的Qt控件进行第二类存储。
3.根据权利要求2所述的基于Qt图形界面软件的操作日志记录方法,其特征在于,所述步骤S3包括以下子步骤:
S31、对第一类存储的Qt控件进行解析,如果解析成功,则进入步骤S32;如果解析失败,则进入步骤S33;
S32、获取Qt控件信息,Qt控件信息包括Qt控件的类型、编码名称和Qt控件的执行功能,以及Qt控件所处的界面路径,将获得的Qt控件信息形成鼠标操作日志数据;
S33、获取Qt控件的类型和编码名称,生成鼠标操作异常日志数据。
4.根据权利要求3所述的基于Qt图形界面软件的操作日志记录方法,其特征在于,所述步骤S4包括以下子步骤:
S41、对第二类存储的Qt控件进行解析,如果解析成功,则进入步骤S42;如果解析失败,则进入步骤S45;
S42、获取Qt控件信息,Qt控件信息包括Qt控件的类型、编码名称和Qt控件中存储的输入值,以及Qt控件所处的界面路径;
S43、将发起此次键盘输入事件的Qt控件与发起上一次键盘输入事件的Qt控件进行比较,判断两次键盘输入是否为对针对同一Qt控件的连续输入;如果是,则不将获得的Qt控件信息形成键盘输入日志数据;如果不是,则进入步骤S44;
S44、将获得的Qt控件信息形成键盘输入日志数据;
S45、获取Qt控件的类型和编码名称,生成键盘输入异常日志数据。
5.根据权利要求4所述的基于Qt图形界面软件的操作日志记录方法,其特征在于,所述步骤S5包括以下子步骤:
S51、将鼠标操作日志数据、鼠标操作异常日志数据、键盘输入日志数据以及键盘输入异常日志数据进行压缩,生成日志数据包;
S52、将日志数据包写入日志缓存区;
S53、当日志缓存区存储的日志数据大小超过阈值时,则将日志缓存区的数据包写入日志文件,并清空日志缓存区。
6.根据权利要求5所述的基于Qt图形界面软件的操作日志记录方法,其特征在于,所述日志数据包中包括鼠标操作日志数据和鼠标操作异常日志数据、键盘操作日志数据和键盘输入异常日志数据、日志数据大小、计算机系统当前时间、计算机网络地址、操作类型、是否异常数据。
7.根据权利要求3或权利要求4所述的基于Qt图形界面软件的操作日志记录方法,其特征在于,所述Qt控件的界面路径为Qt控件所处在的图形界面的名称。
8.一种基于Qt图形界面的软件操作日志的记录系统,其特征在于,包括以下模块,
事件采集模块,用于捕获和记录用户在界面上对Qt控件操作时界面产生的Qt事件;
事件分类模块,用于根据事件的内容判断Qt事件的类型,Qt操作事件的类型分为鼠标事件和键盘事件;
鼠标日志模块,用于监控用户使用鼠标对Qt控件的操作,获得Qt控件信息并形成鼠标操作日志数据;
键盘日志模块,用于监控用户使用键盘对Qt控件输入指令,获得Qt控件信息并形成键盘输入日志数据;
文件记录模块,用于将鼠标操作日志数据和键盘输入日志数据压缩为日志数据包,并将日志数据包进行文件记录;
其中,事件采集模块中包含以下单元:
触发计时单元,用于在用户开始运行Qt图形界面的软件时,触发计时器计时;
记录监控单元,用于在用户在界面上对Qt控件的操作生成Qt事件,在计时超过阈值后,对Qt事件进行记录监控,并停止计时;Qt操作事件包含Qt事件的操作内容和发起该事件的Qt控件。
CN201510629301.5A 2015-09-29 2015-09-29 基于Qt图形界面软件的操作日志记录方法及系统 Active CN105607985B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201510629301.5A CN105607985B (zh) 2015-09-29 2015-09-29 基于Qt图形界面软件的操作日志记录方法及系统

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201510629301.5A CN105607985B (zh) 2015-09-29 2015-09-29 基于Qt图形界面软件的操作日志记录方法及系统

Publications (2)

Publication Number Publication Date
CN105607985A CN105607985A (zh) 2016-05-25
CN105607985B true CN105607985B (zh) 2018-02-06

Family

ID=55987937

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201510629301.5A Active CN105607985B (zh) 2015-09-29 2015-09-29 基于Qt图形界面软件的操作日志记录方法及系统

Country Status (1)

Country Link
CN (1) CN105607985B (zh)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107621989A (zh) * 2017-09-13 2018-01-23 联想(北京)有限公司 一种信息处理方法及装置
CN109144300B (zh) * 2018-07-27 2021-12-21 中国船舶重工集团公司第七0九研究所 一种多用途远程鼠键控制方法及系统
CN109829458B (zh) * 2019-01-14 2023-04-04 上海交通大学 实时自动生成记录系统操作行为的日志文件的方法
CN111104301B (zh) * 2019-12-03 2021-08-20 深圳市联谛信息无障碍有限责任公司 一种在网页中判断障碍用户的方法和系统
CN113961110A (zh) * 2020-07-01 2022-01-21 腾讯科技(深圳)有限公司 用户操作响应方法、装置、计算机设备和存储介质
CN116302621A (zh) * 2023-05-19 2023-06-23 杭州实在智能科技有限公司 基于qt界面库的信创环境元素拾取方法及系统

Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5321838A (en) * 1991-02-28 1994-06-14 Hensley Billy W Event capturing for computer software evaluation
CN101241466A (zh) * 2007-02-08 2008-08-13 深圳迈瑞生物医疗电子股份有限公司 一种嵌入式软件的测试方法和系统
CN102981861A (zh) * 2012-12-12 2013-03-20 上海航天测控通信研究所 一种基于Qt的自定义控件的使用方法
CN102999322A (zh) * 2011-09-16 2013-03-27 深圳市吉阳自动化科技有限公司 一种工业控制器软件界面设计方法
CN103309794A (zh) * 2013-04-16 2013-09-18 北京航空航天大学 一种基于数据采集与关键字挖掘的自动日志生成系统及方法
CN103530218A (zh) * 2013-10-09 2014-01-22 韩金倡 一种基于行为检测的监控触发方法
CN103970533A (zh) * 2014-04-14 2014-08-06 深圳市深信服电子科技有限公司 屏幕录制的信息记录方法及装置
CN104598282A (zh) * 2015-02-05 2015-05-06 广州华多网络科技有限公司 一种控件捕捉方法和设备

Patent Citations (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5321838A (en) * 1991-02-28 1994-06-14 Hensley Billy W Event capturing for computer software evaluation
CN101241466A (zh) * 2007-02-08 2008-08-13 深圳迈瑞生物医疗电子股份有限公司 一种嵌入式软件的测试方法和系统
CN102999322A (zh) * 2011-09-16 2013-03-27 深圳市吉阳自动化科技有限公司 一种工业控制器软件界面设计方法
CN102981861A (zh) * 2012-12-12 2013-03-20 上海航天测控通信研究所 一种基于Qt的自定义控件的使用方法
CN103309794A (zh) * 2013-04-16 2013-09-18 北京航空航天大学 一种基于数据采集与关键字挖掘的自动日志生成系统及方法
CN103530218A (zh) * 2013-10-09 2014-01-22 韩金倡 一种基于行为检测的监控触发方法
CN103970533A (zh) * 2014-04-14 2014-08-06 深圳市深信服电子科技有限公司 屏幕录制的信息记录方法及装置
CN104598282A (zh) * 2015-02-05 2015-05-06 广州华多网络科技有限公司 一种控件捕捉方法和设备

Also Published As

Publication number Publication date
CN105607985A (zh) 2016-05-25

Similar Documents

Publication Publication Date Title
CN105607985B (zh) 基于Qt图形界面软件的操作日志记录方法及系统
US8326987B2 (en) Method for adaptively building a baseline behavior model
Cameron et al. Emergency situation awareness from twitter for crisis management
CN104183027B (zh) 一种用户状态确定方法及装置
CN104699807B (zh) 一种oracle数据表空间的自动监控扩容方法
GB2581676A (en) Device, system, and method of detecting vishing attacks
CN107222472A (zh) 一种Hadoop集群下的用户行为异常检测方法
CN108228377A (zh) 一种面向磁盘故障检测的smart阈值优化方法
US20190079965A1 (en) Apparatus and method for real time analysis, predicting and reporting of anomalous database transaction log activity
CN106371986A (zh) 一种日志处理运维监控系统
CN103488507A (zh) 一种用户行为轨迹回放方法
CN106792456A (zh) 数据分析系统和方法
TW201019104A (en) System and method for detecting behavior anomaly in information access
CN101188523A (zh) 告警相关性规则的生成方法及生成系统
CN102216908A (zh) 支援执行对应于检测事件的动作的系统、支援执行对应于检测事件的动作的方法、支援装置以及计算机程序
CN108734201B (zh) 基于分层原因分析法的核电厂经验反馈事件的分类方法及系统
CN109871963A (zh) 运行故障还原方法、装置、电子设备及存储介质
US11245747B2 (en) Monitoring a building management system
CN104133915B (zh) 一种数据库管理员运维行为的监控方法及系统
CN107239457A (zh) 数据归档方法及装置
US20050188269A1 (en) System and method for providing a health model for software
CN107423110A (zh) 一种基于libvirt的虚拟机实时监测方法及其装置
CN114579646A (zh) 一种多维数据展示平台的可视化控制方法、装置及设备
CN104123217A (zh) 一种业务服务器执行命令的捕获方法及系统
CN111342994A (zh) 网络管理系统和方法

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
GR01 Patent grant
GR01 Patent grant