日志输出方法、装置、电子设备及存储介质制造方法及图纸

技术编号:38221634 阅读:13 留言:0更新日期:2023-07-25 17:53
本申请实施例提供了一种日志输出方法、装置、电子设备及存储介质,该方法包括:获取目标操作函数对应的功能描述信息;根据所述功能描述信息,生成第一编码指令,并将所述第一编码指令以注解方式填充在所述目标操作函数对应的第二编码指令之外的预设位置处,其中,所述第一编码指令为基于模板模式实现的编码指令;在所述目标操作函数被调用的过程中,根据所述第一编码指令,输出目标日志数据,其中,所述目标日志数据反映所述目标操作函数当前被调用所执行的业务操作。所执行的业务操作。所执行的业务操作。

【技术实现步骤摘要】
日志输出方法、装置、电子设备及存储介质


[0001]本公开实施例涉及计算机
,更具体地,涉及一种日志输出方法、装置、电子设备及计算机可读存储介质。

技术介绍

[0002]在业务系统中,为了验证系统的运行是否正常,通常会在业务系统中对应操作函数执行的过程中,添加用于输出该操作函数所执行的操作信息的操作日志,其中,操作日志是用于记录用户在使用业务系统时所执行的操作行为的日志。
[0003]在目前的业务系统中,用于输出操作日志的编码指令通常与用于实现具体业务逻辑的编码指令紧密耦合在一起,这容易增加业务系统中业务逻辑的复杂性,不利于系统编码的开发和维护。

技术实现思路

[0004]本公开的一个目的是提供一种用于日志输出的新的技术方案,以方便、简洁的在业务系统中输出操作日志。
[0005]根据本公开的第一方面,提供了日志输出方法的一个实施例,包括:
[0006]获取目标操作函数对应的功能描述信息;
[0007]根据所述功能描述信息,生成第一编码指令,并将所述第一编码指令以注解方式填充在所述目标操作函数对应的第二编码指令之外的预设位置处,其中,所述第一编码指令为基于模板模式实现的编码指令;
[0008]在所述目标操作函数被调用的过程中,根据所述第一编码指令,输出目标日志数据,其中,所述目标日志数据反映所述目标操作函数当前被调用所执行的业务操作。
[0009]可选地,所述根据所述功能描述信息,生成第一编码指令,包括:
[0010]获取基于模板模式实现的、用于进行日志输出的目标注解日志函数;
[0011]根据所述功能描述信息,获得所述目标注解日志函数的目标参数,以生成所述第一编码指令。
[0012]可选地,所述根据所述功能描述信息,获得所述目标注解日志函数的目标参数,包括:
[0013]将所述功能描述信息作为所述目标参数。
[0014]可选地,所述根据所述功能描述信息,获得所述目标注解日志函数的目标参数,包括:
[0015]获取所述目标操作函数的参数信息;
[0016]根据所述参数信息,生成用于动态描述所述目标操作函数所执行操作的目标描述对象;
[0017]根据所述功能描述信息和所述目标描述对象,生成所述目标参数。
[0018]可选地,所述第一预设函数用于根据所述参数信息,获取所述目标操作函数所操
作对象的原始内容,所述第二预设函数用于根据所述参数信息,获取所述目标操作函数所操作对象的变更后内容;
[0019]所述根据所述功能描述信息和所述目标描述对象,生成所述目标参数,包括:
[0020]从所述参数信息中,获取第一参数和第二参数;
[0021]将所述第一参数作为所述第一预设函数的参数,以基于所述第一预设函数获取所述原始内容;
[0022]将所述第二参数作为所述第二预设函数的参数,以基于所述第二预设函数获取所述变更后内容;
[0023]拼接所述功能描述信息、所述第一预设函数和所述第二预设函数,以生成所述目标参数。
[0024]可选地,所述在所述目标操作函数被调用的过程中,根据所述第一编码指令,输出目标日志数据,包括:
[0025]在所述目标操作函数被调用的过程中,基于所述第二编码指令,在缓存中生成反映所述目标操作函数当前被调用所执行的业务操作的待输出日志数据;
[0026]获取所述目标操作函数的执行状态;
[0027]根据所述执行状态和所述待输出日志数据,生成并输出所述目标日志数据。
[0028]可选地,所述预设位置包括所述第二编码指令之前的位置;
[0029]所述在所述目标操作函数被调用的过程中,基于所述第二编码指令,在缓存中生成反映所述目标操作函数当前被调用所执行的业务操作的待输出日志数据,包括:
[0030]在执行所述目标操作函数对应的所述第二编码指令之前,对所述第一编码指令开启注解解析,并在所述第二编码指令中包含动态的目标描述对象的情况下,对所述目标描述对象进行模板解析,以生成所述待输出日志数据。
[0031]根据本公开的第二方面,提供了日志输出装置的一个实施例,包括:
[0032]获取模块,用于获取目标操作函数对应的功能描述信息;
[0033]编码指令设置模块,用于根据所述功能描述信息,生成第一编码指令,并将所述第一编码指令以注解方式填充在所述目标操作函数对应的第二编码指令之外的预设位置处,其中,所述第一编码指令为基于模板模式实现的编码指令;
[0034]日志输出模块,用于在所述目标操作函数被调用的过程中,根据所述第一编码指令,输出目标日志数据,其中,所述目标日志数据反映所述目标操作函数当前被调用所执行的业务操作。
[0035]根据本公开的第三方面,提供了电子设备的一个实施例,包括如本公开第二方面所述的装置;或者,
[0036]所述电子设备包括:
[0037]存储器,用于存储可执行的指令;
[0038]处理器,用于根据所述指令的控制运行所述电子设备执行如本公开第一方面所述的日志输出方法。
[0039]根据本公开的第四方面,提供了计算机可读存储介质的一个实施例,所述计算机可读存储介质存储有可被计算机读取执行的计算机程序,所述计算机程序用于在被所述计算机读取运行时,执行如公开的第一方面所述的日志输出方法。
[0040]本公开实施例的一个有益效果在于,根据本公开的实施例,通过获取目标操作函数对应的功能描述信息;并根据该功能描述信息,生成第一编码指令,通过将基于模板模式实现的第一编码指令填充在目标操作函数对应的第二编码指令之外的预设位置处,使得电子设备在目标操作函数被调用的过程中,可以根据第一编码指令,输出目标日志数据。本公开的实施例提供的方法通过基于模板模式设计第一编码指令,可以将用于进行日志输出的第一编码指令和用于处理业务逻辑的第二编码指令解耦合,从而在实现电子设备正常输出目标操作日志的同时,还不增加业务系统业务逻辑的复杂性,进而可以降低系统开发和维护成本。
[0041]通过以下参照附图对本说明书的示例性实施例的详细描述,本说明书的其它特征及其优点将会变得清楚。
附图说明
[0042]被结合在说明书中并构成说明书的一部分的附图示出了本说明书的实施例,并且连同其说明一起用于解释本说明书的原理。
[0043]图1是本公开实施例提供的一种日志输出方法的流程示意图。
[0044]图2是本公开实施例提供的日志输出装置的方框原理图。
[0045]图3是本公开实施例提供的一种电子设备的硬件结构示意图。
具体实施方式
[0046]现在将参照附图来详细描述本公开的各种示例性实施例。应注意到:除非另外具体说明,否则在这些实施例中阐述的部件和步骤的相对布置、数字表达式和数值不限制本专利技术的范围。
[0047]以下对至少一个示例性实施例的描述实际上仅仅是说明性的,决不作为对本专利技术及其应用或使用本文档来自技高网
...

【技术保护点】

【技术特征摘要】
1.一种日志输出方法,其特征在于,包括:获取目标操作函数对应的功能描述信息;根据所述功能描述信息,生成第一编码指令,并将所述第一编码指令以注解方式填充在所述目标操作函数对应的第二编码指令之外的预设位置处,其中,所述第一编码指令为基于模板模式实现的编码指令;在所述目标操作函数被调用的过程中,根据所述第一编码指令,输出目标日志数据,其中,所述目标日志数据反映所述目标操作函数当前被调用所执行的业务操作。2.根据权利要求1所述的方法,其特征在于,所述根据所述功能描述信息,生成第一编码指令,包括:获取基于模板模式实现的、用于进行日志输出的目标注解日志函数;根据所述功能描述信息,获得所述目标注解日志函数的目标参数,以生成所述第一编码指令。3.根据权利要求2所述的方法,其特征在于,所述根据所述功能描述信息,获得所述目标注解日志函数的目标参数,包括:将所述功能描述信息作为所述目标参数。4.根据权利要求2所述的方法,其特征在于,所述根据所述功能描述信息,获得所述目标注解日志函数的目标参数,包括:获取所述目标操作函数的参数信息;根据所述参数信息,生成用于动态描述所述目标操作函数所执行操作的目标描述对象;根据所述功能描述信息和所述目标描述对象,生成所述目标参数。5.根据权利要求4所述的方法,其特征在于,所述目标描述对象包括第一预设函数和第二预设函数,其中,所述第一预设函数用于根据所述参数信息,获取所述目标操作函数所操作对象的原始内容,所述第二预设函数用于根据所述参数信息,获取所述目标操作函数所操作对象的变更后内容;所述根据所述功能描述信息和所述目标描述对象,生成所述目标参数,包括:从所述参数信息中,获取第一参数和第二参数;将所述第一参数作为所述第一预设函数的参数,以基于所述第一预设函数获取所述原始内容;将所述第二参数作为所述第二预设函数的参数,以基于所述第二预设函数获取所述变更后内容;拼接所述功能描述信息、所述第一预设函数和所述第二预设函数,以生成所述目标参数。6.根据权利要求1...

【专利技术属性】
技术研发人员:陈勇辉
申请(专利权)人:北京金山云网络技术有限公司
类型:发明
国别省市:

网友询问留言 已有0条评论
  • 还没有人留言评论。发表了对其他浏览者有用的留言会获得科技券。

1