CN110716846B - 一种基于区块链的模块间调用日志记录方法及系统 - Google Patents
一种基于区块链的模块间调用日志记录方法及系统 Download PDFInfo
- Publication number
- CN110716846B CN110716846B CN201910952405.8A CN201910952405A CN110716846B CN 110716846 B CN110716846 B CN 110716846B CN 201910952405 A CN201910952405 A CN 201910952405A CN 110716846 B CN110716846 B CN 110716846B
- Authority
- CN
- China
- Prior art keywords
- log data
- blockchain
- module
- data
- modules
- 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
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/30—Monitoring
- G06F11/34—Recording or statistical evaluation of computer activity, e.g. of down time, of input/output operation ; Recording or statistical evaluation of user activity, e.g. usability assessment
- G06F11/3466—Performance evaluation by tracing or monitoring
- G06F11/3476—Data logging
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/24—Querying
- G06F16/245—Query processing
- G06F16/2458—Special types of queries, e.g. statistical queries, fuzzy queries or distributed queries
- G06F16/2465—Query processing support for facilitating data mining operations in structured databases
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/901—Indexing; Data structures therefor; Storage structures
- G06F16/9024—Graphs; Linked lists
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/62—Protecting access to data via a platform, e.g. using keys or access control rules
- G06F21/6218—Protecting access to data via a platform, e.g. using keys or access control rules to a system of files or objects, e.g. local or distributed file system or database
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Databases & Information Systems (AREA)
- General Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Software Systems (AREA)
- Computer Hardware Design (AREA)
- Probability & Statistics with Applications (AREA)
- Mathematical Physics (AREA)
- Fuzzy Systems (AREA)
- Computational Linguistics (AREA)
- Quality & Reliability (AREA)
- Computing Systems (AREA)
- Health & Medical Sciences (AREA)
- Bioethics (AREA)
- General Health & Medical Sciences (AREA)
- Computer Security & Cryptography (AREA)
- Debugging And Monitoring (AREA)
Abstract
本发明公开了一种基于区块链的模块间调用日志记录方法及系统,属于计算机领域,本发明要解决的技术问题为如何防止模块间调用日志数据丢失、被非法篡改,从而提高调用日志数据的完整性和可信度,为异常定位提供可靠的依据,采用的技术方案为:该方法步骤如下:S1、部署区块链平台:在服务器上搭建一个去中心化的区块链数据库;S2、调用日志写链:模块间发生相互调用时,会将调用日志数据进行写链,从而保证数据的安全性和完整性;S3、异常定位:当模块间数据交互出现问题时,通过对比区块链上两个组织的日志数据来迅速定位异常模块;S4、日志数据挖掘。该系统包括区块链平台部署单元、调用日志写链单元、异常定位单元及日志数据挖掘单元。
Description
技术领域
本发明涉及计算机领域,具体涉及模块间调用日志记录系统的实现方式,具体地说是一种基于区块链的模块间调用日志记录方法及系统。
背景技术
软件的架构正在逐步趋于模块化,模块化就是将程序划分为多个易于处理的单元,每个模单元是一组方法的集合,通过模块间的互相协作完成整个功能。模块化是复用的基础、是合作的基础、是分层的基础,会使整个程序更加灵活。由于模块间有频繁的调用,调用失败的情况时有发生,而且失败的原因也多种多样,可以分为以下几种:
(1)、调用方发送异常:调用指令发送失败;
(2)、发送网络异常:调用方指令已发送,但指令丢失;
(3)、被调用方接收异常:没接收到指令;
(4)、被调用方回传异常:响应信息没有发送成功;
(5)、回传网络异常:已回传,但丢失;
(6)、调用方接收异常:没有接收到。
当模块间调用失败时,一般会通过分析调用日志的方式来定位问题出现的位置。但是基于中心化系统的传统日志存储方案会存在如下问题:
①、日志存储在传统的集中数据库中,易丢失,容易破坏日志数据的完整性,模块调用失败时无迹可寻;
②、模块间调用日志由中心库集中存储,可非法篡改的概率非常大,线上事故追责时,日志证据不可信。
综上所述,如何防止模块间调用日志数据丢失、被非法篡改,从而提高调用日志数据的完整性和可信度,为异常定位提供可靠的依据是目前现有技术中亟待解决的问题。
发明内容
本发明的技术任务是提供一种基于区块链的模块间调用日志记录方法及系统,来解决如何防止模块间调用日志数据丢失、被非法篡改,从而提高调用日志数据的完整性和可信度,为异常定位提供可靠的依据的问题。
本发明的技术任务是按以下方式实现的,一种基于区块链的模块间调用日志记录方法,该方法步骤如下:
S1、部署区块链平台:在服务器上搭建一个去中心化的区块链数据库,复杂软件系统中的每个模块是注册在区块链上的组织,每个模块都可以看成一个用户,用户具有区块链数据库读写权限;
S2、调用日志写链:模块间发生相互调用时,会将调用日志数据进行写链,从而保证数据的安全性和完整性;
S3、异常定位:当模块间数据交互出现问题时,通过对比区块链上两个组织的日志数据来迅速定位异常模块;
S4、日志数据挖掘:通过对日志数据的分析,针对单个模块进行优化,进而提升整个系统的性能。区块数据公示需要搭建区块链浏览器。
作为优选,所述步骤S1中的部署区块链平台包括编写智能合约,智能合约封装了日志数据写链的操作,只要模块间发生了交互,就满足了智能合约的触发条件,合约就被执行,数据就被写到区块链上。
作为优选,所述步骤S2中调用日志数据进行写链的前提是软件系统中的各个模块先要创建基于私钥的区块链身份,保障用户隐私和权益。
更优地,所述步骤S2中的调用日志数据通过日志记录智能合约上传到区块链上,将原始调用日志数据锁在链上,同时能够根据上链时间作为确权依据。
更优地,所述步骤S2中调用日志数据包括调用时间、被调用模块名称、被调用方法、被调用模块响应时间及响应数据。
作为优选,所述步骤S3中异常定位具体是:
模块间调用日志数据被完整的记录在区块链上,当模块间调用失败时,基于调用日志数据的完整性和不可篡改性,区块链上记录的日志会成为异常定位最直接的信息源,也为调用异常引起的线上事故定责,提供最有效的证据。
一种基于区块链的模块间调用日志记录系统,该系统包括,
区块链平台部署单元,用于在服务器上搭建一个去中心化的区块链数据库,复杂软件系统中的每个模块是注册在区块链上的组织,每个模块都可以看成一个用户,用户具有区块链数据库读写权限;
调用日志写链单元,用于模块间发生相互调用时,会将调用日志数据进行写链,从而保证数据的安全性和完整性;
异常定位单元,用于当模块间数据交互出现问题时,通过对比区块链上两个组织的日志数据来迅速定位异常模块;
日志数据挖掘单元,用于通过对日志数据的分析,针对单个模块进行优化,进而提升整个系统的性能。
作为优选,所述部署区块链平台单元包括智能合约编写单元,智能合约编写单元封装了日志数据写链的操作,只要模块间发生了交互,就满足了智能合约的触发条件,合约就被执行,数据就被写到区块链上。
作为优选,所述调用日志数据进行写链的前提是软件系统中的各个模块先要创建基于私钥的区块链身份,保障用户隐私和权益;调用日志数据通过日志记录智能合约上传到区块链上,将原始调用日志数据锁在链上,同时能够根据上链时间作为确权依据;调用日志数据包括调用时间、被调用模块名称、被调用方法、被调用模块响应时间及响应数据。
更优地,所述异常定位单元具体用于模块间调用日志数据被完整的记录在区块链上,当模块间调用失败时,基于调用日志数据的完整性和不可篡改性,区块链上记录的日志会成为异常定位最直接的信息源,也为调用异常引起的线上事故定责,提供最有效的证据。
本发明的基于区块链的模块间调用日志记录方法及系统具有以下优点:
(一)、本发明有效防止模块间调用日志数据丢失、被非法篡改,从而提高调用日志数据的完整性和可信度,为异常定位提供可靠的依据;
(二)、本发明部署的区块链是一种去中心化的分布式存储技术,具有可信、不可篡改等特性,基于区块链的这些特性,有针对性的用于模块间调用日志存储相关的业务场景,区块链的每个节点都会记录一份调用日志数据,个别的节点发起的数据修改不会生效,大大提高了数据可信度;区块链会使用一段代码去执行各项逻辑,而且代码公开可阅读,确保了逻辑的公平公正,由于代码执行时没有人为的干预,也加大了篡改数据的难度;基于区块链的技术优势,可有效解决可信问题,从而保证日志数据的完整性和可信任性;
(三)、本发明记录在区块链上的日志数据完整且不可篡改,基于此可以挖掘出哪些模块被调用的频率较高,哪些模块在整个调用链路中响应时间较慢等信息,从而针对单个模块进行优化,进而提升整个系统的性能;
(四)、基于区块链的技术优势,模块间调用日志数据采用智能合约的形式,提高数据可信度;
(五)、基于区块链的技术优势,模块间调用日志数据多节点分布式存储,降低了单点数据丢失破坏数据完整性的问题;
附图说明
下面结合附图对本发明进一步说明。
附图1为基于区块链的模块间调用日志记录方法的流程框图;
附图2为基于区块链的模块间调用日志记录系统的结构框图。
具体实施方式
参照说明书附图和具体实施例对本发明的一种基于区块链的模块间调用日志记录方法及系统作以下详细地说明。
实施例1:
如附图1所示,本发明的基于区块链的模块间调用日志记录方法,该方法步骤如下:
S1、部署区块链平台:在服务器上搭建一个去中心化的区块链数据库,复杂软件系统中的每个模块是注册在区块链上的组织,每个模块都可以看成一个用户,用户具有区块链数据库读写权限;
S2、调用日志写链:模块间发生相互调用时,会将调用日志数据进行写链,从而保证数据的安全性和完整性;
S3、异常定位:当模块间数据交互出现问题时,通过对比区块链上两个组织的日志数据来迅速定位异常模块;
S4、日志数据挖掘:通过对日志数据的分析,针对单个模块进行优化,进而提升整个系统的性能。区块数据公示需要搭建区块链浏览器。
其中,步骤S1中的部署区块链平台包括编写智能合约,智能合约封装了日志数据写链的操作,只要模块间发生了交互,就满足了智能合约的触发条件,合约就被执行,数据就被写到区块链上。
步骤S2中调用日志数据进行写链的前提是软件系统中的各个模块先要创建基于私钥的区块链身份,保障用户隐私和权益;调用日志数据通过日志记录智能合约上传到区块链上,将原始调用日志数据锁在链上,同时能够根据上链时间作为确权依据;调用日志数据包括调用时间、被调用模块名称、被调用方法、被调用模块响应时间及响应数据。
步骤S3中异常定位具体是:模块间调用日志数据被完整的记录在区块链上,当模块间调用失败时,基于调用日志数据的完整性和不可篡改性,区块链上记录的日志会成为异常定位最直接的信息源,也为调用异常引起的线上事故定责,提供最有效的证据。
实施例2:
如附图2所示,本发明的基于区块链的模块间调用日志记录系统,该系统包括,
区块链平台部署单元,用于在服务器上搭建一个去中心化的区块链数据库,复杂软件系统中的每个模块是注册在区块链上的组织,每个模块都可以看成一个用户,用户具有区块链数据库读写权限;部署区块链平台单元包括智能合约编写单元,智能合约编写单元封装了日志数据写链的操作,只要模块间发生了交互,就满足了智能合约的触发条件,合约就被执行,数据就被写到区块链上。
调用日志写链单元,用于模块间发生相互调用时,会将调用日志数据进行写链,从而保证数据的安全性和完整性;调用日志数据进行写链的前提是软件系统中的各个模块先要创建基于私钥的区块链身份,保障用户隐私和权益;调用日志数据通过日志记录智能合约上传到区块链上,将原始调用日志数据锁在链上,同时能够根据上链时间作为确权依据;调用日志数据包括调用时间、被调用模块名称、被调用方法、被调用模块响应时间及响应数据。
异常定位单元,用于当模块间数据交互出现问题时,通过对比区块链上两个组织的日志数据来迅速定位异常模块;异常定位单元具体用于模块间调用日志数据被完整的记录在区块链上,当模块间调用失败时,基于调用日志数据的完整性和不可篡改性,区块链上记录的日志会成为异常定位最直接的信息源,也为调用异常引起的线上事故定责,提供最有效的证据。
日志数据挖掘单元,用于通过对日志数据的分析,针对单个模块进行优化,进而提升整个系统的性能。
最后应说明的是:以上各实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述各实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的范围。
Claims (2)
1.一种基于区块链的模块间调用日志记录方法,其特征在于,该方法步骤如下:
S1、部署区块链平台:在服务器上搭建一个去中心化的区块链数据库,复杂软件系统中的每个模块是注册在区块链上的组织,每个模块都可以看成一个用户,用户具有区块链数据库读写权限;其中,部署区块链平台包括编写智能合约,智能合约封装了日志数据写链的操作,只要模块间发生了交互,就满足了智能合约的触发条件,合约就被执行,数据就被写到区块链上;
S2、调用日志写链:模块间发生相互调用时,会将调用日志数据进行写链,从而保证数据的安全性和完整性;其中,调用日志数据进行写链的前提是软件系统中的各个模块先要创建基于私钥的区块链身份,保障用户隐私和权益;调用日志数据通过日志记录智能合约上传到区块链上,将原始调用日志数据锁在链上,同时能够根据上链时间作为确权依据;调用日志数据包括调用时间、被调用模块名称、被调用方法、被调用模块响应时间及响应数据;
S3、异常定位:当模块间数据交互出现问题时,通过对比区块链上两个组织的日志数据来迅速定位异常模块;具体是:
模块间调用日志数据被完整的记录在区块链上,当模块间调用失败时,基于调用日志数据的完整性和不可篡改性,区块链上记录的日志会成为异常定位最直接的信息源,也为调用异常引起的线上事故定责,提供最有效的证据;
S4、日志数据挖掘:通过对日志数据的分析,针对单个模块进行优化,进而提升整个系统的性能。
2.一种基于区块链的模块间调用日志记录系统,其特征在于,该系统包括,
区块链平台部署单元,用于在服务器上搭建一个去中心化的区块链数据库,复杂软件系统中的每个模块是注册在区块链上的组织,每个模块都可以看成一个用户,用户具有区块链数据库读写权限;其中,部署区块链平台单元包括智能合约编写单元,智能合约编写单元封装了日志数据写链的操作,只要模块间发生了交互,就满足了智能合约的触发条件,合约就被执行,数据就被写到区块链上;
调用日志写链单元,用于模块间发生相互调用时,会将调用日志数据进行写链,从而保证数据的安全性和完整性;其中,调用日志数据进行写链的前提是软件系统中的各个模块先要创建基于私钥的区块链身份,保障用户隐私和权益;调用日志数据通过日志记录智能合约上传到区块链上,将原始调用日志数据锁在链上,同时能够根据上链时间作为确权依据;调用日志数据包括调用时间、被调用模块名称、被调用方法、被调用模块响应时间及响应数据;
异常定位单元,用于当模块间数据交互出现问题时,通过对比区块链上两个组织的日志数据来迅速定位异常模块;其中,异常定位单元具体用于模块间调用日志数据被完整的记录在区块链上,当模块间调用失败时,基于调用日志数据的完整性和不可篡改性,区块链上记录的日志会成为异常定位最直接的信息源,也为调用异常引起的线上事故定责,提供最有效的证据;
日志数据挖掘单元,用于通过对日志数据的分析,针对单个模块进行优化,进而提升整个系统的性能。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910952405.8A CN110716846B (zh) | 2019-10-09 | 2019-10-09 | 一种基于区块链的模块间调用日志记录方法及系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910952405.8A CN110716846B (zh) | 2019-10-09 | 2019-10-09 | 一种基于区块链的模块间调用日志记录方法及系统 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110716846A CN110716846A (zh) | 2020-01-21 |
CN110716846B true CN110716846B (zh) | 2023-08-04 |
Family
ID=69212356
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910952405.8A Active CN110716846B (zh) | 2019-10-09 | 2019-10-09 | 一种基于区块链的模块间调用日志记录方法及系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN110716846B (zh) |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN114398668A (zh) * | 2021-12-14 | 2022-04-26 | 中国民用航空飞行学院 | 一种基于区块链的民航隐私数据保护储存系统 |
CN114564749B (zh) * | 2022-03-04 | 2022-12-23 | 厦门熙重电子科技有限公司 | 一种针对智慧云服务的用户信息保护方法及服务器 |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109656778A (zh) * | 2018-11-28 | 2019-04-19 | 金蝶软件(中国)有限公司 | 数据获取方法、装置、计算机设备和存储介质 |
CN109951340A (zh) * | 2019-04-01 | 2019-06-28 | 山东浪潮云信息技术有限公司 | 一种运用区块链进行服务调用存证的系统及方法 |
CN109992492A (zh) * | 2019-04-11 | 2019-07-09 | 苏州浪潮智能科技有限公司 | 功能模块的日志记录方法、装置、设备及可读存储介质 |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10320566B2 (en) * | 2017-04-04 | 2019-06-11 | International Business Machines Corporation | Distributed logging of application events in a blockchain |
-
2019
- 2019-10-09 CN CN201910952405.8A patent/CN110716846B/zh active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109656778A (zh) * | 2018-11-28 | 2019-04-19 | 金蝶软件(中国)有限公司 | 数据获取方法、装置、计算机设备和存储介质 |
CN109951340A (zh) * | 2019-04-01 | 2019-06-28 | 山东浪潮云信息技术有限公司 | 一种运用区块链进行服务调用存证的系统及方法 |
CN109992492A (zh) * | 2019-04-11 | 2019-07-09 | 苏州浪潮智能科技有限公司 | 功能模块的日志记录方法、装置、设备及可读存储介质 |
Also Published As
Publication number | Publication date |
---|---|
CN110716846A (zh) | 2020-01-21 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN108520464B (zh) | 一种基于传统区块链的实时自动化监管报告系统 | |
CN110716846B (zh) | 一种基于区块链的模块间调用日志记录方法及系统 | |
US10057285B2 (en) | System and method for auditing governance, risk, and compliance using a pluggable correlation architecture | |
US7765460B2 (en) | Out-of-band change detection | |
US9953100B2 (en) | Automated runtime command replacement in a client-server session using recorded user events | |
CN110474870B (zh) | 基于区块链的网络主动防御方法、系统及计算机可读存储介质 | |
CN2917099Y (zh) | 用于关键任务计算机系统的“三容”式数字黑匣子 | |
US11115804B2 (en) | Subscription to dependencies in smart contracts | |
CN105260314A (zh) | 内存泄漏的监测方法 | |
CN111444262A (zh) | 一种基于区块链的电力数据的共享系统 | |
CN101388033A (zh) | 基于Windows系统文件变更事件的文件保护技术 | |
CN112214802B (zh) | 一种区块链智能合约消息发布订阅方法 | |
CN113162950A (zh) | 一种基于i国网的移动应用二次权限认证与管理系统 | |
CN104536892B (zh) | 一种软件在线调试方法和系统 | |
CN103023651B (zh) | 用于监控可移动设备的接入的方法和装置 | |
Wolf et al. | Bend, don’t break: Using reconfiguration to achieve survivability | |
CN109254863A (zh) | 一种记录系统事件日志的方法、装置及受控终端 | |
CN112181793B (zh) | 一种日志记录方法、装置及设备 | |
CN115473712B (zh) | 一种云安全服务安全管理平台及云安全服务管理方法 | |
Wang et al. | Research on survivability strategic of operating system | |
CN112860269A (zh) | 一种基于微服务的分布式向量生成系统及方法 | |
CN117540391A (zh) | 一种基于区块链技术的信息系统安全监理方法及应用 | |
CN115270199A (zh) | 一种物流数据防篡改方法及系统 | |
CN117971621A (zh) | 一种进程管理方法及计算设备 | |
Caricato et al. | TIPS: A Zero-Downtime Platform Powered by Automation |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
TA01 | Transfer of patent application right | ||
TA01 | Transfer of patent application right |
Effective date of registration: 20200721 Address after: 250100 No. 1036 Tidal Road, Jinan High-tech Zone, Shandong Province, S01 Building, Tidal Science Park Applicant after: Inspur cloud Information Technology Co.,Ltd. Address before: 250100 Room 3110, S01 Building, Tidal Building, 1036 Tidal Road, Jinan High-tech Zone, Shandong Province Applicant before: Shandong Aicheng Network Information Technology Co.,Ltd. |
|
GR01 | Patent grant | ||
GR01 | Patent grant |