WO2012130009A1 - 一种软件中的模块修复方法及装置 - Google Patents

一种软件中的模块修复方法及装置 Download PDF

Info

Publication number
WO2012130009A1
WO2012130009A1 PCT/CN2012/071682 CN2012071682W WO2012130009A1 WO 2012130009 A1 WO2012130009 A1 WO 2012130009A1 CN 2012071682 W CN2012071682 W CN 2012071682W WO 2012130009 A1 WO2012130009 A1 WO 2012130009A1
Authority
WO
WIPO (PCT)
Prior art keywords
module
software
content
abnormal
detecting
Prior art date
Application number
PCT/CN2012/071682
Other languages
English (en)
French (fr)
Inventor
马远真
李宝生
陶伟华
Original Assignee
北京奇虎科技有限公司
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 北京奇虎科技有限公司 filed Critical 北京奇虎科技有限公司
Priority to US14/008,278 priority Critical patent/US20140310560A1/en
Publication of WO2012130009A1 publication Critical patent/WO2012130009A1/zh

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/14Error detection or correction of the data by redundancy in operation
    • G06F11/1479Generic software techniques for error detection or fault masking
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0793Remedial or corrective actions
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/07Responding to the occurrence of a fault, e.g. fault tolerance
    • G06F11/0703Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation
    • G06F11/0706Error or fault processing not based on redundancy, i.e. by taking additional measures to deal with the error or fault not making use of redundancy in operation, in hardware, or in data representation the processing taking place on a specific hardware platform or in a specific software environment
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F11/00Error detection; Error correction; Monitoring
    • G06F11/36Preventing errors by testing or debugging software
    • G06F11/3668Software testing
    • G06F11/3672Test management
    • G06F11/3688Test management for test execution, e.g. scheduling of test suites
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • G06F8/656Updates while running

Definitions

  • the present application relates to electronic computer technology, and in particular to a module repair method and apparatus in software. Background technique
  • PCs PCs
  • PDAs PDAs
  • mobile phones etc. to engage in online activities such as browsing the web, chatting on the Internet, and viewing emails. Wait.
  • a software tool such as a browser, a chat tool, or a mailbox client
  • a software tool such as a browser
  • a chat tool such as a chat tool
  • a mailbox client When using a software tool such as a browser, a chat tool, or a mailbox client, once a module in a software tool (such as a browser) that the user is using is damaged or an exception occurs, the user cannot continue to use the module. In severe cases, it is not even possible to use the entire software tool (such as a browser). If the user wants to continue using this software tool, the usual practice is: Re-download the software tool, but install it again. In this way, the operation is relatively cumbersome, which brings inconvenience to the user. And if the user is using a software tool (such as a browser) to engage in important or urgent matters, if the software tool is abnormal, it is likely to cause trouble or even loss to the user.
  • the application provides a module repairing method and device in software.
  • the application can self-repair through a network when a module in the software fails, so that the software can be used normally.
  • the application can also perform self-testing on the software through the network, so as to avoid problems such as untimely operation and cumbersome operation caused by manual detection.
  • the present application provides a module repair method in software.
  • the method detects an abnormal module in the software and an abnormal content corresponding to the module, and then downloads normal content corresponding to the abnormal content, and retrieves when the abnormal module is used. Corresponding to the normal content of the download.
  • the method further includes: loading the downloaded normal content into the system memory directly; then, when the abnormal module is used, retrieving the corresponding The normal content of the download is: when the abnormal module is used, the corresponding normal content of the download is directly retrieved from the memory.
  • the normal content corresponding to the abnormal content is downloaded in a manner of accessing the web page address.
  • the downloaded normal content is a configuration file and/or a data file.
  • the above detection is a check of the correctness and/or integrity of some or all of the modules of the software.
  • the detecting step comprises the step of scanning a file associated with the software.
  • the scanning step comprises the steps of extracting a feature content portion of the file and generating a current file list.
  • the extracted feature content part adopts a full-text abstraction algorithm.
  • the detecting step further comprises the step of analyzing the current file list according to a standard file list.
  • the analyzing step comprises: matching the current file list with the standard file list, and matching, determining that the software is abnormal, and the module corresponding to the unmatched content is an abnormal module in the software, and the unmatched content is abnormal. content.
  • the analyzing step includes matching the current file list with the standard file list, and determining that the software is abnormal when the current file list lacks one or more contents of the standard file list, and the missing
  • the module corresponding to the content is an exception module in the software, and the missing content is an abnormal content.
  • the above list of standard files includes a feature content portion of the correct file, and a download address including the correct file.
  • the method further includes: saving the correct data directory locally, and searching for the download address of the downloaded normal content according to the directory.
  • the detecting comprises: detecting the software locally.
  • the detecting comprises: requesting detection of the software by accessing a webpage address.
  • the requesting to detect the software by accessing a webpage address comprises: downloading an analysis function for detecting the software abnormality by using a webpage address; and detecting the software by using the analysis function.
  • the method before requesting to detect the software by accessing a webpage address, the method further includes: determining whether the software is normal; if the software is abnormal, requesting the software by accessing a webpage address The detection is performed; or, according to the detection instruction issued by the user, the software is requested to be detected by accessing the webpage address.
  • the present application provides a module repair device in software.
  • the device includes a detection module, an acquisition module, and a repair module.
  • the detecting module is configured to detect an abnormal module in the software and an abnormal content corresponding to the module when the module in the software is abnormal;
  • the acquiring module is configured to download normal content corresponding to the abnormal content;
  • the repair module Configured to use the difference When the normal module is used, the corresponding normal content of the download is retrieved.
  • the device further includes: a saving module configured to directly load the downloaded normal content into the system memory; and the repair module directly retrieves the corresponding content from the memory when using the abnormal module The normal content of the download.
  • a saving module configured to directly load the downloaded normal content into the system memory
  • the repair module directly retrieves the corresponding content from the memory when using the abnormal module The normal content of the download.
  • the obtaining module downloads normal content corresponding to the abnormal content in a manner of accessing a webpage address.
  • the detection module comprises a scanning module and an analysis module.
  • the scanning module is configured to scan a file related to the software, scan each file, extract a feature content part of the file, and generate a current file list;
  • the analysis module is configured to list the standard file and the current file list Matching, and when one or more items in the current file list do not match the corresponding content in the standard file list, or when the current file list lacks one or more items in the standard file list And determining that the software is abnormal, and the module corresponding to the unmatched content or the missing content is an abnormal module in the software, and the unmatched content or the missing content is abnormal content.
  • the detecting module is a first detecting module, and the first detecting module locally detects the software.
  • the detecting module is a second detecting module, requesting to detect the software by accessing a webpage address, and the second detecting module downloads an analysis function for detecting the software abnormality by using a webpage address, and using the The analysis function detects the software.
  • the method further includes a determining module configured to determine whether the software is normal; if the software is abnormal, the second detecting module is configured to access a webpage address The mode requesting to detect the software; or, according to the detection instruction sent by the user, the second detecting module requests to detect the software by accessing a webpage address.
  • the present application provides a computer readable recording medium having recorded thereon a program for executing a module repairing method in the software.
  • this application is capable of self-repairing an erroneous module in the software without requiring the user to go to the network. Find and download the correct version of the software and install it, which is convenient for users and saves time. And if the software is maliciously attacked by a virus or the like, since the normal content obtained by the application is directly loaded into the memory without being saved to the local, the normal content in the memory is not easily destroyed by the virus, and the stability is better. And the normal content is loaded directly into memory without saving to the local, this way the execution is faster.
  • the application can also perform self-testing on the software without manual inspection, so that errors can be found more timely and accurately, and the user experience is better.
  • FIG. 1 is a flowchart of a self-repair method in software according to an embodiment of the present application
  • FIG. 2 is a flowchart of a browser self-repair method according to an embodiment of the present application
  • FIG. 3 is a block diagram of a self-repairing software device according to an embodiment of the present application.
  • FIG. 4 is a flowchart of a software self-detection method according to another embodiment of the present application.
  • FIG. 5 is a flowchart of a browser self-detection method according to another embodiment of the present application.
  • FIG. 6 is a block diagram of a self-testing software device of another embodiment of the present application.
  • FIG. 7 is a flowchart of a module repairing method in a software according to another embodiment of the present application
  • FIG. 8 is a structural diagram of a module repairing apparatus in a software according to another embodiment of the present application
  • FIG. 10 is a structural diagram of a module repairing device in a software according to another preferred embodiment of the present application. detailed description
  • step 110 when the module in the software is in error, the correct content corresponding to the erroneous content is obtained by accessing the webpage address.
  • step 120 the obtained correct content is directly loaded into the system memory, and is not saved to the local, and the correct content is directly retrieved from the memory when the module is used.
  • the software Since the above step 10 0 is to acquire the correct content corresponding to the error content in a network manner (that is, in a manner of accessing a web page address). Therefore, the software has a self-healing function that does not require manual repair. And because the above step 120 is to load the obtained correct content into the system memory, it does not need to be saved locally. Therefore, the software performs faster and has better stability. When the software is attacked by a virus and its module is destroyed, this embodiment loads the correct content into the memory without saving to the local mode, so that the correct The content is not destroyed by the virus, which in turn ensures that the browser can be used normally.
  • the above-described loading of the correct content obtained into the system memory is a preferred implementation.
  • the obtained correct content may be first saved to the local hard disk, and when the abnormal module is used, the corresponding correct content is read from the hard disk, loaded into the memory, and then adjusted from the memory. take.
  • the software described in this embodiment may be any software device such as a browser, a chat tool, or a mailbox client.
  • Figure 2 is a browser, for example, to further illustrate the software repair method of Figure 1.
  • FIG. 2 is a flow chart of a self-repair method of a browser according to an embodiment of the present application.
  • the following steps 21 0 to 250 are a specific embodiment for detecting the browser and finding an error module in the browser when the browser is in error.
  • the present application is not limited to this detection method.
  • the browser scans all files associated with the browser, including scanning all files in the browser installation directory, system files, configuration files, data files, and the like associated with the browser.
  • a system file associated with the browser is a ur lmon. dl l file
  • a data file associated with the browser is a .d t file.
  • the file is extracted using the md5 algorithm.
  • the feature content portion of the feature content, and the feature content is capable of uniquely identifying the file. It should be noted that the feature content in the extracted file is not limited to the md5 algorithm, and any full-text digest algorithm such as CRC, md2, md3, or md4 may be used.
  • the browser also obtains the version number, file size, and the like of the file.
  • a current file list is generated, and the current file list contains the feature content of each file.
  • the current file list further includes a file version number, a file size, and the like, and the feature content of each file and its version number, file size, and the like are stored correspondingly.
  • the browser analyzes the current file list based on the list of standard files to check if the browser is in error.
  • the standard file list includes the feature content of the correct file. And, the standard file list can be backed up locally in advance.
  • step 250 if one or more items in the current file list do not match the corresponding content in the standard file list, or when one or more of the standard file list is missing in the current file list.
  • the content of the item indicates that the corresponding module in the browser is in error, and the module corresponding to the "mismatched file” or “missing file” is the faulty module in the browser, the "mismatched file” or “missing file” " That is the error content. Therefore, this step is a check of the correctness and/or integrity of the module in the browser to find the faulty module in the browser.
  • the correctness check generally refers to checking whether the file version number, the file size, and the like are consistent with the corresponding content in the standard file list.
  • the integrity check generally refers to checking whether the contents of the file have been tampered with by a full-text digest algorithm.
  • step 260 if the browser is in error, according to the error module in the browser obtained in step 250, the browser acquires the correct content corresponding to the error content by accessing the webpage address.
  • the acquired content is a configuration file and/or a data file.
  • the list of standard files described in steps 240, 250 includes, in addition to the feature content of the correct file, the download address of the correct file. Therefore, step 260 can be downloaded from the server through the network according to the download address and by accessing the webpage address. The correct content corresponding to the error content.
  • the correct data directory can also be saved locally and the download address of the correct content can be found based on the directory.
  • the download address is saved to the directory in the form of data storage of the file. Therefore, step 260 downloads the correct content corresponding to the above erroneous content from the server through the network by accessing the webpage address according to the download address.
  • step 270 the browser loads the acquired content directly into the system memory without saving it locally, and directly retrieves the correct content from the memory when the module is used.
  • the application is not limited to detecting whether the browser itself is in error or not, and the server of the browser may detect whether the browser is in error, and then send the detection result to the browser.
  • the detection method is the same as the detection method in the above steps 210 to 250, and details are not described herein again.
  • the software device 300 includes a first detection module 310, an acquisition module 320, and a first repair module 330.
  • the software device 300 is a browser.
  • the first detecting module 310 is configured to detect the software, and find a module that has been erroneous in the software when the software is in error.
  • the first detection module 310 is a check of the correctness and/or integrity of some or all of the software.
  • the obtaining module 320 acquires the correct content corresponding to the erroneous content by accessing the webpage address according to the erroneous module obtained by the first detecting module 310.
  • the content acquired by the obtaining module 320 is a configuration file and/or a data file.
  • the first repair module 330 is configured to load the acquired correct content directly into the system memory without saving it locally, and directly retrieve the correct content from the memory when using the module.
  • FIG. 4 is a flow chart of a software self-test method according to another embodiment of the present application.
  • the software is requested to be detected in a manner that accesses the web page address.
  • step 420 when a module error in the software is detected, the corresponding error portion is repaired.
  • the embodiment can perform self-detection on the software without manual inspection, the error can be found more accurately and timely, and the user experience is better.
  • the application software may be any software device such as a browser, a chat tool, or a mailbox client.
  • Figure 5 is a diagram illustrating the software repair method of Figure 4 using a browser as an example.
  • FIG. 5 is a flowchart of a browser self-detection method according to another embodiment of the present application.
  • the browser can perform self-test on a regular basis (such as one week), or it can perform self-test every time it is turned on, and can also perform self-test according to the detection instruction issued by the user.
  • the browser obtains an analysis function provided by the web page address to detect if it is in error.
  • the analysis function is a function obtained by editing the javascr ipt language provided by ur l.
  • the browser uses the analysis function to detect if it is normal, and such detection is a check of the correctness and/or integrity of some or all of the modules of the browser.
  • the specific inspection method is:
  • the standard file list includes the feature content of the correct file, preferably Also, including the download address of the correct content;
  • step 530 when the browser detects an error, the browser repairs the corresponding error portion.
  • the browser obtains the correct content corresponding to the erroneous content by accessing the webpage address. More preferably, the browser loads the correct content directly into the system memory, does not store it locally, and retrieves the correct content directly from memory when the module is used.
  • the software before the software is requested to be accessed by accessing the webpage address, it may be determined in advance whether the software is normal. If the software is abnormal, the software is requested to be detected by accessing the webpage address; or the software may be requested to be detected by accessing the webpage address according to the detection instruction sent by the user. Wherein, the software can be used to determine whether the software is normal. If the content in the registry is modified, the software is abnormal.
  • this kind of judgment is a relatively simple error judgment, and it cannot accurately locate each erroneous module and corresponding error content, and software detection by the analysis function can do this.
  • the software device 600 includes a request detection module 610, a second detection module 620, and a second repair module 630.
  • the software device 600 is a browser.
  • the request detection module 610 requests the software to be checked by accessing the web page address. Further, the request detection module 610 implements the inspection of the software by obtaining an analysis function provided by the web page address for detecting the software error.
  • the second detecting module 620 is configured to detect whether the software is normal, and if the software is abnormal, request to detect the software by accessing a webpage address; or request the software by accessing a webpage address according to a detection instruction issued by the user. Test.
  • the second detecting module 620 It is a check of the correctness and completeness of some or all of the modules of the software.
  • the second repair module 630 repairs the corresponding error portion when detecting a module error in the software.
  • the second repair module 630 acquires the correct content corresponding to the erroneous content in a manner of accessing the webpage address, so as to repair the erroneous part. Further, the second repair module 630 loads the acquired content directly into the system memory and saves it locally, and directly retrieves the correct content from the memory when the module is used.
  • Step 710 When an abnormality occurs in a module in the software, detecting an abnormal module in the software and an abnormal content corresponding to the module;
  • the exception indicates the error
  • the exception module indicates the wrong module
  • the abnormal content indicates the wrong content.
  • the detection is performed by detecting the software locally, and when an abnormality of the software is detected, an abnormal module in the software is found, and an automatic repair is performed;
  • the software is requested to be detected by accessing the web page address.
  • an analysis function for detecting the software abnormality is downloaded through a webpage address, and the software is detected by the analysis function.
  • the software is detected by the analysis function.
  • it may be determined in advance whether the software is normal. If the software is abnormal, the software is requested to be detected by accessing the webpage address; or, according to the detection instruction issued by the user, the software is requested to be detected by accessing the webpage address.
  • the standard file list includes the feature content of the correct file, preferably, Also includes the download address of the correct content;
  • Step 720 Download the correct content corresponding to the abnormal content.
  • the correct content is normal content.
  • the normal content corresponding to the abnormal content can be downloaded in a manner of accessing the web page address.
  • Step 730 retrieve corresponding correct content when using the abnormal module.
  • the downloaded correct content can also be directly loaded into the system memory, and then the corresponding correct content is directly retrieved from the memory when the error module is used.
  • FIG. 8 it is a structural diagram of a module repair device in a software according to an embodiment of the present application.
  • the module repair device 800 in the software may include the following modules:
  • the detecting module 810 is configured to: when an abnormality occurs in a module in the software, detect an abnormal module in the software and an abnormal content corresponding to the module;
  • the obtaining module 820 is configured to download the correct content corresponding to the abnormal content; and the repairing module 830 is configured to retrieve the corresponding correct content when the abnormal module is used.
  • the device may further include:
  • the saving module 840 is configured to directly load the downloaded correct content into the system memory; then the repair module 830 directly retrieves the corresponding correct content from the memory when the abnormal module is used.
  • the acquiring module downloads the normal content corresponding to the abnormal content by accessing a webpage address.
  • the detecting module 810 may include a scanning module 81 1 and an analyzing module 812: the scanning module 811 is configured to scan a file related to the software, and extract a feature portion in the file for each file scanned, and Generate a list of current files;
  • the analyzing module 812 is configured to match the standard file list with the current file list, when matching, or when the current file list lacks one or more contents of the standard file list, determining that the software is abnormal, and The module corresponding to the unmatched content or the missing content is an abnormal module in the software, and the unmatched content or the missing content is abnormal content.
  • the detecting module 810 can be a first detecting module 910, and the first detecting module 910 locally detects the software.
  • the detecting module 810 may also be the second detecting module 110, requesting to detect the software by accessing a webpage address.
  • the second detecting module 110 downloads an analysis function for detecting the software abnormality through a webpage address, and detects the software by using the analysis function.
  • the following modules may also be included:
  • the determining module 150 is configured to determine whether the software is normal
  • the second detecting module 110 requests to detect the software by accessing the webpage address; or, according to the detecting instruction sent by the user, the second detecting module 110 uses the method of accessing the webpage address. Request to test the software.
  • the present application also provides a computer readable recording medium having recorded thereon a program for executing the module repairing method in the above software.
  • the content of the module repairing method in the software can be referred to the content described in the embodiments of FIG. 1 , FIG. 2 and FIG. 4 , FIG. 5 and FIG. 7 , and details are not described herein again.
  • the computer readable recording medium includes any mechanism for storing or transmitting information in a form readable by a computer (eg, a computer).
  • a machine-readable medium includes a read only memory (ROM), a random access memory (RAM), a magnetic disk storage medium, an optical storage medium, a flash storage medium, an electrical, optical, acoustic, or other form of propagated signal (eg, a carrier wave) , infrared signals, digital signals, etc.).
  • the present application is not limited to use only in a PC (Personal Computer), but also in various electronic devices such as a PDA (PDA), a mobile phone, and the like.
  • the information transmission method of the present application may be wired or wireless.
  • the application can be described in the general context of computer-executable instructions executed by a computer, such as a program module.
  • program modules include routines, programs, objects, components, data structures, and the like that perform particular tasks or implement particular types of abstract data.
  • the present application can also be practiced in a distributed computing environment where tasks are performed by remote processing devices that are connected through a communication network.
  • program modules can be located in both local and remote computer storage media including storage devices.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • General Engineering & Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Quality & Reliability (AREA)
  • Software Systems (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Hardware Design (AREA)
  • Information Transfer Between Computers (AREA)

Description

一种软件中的模块修复方法及装置
技术领域
本申请涉及电子计算机技术, 尤其涉及一种软件中的模块修复方法及装 置。 背景技术
随着电子计算机技术的快速发展, 越来越多的人开始使用 PC机(个人 计算机) 、 PDA (掌上电脑) 、 手机等电子设备上网, 从事网络活动, 如浏 览网页、 网络聊天、 查看电子邮件等。
人们在使用浏览器、 聊天工具或者邮箱客户端等软件工具时, 一旦用户 正在使用的软件工具(如浏览器) 中的某一模块遭到破坏或者发生异常时, 用户就无法继续使用此模块, 严重时甚至无法使用整个软件工具 (如浏览 器) 。 如果用户想要继续使用此种软件工具, 通常的做法是: 重新下载此种 软件工具, 然而再安装。 此种方式, 操作相对繁瑣, 给用户带来了不便。 并 且如果用户正在使用某种软件工具(如浏览器)从事重要或紧急事务时, 若 该软件工具发生异常, 很可能会给用户带来麻烦, 甚至带来损失。
此外, 人们在使用软件工具(如浏览器)时, 一旦软件出错, 只能靠人 工感知, 即通过人眼来发现软件有错误发生。 并且在发现软件出错后, 也不 能智能地对该出错内容进行修复。 此种方式, 由于未能及时检测到软件发生 了错误, 也没有对出错内容作出相应修复, 因此很可能导致软件的崩溃。 并 且此种由人工来感知软件出错并对错误内容进行修复的方式, 操作繁瑣, 给 用户带来了不便。尤其是对于那些初学互联网以及只具有简单互联网知识的 用户来说, 由他们来及时发现软件有错误发生, 某些情况下会存在着一定的 困难。 然而, 如果不能及时发现错误并对错误进行修复, 用户就无法正常使 用该软件工具,从而影响用户通过该软件工具进行正常的学习、工作或娱乐。 发明内容
本申请提供了一种软件中的模块修复方法及装置, 本申请可以在软件中 的模块出错时通过网络方式进行自修复, 从而使该软件能够正常使用。 本申 请还可以通过网络方式对软件进行自检测, 以免人工检测所带来的不及时、 操作繁瑣等问题。
在第一方面, 本申请提供了一种软件中的模块修复方法。 该方法在所述 软件中的模块发生异常时, 检测软件中的异常模块及该模块对应的异常内 容, 然后下载与所述异常内容相对应的正常内容, 并在使用所述异常模块时 调取相应的所述下载的正常内容。
优选地, 所述下载与所述异常内容相对应的正常内容之后, 还包括: 将 该下载到的正常内容直接加载到系统内存中; 则所述在使用所述异常模块时 调取相应的所述下载的正常内容为: 在使用所述异常模块时直接从内存中调 取相应的所述下载的正常内容。
优选地, 以访问网页地址的方式下载与所述异常内容相对应的正常内 容。
优选地, 所述下载到的正常内容为配置文件和 /或数据文件。
优选地, 上述检测是对该软件部分或全部模块的正确性和 /或完整性进 行的检查。
优选地, 上述检测步骤包括扫描与该软件相关文件的步骤。
优选地, 上述扫描步骤包括提取所述文件中的特征内容部分, 并生成当 前文件列表的步骤。
优选地, 上述提取特征内容部分采用全文摘要算法。
优选地, 所述检测步骤还包括根据标准文件列表对所述当前文件列表进 行分析的步骤。 优选地, 上述分析步骤包括将该当前文件列表与标准文件列表将匹配, 匹配时, 判定该软件异常, 并且该不匹配内容所对应的模块为该软件中的异 常模块, 该不匹配内容为异常内容。
优选地, 上述分析步骤包括将该当前文件列表与标准文件列表进行匹 配, 并在该当前文件列表缺少该标准文件列表中的某一项或多项内容时, 判 定该软件异常, 并且该缺少的内容所对应的模块为该软件中的异常模块, 该 缺少的内容为异常内容。
优选地, 上述标准文件列表包括正确文件的特征内容部分, 以及包括该 正确文件的下载地址。
优选地, 所述下载正常内容之前, 还包括: 在本地预置保存正确数据目 录, 并根据该目录查找所述下载正常内容的下载地址。
优选地, 所述检测包括: 在本地对所述软件进行检测。
优选地, 所述检测包括: 以访问网页地址的方式请求对所述软件进行检 测。
优选地, 所述以访问网页地址的方式请求对所述软件进行检测, 包括: 通过网页地址下载用于检测该软件异常的分析函数; 利用该分析函数检测该 软件。
优选地, 所述以访问网页地址的方式请求对所述软件进行检测之前, 还 包括: 判定所述软件是否正常的步骤; 如果所述软件异常, 则以访问网页地 址的方式请求对所述软件进行检测; 或者, 根据用户发出的检测指令, 以访 问网页地址的方式请求对所述软件进行检测。
在第二方面, 本申请提供了一种软件中的模块修复装置。 该装置包括检 测模块、 获取模块和修复模块。 该检测模块配置为在所述软件中的模块发生 异常时, 检测软件中异常的模块及该模块对应的异常内容; 该获取模块配置 为下载与所述异常内容相对应的正常内容; 该修复模块配置为在使用所述异 常模块时调取相应的所述下载的正常内容。
优选地, 所述装置还包括: 保存模块, 配置为将该下载到的正常内容直 接加载到系统内存中; 则所述修复模块在使用所述异常模块时直接从内存中 调取相应的所述下载的正常内容。
优选地, 所述获取模块以访问网页地址的方式下载与所述异常内容相对 应的正常内容。
优选地, 所述检测模块包括扫描模块和分析模块。 该扫描模块配置为扫 描与该软件相关文件的,每扫描一个文件,提取所述文件中的特征内容部分, 并生成当前文件列表; 该分析模块, 配置为将标准文件列表与所述当前文件 列表进行匹配,并在该当前文件列表中某一项或多项内容与标准文件列表中 的相应内容不匹配时,或者在该当前文件列表缺少该标准文件列表中的某一 项或多项内容时, 判定该软件异常, 并且该不匹配内容或缺少的内容所对应 的模块为该软件中的异常模块, 该不匹配内容或缺少的内容为异常内容。
优选地, 所述检测模块为第一检测模块, 所述第一检测模块在本地对所 述软件进行检测。
优选地, 所述检测模块为第二检测模块, 以访问网页地址的方式请求对 所述软件进行检测, 所述第二检测模块通过网页地址下载用于检测该软件异 常的分析函数, 并利用该分析函数检测该软件。
优选地, 当所述检测模块为第二检测模块时, 还包括判定模块, 该判定 模块配置为判定所述软件是否正常; 如果所述软件异常, 则所述第二检测模 块以访问网页地址的方式请求对所述软件进行检测; 或者, 根据用户发出的 检测指令, 所述第二检测模块以访问网页地址的方式请求对所述软件进行检 测。
在第三方面, 本申请提供了一种在其上记录有用于执行所述软件中的模 块修复方法的程序的计算机可读记录介质。
本申请一方面能够对软件中的已出错模块进行自修复, 而无需用户到网 上查找并下载正确版本的软件并安装, 为用户提供了方便, 节约了时间。 并 且如果软件是被病毒等恶意攻击时, 由于本申请是将获取到的正常内容直接 加载到内存中, 而不保存到本地, 因此内存中的正常内容不易被病毒破坏, 稳定性更好。 并且将正常内容直接加载到内存中而不保存到本地, 此种方式 执行速度更快。
本申请另一方面还能够对软件进行自检测, 而无需人工来检查, 因此能 够更加及时准确地发现错误, 用户体验更佳。 附图说明
下面将参照附图对本申请的具体实施方案进行更详细的说明, 在附图 中:
图 1 是本申请一个实施例的软件中自修复方法流程图;
图 2是本申请一个实施例的浏览器自修复方法流程图;
图 3是本申请一个实施例的自修复软件设备框图;
图 4是本申请另一个实施例的软件自检测方法流程图;
图 5是本申请另一个实施例的浏览器自检测方法流程图;
图 6是本申请另一个实施例的自检测软件设备框图;
图 7是本申请另一个实施例所述一种软件中的模块修复方法流程图; 图 8是本申请另一个实施例所述一种软件中的模块修复装置结构图; 图 9 是本申请另一个优选实施例所述一种软件中的模块修复装置结构 图;
图 1 0是本申请另一个优选实施例所述一种软件中的模块修复装置结构 图。 具体实施方式
图 1是本申请一个实施例的软件自修复方法流程图。 在步骤 110 , 软件中的模块出错时, 以访问网页地址的方式获取与所述 出错内容相对应的正确内容。
在步骤 120 , 将该获取到的正确内容直接加载到系统内存中, 而不保存 到本地, 并在使用该模块时直接从内存中调取相应正确内容。
由于上述步骤 11 0是以网络方式(即以访问网页地址的方式)获取与出 错内容相对应的正确内容。 因此该软件具有自修复功能, 无需人工修复。 并 且由于上述步骤 120是将获取到的正确内容加载到系统内存中, 而无需保存 到本地。 因此, 该软件执行速度更快, 且稳定性能更好, 当该软件遭到病毒 攻击而导致其模块被破坏时, 本实施例将正确内容加载到内存而不保存到本 地的方式, 使得该正确内容不被病毒所破坏, 进而保证该浏览器能够正常使 用。
当然, 上述将获取到的正确内容加载到系统内存中是一种优选地实现方 案。 在另一实施例中, 还可以将获取到的正确内容先保存到本地硬盘, 当使 用所述异常模块时再从硬盘读取相应的正确内容, 并加载到内存中, 然后再 从内存中调取。
需要说明的是, 本申请实施例所述的软件可以是浏览器、 聊天工具、 邮 箱客户端等任意一种软件设备。 图 2是以浏览器为例, 对图 1软件修复方法 做进一步阐述。
图 2是本申请一个实施例的浏览器的自修复方法流程图。
以下步骤 21 0到步骤 250是检测浏览器, 并在该浏览器出错时查找到该 浏览器中已出错模块的一个具体实施例, 本申请不限于此种检测方式。
在步骤 210 , 该浏览器扫描与该浏览器相关的所有文件, 包括扫描该浏 览器安装目录下的所有文件、 与该浏览器相关的系统文件、 配置文件、 数据 文件等。 例如, 一个与该浏览器相关的系统文件是 ur lmon. dl l文件, 一个 与该浏览器相关的数据文件是. da t文件。
在步骤 220 , 该浏览器每扫描一个文件, 就会采用 md5算法提取该文件 中的特征内容部分,且该特征内容能够唯一性地标识该文件。需要说明的是, 上述提取文件中的特征内容不限于采用 md5算法,也可以采用 CRC、md2、md3、 md4等任意一种全文摘要算法。
较佳地, 该浏览器还会获取文件的版本号、 文件大小等。
在步骤 230 , 在该浏览器扫描完所有文件后, 生成一个当前文件列表, 且该当前文件列表包含每一文件的特征内容。
较佳地, 该当前文件列表还包含文件版本号、 文件大小等, 且每一文件 的特征内容及其版本号、 文件大小等信息相对应的存放。
在步骤 240 ,该浏览器根据标准文件列表,对该当前文件列表进行分析, 以检查该浏览器是否出错。其中,该标准文件列表包括正确文件的特征内容。 并且, 所述标准文件列表可以预先备份到本地。
在步骤 250, 若该当前文件列表中有某一项或多项内容, 与标准文件列 表中的相应内容不匹配时, 或者当该当前文件列表中缺少该标准文件列表中 的某一项或多项内容时, 说明该浏览器中的相应模块出错, 且该 "不匹配文 件" 或 "缺少文件" 所对应的模块就是该浏览器中的已出错模块, 该 "不匹 配文件" 或 "缺少文件" 即为出错内容。 因此, 此步骤是对该浏览器中模块 的正确性和 /或完整性所作出的检查, 以查找到该浏览器中的已出错模块。
其中, 所述正确性检查通常是指检查文件版本号、 文件大小等信息是否 与标准文件列表中的相应内容一致。所述完整性检查通常是指通过全文摘要 算法检查文件内容是否被篡改过。
在步骤 260 , 若该浏览器出错, 则根据步骤 250得到的该浏览器中的已 出错模块, 该浏览器以访问网页地址方式获取与该出错内容相应的正确内 容。 较佳地, 该获取到的内容为配置文件和 /或数据文件。
在本申请的一个实施例中, 步骤 240、 250 中所述的标准文件列表除包 括正确文件的特征内容之外,还包括该正确文件的下载地址。因此,步骤 260 可以根据该下载地址, 以访问网页地址方式, 通过网络从服务端下载与上述 出错内容相应的正确内容。
在本申请的另一个实施例中, 还可以在本地预置保存正确数据目录, 并 根据该目录查找正确内容的下载地址。 换而言之, 所述下载地址是以文件的 数据存储形式保存到目录下。 因此, 步骤 260根据该下载地址, 以访问网页 地址方式, 通过网络从服务端下载与上述出错内容相应的正确内容。
在步骤 270 , 该浏览器将所获取到的内容直接加载到系统内存中, 而不 将其保存到本地, 在使用该模块时直接从内存中调取相应正确内容。
需要说明的是, 本申请也不限于仅由浏览器来检测其自身是否出错, 还 可以由该浏览器的服务端来检测该浏览器是否出错,再将该检测结果发送至 该浏览器, 具体检测方法与上述步骤 210到步骤 250检测方法相同, 在此不 再赘述。
图 3是本申请一个实施例的自修复软件设备框图。该软件设备 300包括 第一检测模块 310、 获取模块 320、 第一修复模块 330。 一个例子中, 该软件 设备 300为浏览器。
该第一检测模块 310用于检测该软件, 并在该软件出错时查找到该软件 中已出错的模块。 较佳地, 该第一检测模块是 310是对该软件部分或全部模 块的正确性和 /或完整性所进行的检查。
该获取模块 320在该软件中的模块出错时,根据该第一检测模块 310得 到的该已出错模块, 以访问网页地址的方式获取与出错内容相对应的正确内 容。 较佳地, 该获取模块 320所获取到的内容是配置文件和 /或数据文件。
该第一修复模块 330 用于将所获取到的正确内容直接加载到系统内存 中, 而不将其保存到本地, 并在使用该模块时直接从内存中调取相应正确内 容。
上述实施例列举的是通过在本地检测软件,在该软件出错时查找到该软 件中已出错模块的, 并进行自动修复的例子。 除此之外, 还可以请求的方式 对软件进行检测并修复, 具体实施例如图 4所示。 图 4是本申请另一个实施例的软件自检测方法流程图。
在步骤 410 , 以访问网页地址的方式请求对所述软件进行检测。
在步骤 420 , 在检测到该软件中的模块出错时, 对相应出错部分进行修 复。
由于本实施例能够对软件进行自检测, 而无需人工来检查, 因此能够更 加及时准确地发现错误, 用户体验更佳。
需要说明的是, 本申请软件可以是浏览器、 聊天工具、 邮箱客户端等任 意一种软件设备。 图 5是以浏览器为例对图 4软件修复方法做进一步阐述。
图 5是本申请另一个实施例的浏览器自检测方法流程图。
需要说明的是, 该浏览器可以定期(如一个星期)进行自检测, 也可以 在其每次被开启时进行自检测, 还可以根据用户发出的检测指令进行自检 测。
在步骤 510 , 该浏览器获取网页地址提供的用于检测其是否出错的分析 函数。 较佳地, 该分析函数是 ur l提供的 javascr ipt语言编辑得到的函数。
在步骤 520, 该浏览器利用该分析函数检测其是否正常, 且此种检测是 对该浏览器部分或全部模块的正确性和 /或完整性进行的检查。
具体检查方法是:
( 1 )扫描与该浏览器相关的所有文件, 包括配置文件和 /或数据文件, 且每扫描一个文件就会采用全文摘要算法提取该文件中的特征内容部分,且 该特征内容能够唯一性标识该文件;
( 2 )在该分析函数扫描完所有文件后, 生成一个当前文件列表, 且该 当前文件列表包含每一文件的特征内容;
( 3 )根据标准文件列表, 对该当前文件列表进行分析, 以检查该浏览 器是否出错, 并获知该浏览器中的已出错模块; 其中, 该标准文件列表包括 正确文件的特征内容, 较佳地, 还包括该正确内容的下载地址;
( 4 )若该当前文件列表中的某一项或多项内容与标准文件列表中的相 应内容不匹配,或者该当前文件列表中缺少该标准文件列表中的某一项或多 项内容时, 说明该浏览器出错, 并根据匹配结果获知该浏览器中的已出错模 块。
在步骤 530 , 在检测到该浏览器出错时, 该浏览器对相应出错部分进行 修复。
较佳地, 该浏览器以访问网页地址方式获取与出错内容相应的正确内 容。 更佳地, 该浏览器将所获取到的正确内容直接加载到系统内存中, 而不 存储到本地, 并在使用该模块时直接从内存中调取相应正确内容。
在本申请的一个实施例中, 以访问网页地址的方式请求对所述软件进行 检测之前, 还可以预先判定所述软件是否正常。 如果所述软件异常, 则以访 问网页地址的方式请求对所述软件进行检测; 或者, 也可以根据用户发出的 检测指令, 以访问网页地址的方式请求对所述软件进行检测。 其中, 可通过 注册表来判定所述软件是否正常, 如果注册表中的内容被修改, 则表明该软 件异常。
需要说明的是, 这种判定是一种相对简单的出错判定, 并不能十分准确 地定位到每个出错的模块及相应的出错内容, 而利用分析函数进行的软件检 测则可以做到这一点。
图 6是本申请另一个实施例的自检测软件设备框图。该软件设备 600包 括请求检测模块 610、 第二检测模块 620、 第二修复模块 630。 一个例子中 , 该软件设备 600为浏览器。
该请求检测模块 610以访问网页地址方式请求对该软件进行检查。进一 步地, 该请求检测模块 610是通过获取网页地址提供的用于检测该软件出错 的分析函数来实现对该软件的检查。
该第二检测模块 620用于检测该软件是否正常,如果该软件异常则以访 问网页地址的方式请求对该软件进行检测; 或根据用户发出的检测指令, 以 访问网页地址的方式请求对该软件进行检测。 较佳地, 该第二检测模块 620 是对该软件部分或全部模块的正确性、 完整性进行的检查。
该第二修复模块 630在检测到该软件中的模块出错时,对相应出错部分 进行修复。
进一步地, 该第二修复模块 630以访问网页地址的方式获取与所述出错 内容相对应正确内容, 以便对该出错部分进行修复。 更进一步地, 该第二修 复模块 630将所获取到的内容直接加载到系统内存中而保存到本地, 并在使 用该模块时直接从内存中调取该正确内容。
综上所述, 经过图 1至图 6多个实施例的说明, 本申请提供的软件自修 复方法可总体概括为以下处理步骤, 如图 7实施例所示:
步骤 710 , 在所述软件中的模块发生异常时, 检测软件中的异常模块及 该模块对应的异常内容;
所述异常即指出错, 异常模块即指出错模块, 异常内容即指出错内容。 其中, 提供了两种检测方式:
一种是, 如图 1、 图 2和图 3实施例所述, 通过在本地检测所述软件来 进行检测, 在检测到该软件异常时查找到该软件中异常模块的, 并进行自动 修复;
另一种是, 如图 4、 图 5和图 6实施例所述, 以访问网页地址的方式请 求对所述软件进行检测。 具体地, 通过网页地址下载用于检测该软件异常的 分析函数, 并利用该分析函数检测该软件。 较佳地, 以访问网页地址的方式 请求对所述软件进行检测之前, 还可以预先判定所述软件是否正常。 如果所 述软件异常, 则以访问网页地址的方式请求对所述软件进行检测; 或者, 根 据用户发出的检测指令, 以访问网页地址的方式请求对所述软件进行检测。
需要说明的是, 无论是本地检测还是请求检测, 具体的检测过程都是相 同的, 即:
( 1 )扫描与该软件相关的所有文件, 包括配置文件和 /或数据文件, 且 每扫描一个文件就会采用全文摘要算法提取该文件中的特征内容部分,且该 特征内容能够唯一性标识该文件;
( 2 )在该分析函数扫描完所有文件后, 生成一个当前文件列表, 且该 当前文件列表包含每一文件的特征内容;
( 3 )根据标准文件列表, 对该当前文件列表进行分析, 以检查该软件 是否出错, 并获知该软件中的已出错模块; 其中, 该标准文件列表包括正确 文件的特征内容, 较佳地, 还包括该正确内容的下载地址;
( 4 )若该当前文件列表中的某一项或多项内容与标准文件列表中的相 应内容不匹配,或者该当前文件列表中缺少该标准文件列表中的某一项或多 项内容时, 说明该软件异常, 并根据匹配结果获知该软件中的异常模块。
步骤 720, 下载与所述异常内容相对应的正确内容;
所述正确内容即为正常的内容。 可以访问网页地址的方式下载与所述异 常内容相对应的正常内容。
步骤 730, 在使用所述异常模块时调取相应的正确内容。
优选地, 在步骤 730之前, 还可以将该下载到的正确内容直接加载到系 统内存中, 然后在使用所述出错模块时直接从内存中调取相应正确内容。
基于图 7 , 本申请还提供了相应的装置实施例, 如图 8所示, 是本申请 实施例所述一种软件中的模块修复装置结构图。
所述软件中的模块修复装置 800可以包括以下模块:
检测模块 810, 配置为在所述软件中的模块发生异常时, 检测软件中的 异常模块及该模块对应的异常内容;
获取模块 820, 配置为下载与所述异常内容相对应的正确内容; 修复模块 830, 配置为在使用所述异常模块时调取相应的正确内容。 较佳地, 所述装置还可以包括:
保存模块 840, 配置为将该下载到的正确内容直接加载到系统内存中; 则所述修复模块 830在使用所述异常模块时直接从内存中调取相应的正 确内容。 较佳地, 所述获取模块以访问网页地址的方式下载与所述异常内容相对 应的正常内容。
较佳地, 所述检测模块 810可以包括扫描模块 81 1和分析模块 812 : 扫描模块 811 , 配置为扫描与该软件相关文件的, 每扫描一个文件, 提 取所述文件中的特征内容部分, 并生成当前文件列表;
分析模块 812 , 配置为将标准文件列表与所述当前文件列表进行匹配, 匹配时,或者在该当前文件列表缺少该标准文件列表中的某一项或多项内容 时, 判定该软件异常, 并且该不匹配内容或缺少的内容所对应的模块为该软 件中的异常模块, 该不匹配内容或缺少的内容为异常内容。
较佳地, 在本申请的另一实施例中, 如图 9所示, 所述检测模块 810可 以为第一检测模块 910 ,所述第一检测模块 910在本地对所述软件进行检测。
较佳地, 在本申请的另一实施例中, 如图 10所示, 所述检测模块 810 还可以为第二检测模块 110 , 以访问网页地址的方式请求对所述软件进行检 测。 所述第二检测模块 11 0通过网页地址下载用于检测该软件异常的分析函 数, 并利用该分析函数检测该软件。
较佳地, 当所述检测模块 810为第二检测模块 110时, 还可以包括以下 模块:
判定模块 150 , 配置为判定所述软件是否正常;
如果所述软件异常, 则所述第二检测模块 110以访问网页地址的方式请 求对所述软件进行检测; 或者, 根据用户发出的检测指令, 所述第二检测模 块 110以访问网页地址的方式请求对所述软件进行检测。
基于以上内容, 本申请还提供了一种在其上记录有用于执行上述软件中 的模块修复方法的程序的计算机可读记录介质。 其中, 所述软件中的模块修 复方法的具体内容可参见图 1、 图 2和图 4、 图 5以及图 7实施例所述的内 容, 在此不再贅述。 所述计算机可读记录介质包括用于以计算机(例如计算机)可读的形式 存储或传送信息的任何机制。 例如, 机器可读介质包括只读存储器(ROM )、 随机存取存储器(RAM ) 、 磁盘存储介质、 光存储介质、 闪速存储介质、 电、 光、 声或其他形式的传播信号 (例如, 载波、 红外信号、 数字信号等)等。
需要说明的是, 本申请并未被限定在仅用于 PC (个人计算机)中, 也可 以用于 PDA (掌上电脑)、 手机等各种电子设备中。 并且, 本申请的信息发送 方式即可以是有线的也可以是无线的。
本申请可以在由计算机执行的计算机可执行指令的一般上下文中描 述, 例如程序模块。 一般地, 程序模块包括执行特定任务或实现特定抽 象数据类型的例程、 程序、 对象、 组件、 数据结构等等。 也可以在分布 式计算环境中实践本申请, 在这些分布式计算环境中, 由通过通信网络 而被连接的远程处理设备来执行任务。 在分布式计算环境中, 程序模块 可以位于包括存储设备在内的本地和远程计算机存储介质中。
最后, 还需要说明的是, 在本文中, 诸如第一和第二等之类的关系 术语仅仅用来将一个或一些实体或者操作与另一个或另一些实体或操作 区分开来, 而不一定要求或者暗示这些实体或操作之间存在任何这种实 际的关系或者顺序。
而且, 上文中的 "和 /或" 表示本文既包含了 "和" 的关系, 也包含 了 "或" 的关系, 其中: 如果方案 A与方案 B是 "和" 的关系, 则表示 某实施例中可以同时包括方案 A和方案 B; 如果方案 A与方案 B是 "或" 的关系, 则表示某实施例中可以单独包括方案 A , 或者单独包括方案 B。
显而易见, 在不偏离本申请的真实精神和范围的前提下, 在此描述的本 申请可以有许多变化。因此,所有对于本领域技术人员来说显而易见的改变, 都应包括在本权利要求书所涵盖的范围之内。本申请所要求保护的范围仅由 所述的权利要求书进行限定。

Claims

权 利 要 求 书
1.一种软件中的模块修复方法, 其特征在于, 包括:
在所述软件中的模块发生异常时,检测软件中的异常模块及该模块对应 的异常内容;
下载与所述异常内容相对应的正常内容;
在使用所述异常模块时调取相应的所述下载的正常内容。
2 . 如权利要求 1 所述的软件中的模块修复方法, 其特征在于, 所述下 载与所述异常内容相对应的正常内容之后, 还包括:
将该下载到的正常内容直接加载到系统内存中;
则所述在使用所述异常模块时调取相应的所述下载的正常内容为: 在使 用所述异常模块时直接从内存中调取相应的所述下载的正常内容。
3. 如权利要求 1所述的软件中的模块修复方法, 其特征在于: 以访问网页地址的方式下载与所述异常内容相对应的正常内容。
4. 如权利要求 1 所述的软件中的模块修复方法, 其特征在于, 所述下 载到的正常内容为配置文件和 /或数据文件。
5. 如权利要求 1 所述的软件中的模块修复方法, 其特征在于, 所述检 测是对该软件部分或全部模块的正确性和 /或完整性进行的检查。
6. 如权利要求 1 所述的软件中的模块修复方法, 其特征在于, 所述检 测步骤包括扫描与该软件相关文件的步骤。
7. 如权利要求 5所述的软件中的模块修复方法, 其特征在于, 所述扫 描步骤包括提取所述文件中的特征内容部分, 并生成当前文件列表的步骤。
8. 如权利要求 7所述的软件中的模块修复方法, 其特征在于, 所述提 取特征内容部分采用全文摘要算法。
9. 如权利要求 7所述的软件中的模块修复方法, 其特征在于, 所述检 测步骤还包括根据标准文件列表对所述当前文件列表进行分析的步骤。
1 0. 如权利要求 9所述的软件中的模块修复方法, 其特征在于, 所述分 析的步骤包括:
将该当前文件列表与标准文件列表进行匹配, 并在该当前文件列表中某 并且该不匹配内容所对应的模块为该软件中的异常模块, 该不匹配内容为异 常内容。
1 1. 如权利要求 9所述的软件中的模块修复方法, 其特征在于, 所述分 析的步骤包括:
将该当前文件列表与标准文件列表进行匹配,并在该当前文件列表缺少 该标准文件列表中的某一项或多项内容时, 判定该软件异常, 并且该缺少的 内容所对应的模块为该软件中的异常模块, 该缺少的内容为异常内容。
12.如权利要求 9所述的软件中的模块修复方法, 其特征在于, 所述标 准文件列表包括正确文件的特征内容部分, 以及包括该正确文件的下载地 址。
1 3.如权利要求 1 所述的软件中的模块修复方法, 其特征在于, 所述下 载正常内容之前, 还包括:
在本地预置保存正确数据目录, 并根据该正确数据目录查找所述正常内 容的下载地址。
14. 如权利要求 1所述的软件中的模块修复方法, 其特征在于, 所述检 测包括:
在本地对所述软件进行检测。
15. 如权利要求 1所述的软件中的模块修复方法, 其特征在于, 所述检 测包括:
以访问网页地址的方式请求对所述软件进行检测。
16. 如权利要求 15所述的软件中的模块修复方法, 其特征在于, 所述 以访问网页地址的方式请求对所述软件进行检测, 包括: 通过网页地址下载用于检测该软件异常的分析函数;
利用该分析函数检测该软件。
17. 如权利要求 15所述的软件中的模块修复方法, 其特征在于, 所述 以访问网页地址的方式请求对所述软件进行检测之前, 还包括:
判定所述软件是否正常的步骤;
如果所述软件异常, 则以访问网页地址的方式请求对所述软件进行检 测; 或者, 根据用户发出的检测指令, 以访问网页地址的方式请求对所述软 件进行检测。
18. 一种软件中的模块修复装置, 其特征在于, 包括:
检测模块, 配置为在所述软件中的模块发生异常时, 检测软件中的异常 模块及该模块对应的异常内容;
获取模块, 配置为下载与所述异常内容相对应的正常内容;
修复模块, 配置为在使用所述异常模块时调取相应的所述下载的正常内 容。
19. 如权利要求 18所述的软件中的模块修复装置, 其特征在于, 还包 括:
保存模块, 配置为将该下载到的正常内容直接加载到系统内存中; 则所述修复模块在使用所述异常模块时直接从内存中调取相应的所述 下载的正常内容。
20. 如权利要求 18所述的软件中的模块修复装置, 其特征在于: 所述获取模块以访问网页地址的方式下载与所述异常内容相对应的正 常内容。
21. 如权利要求 18所述的软件中的模块修复装置, 其特征在于, 所述 检测模块包括:
扫描模块, 配置为扫描与该软件相关文件的, 每扫描一个文件, 提取所 述文件中的特征内容部分, 并生成当前文件列表; 分析模块, 配置为将标准文件列表与所述当前文件列表进行匹配, 并在 时, 或者在该当前文件列表缺少该标准文件列表中的某一项或多项内容时, 判定该软件异常, 并且该不匹配内容或缺少的内容所对应的模块为该软件中 的异常模块, 该不匹配内容或缺少的内容为异常内容。
22. 如权利要求 21 所述的软件中的模块修复装置, 其特征在于, 所述 检测模块为第一检测模块, 所述第一检测模块在本地对所述软件进行检测。
23. 如权利要求 21 所述的软件中的模块修复装置, 其特征在于, 所述 检测模块为第二检测模块, 以访问网页地址的方式请求对所述软件进行检 测, 所述第二检测模块通过网页地址下载用于检测该软件异常的分析函数, 并利用该分析函数检测该软件。
24. 如权利要求 23所述的软件中的模块修复装置, 其特征在于, 当所 述检测模块为第二检测模块时, 还包括:
判定模块, 配置为判定所述软件是否正常;
如果所述软件异常, 则所述第二检测模块以访问网页地址的方式请求对 所述软件进行检测; 或者, 根据用户发出的检测指令, 所述第二检测模块以 访问网页地址的方式请求对所述软件进行检测。
25. 一种在其上记录有用于执行权利要求 1所述方法的程序的计算机可 读记录介质。
PCT/CN2012/071682 2011-03-29 2012-02-27 一种软件中的模块修复方法及装置 WO2012130009A1 (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US14/008,278 US20140310560A1 (en) 2011-03-29 2012-02-27 Method and apparatus for module repair in software

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
CN201110076467.0A CN102436402B (zh) 2011-03-29 2011-03-29 一种软件中的模块修复方法及该软件设备
CN201110076467.0 2011-03-29

Publications (1)

Publication Number Publication Date
WO2012130009A1 true WO2012130009A1 (zh) 2012-10-04

Family

ID=45984481

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/CN2012/071682 WO2012130009A1 (zh) 2011-03-29 2012-02-27 一种软件中的模块修复方法及装置

Country Status (3)

Country Link
US (1) US20140310560A1 (zh)
CN (1) CN102436402B (zh)
WO (1) WO2012130009A1 (zh)

Families Citing this family (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20110029658A1 (en) * 2009-07-24 2011-02-03 Theodore Werth System and methods for providing a multi-device, multi-service platform via a client agent
CN103544071B (zh) * 2012-07-17 2017-02-15 阿里巴巴集团控股有限公司 崩溃信息的处理方法、装置及系统
CN105100092B (zh) * 2012-09-17 2018-06-12 北京奇虎科技有限公司 控制客户端访问网络的检测方法、装置和系统
CN103246578B (zh) * 2013-05-23 2017-08-01 北京奇虎科技有限公司 应用软件进行崩溃处理的方法及进行崩溃处理的浏览器
CN104135483B (zh) * 2014-06-13 2018-05-18 汪志 一种网络安全自动配置管理系统
CN105335246B (zh) * 2015-10-27 2018-04-27 北京大学 一种基于问答网站分析的程序崩溃缺陷自动修复方法
US9588758B1 (en) 2015-12-18 2017-03-07 International Business Machines Corporation Identifying user managed software modules
CN106649581B (zh) * 2016-11-17 2023-04-04 Vidaa(荷兰)国际控股有限公司 一种网页的修复方法以及客户端
CN108446573A (zh) * 2018-02-28 2018-08-24 云宏信息科技股份有限公司 文件完整性检查方法及装置
CN110825396B (zh) * 2019-10-31 2023-07-25 Oppo(重庆)智能科技有限公司 异常处理方法及相关设备

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR20020055789A (ko) * 2000-12-29 2002-07-10 구자홍 이동 통신용 단말기의 소프트웨어 유지 및 보수 방법
US6757837B1 (en) * 1999-10-19 2004-06-29 Tivo, Inc. Method and apparatus for software failure diagnosis and repair
CN101482823A (zh) * 2009-01-19 2009-07-15 中兴通讯股份有限公司 一种单板应用版本的实现方法及系统

Family Cites Families (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7536683B2 (en) * 1999-01-15 2009-05-19 Adobe Systems Incorporated Method of dynamically appending a library to an actively running program
US6718549B1 (en) * 1999-05-05 2004-04-06 Microsoft Corporation Methods for managing the distribution of client bits to client computers
US6704730B2 (en) * 2000-02-18 2004-03-09 Avamar Technologies, Inc. Hash file system and method for use in a commonality factoring system
CN101242260B (zh) * 2007-02-08 2010-12-15 北京天融信网络安全技术有限公司 防火墙系统自动修复方法
CN101221511A (zh) * 2008-01-25 2008-07-16 中兴通讯股份有限公司 一种终端设备应用软件的自动安装及升级方法
US20100083243A1 (en) * 2008-09-29 2010-04-01 Synopsys, Inc. System and method for delivering software
CN101719836A (zh) * 2008-10-09 2010-06-02 联想(北京)有限公司 一种故障检测方法及装置
US8015450B1 (en) * 2009-03-26 2011-09-06 Symantec Corporation Systems and methods for detecting and automatically installing missing software components
CN101699399B (zh) * 2009-11-03 2014-04-30 中兴通讯股份有限公司 一种软件更新的系统和方法

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6757837B1 (en) * 1999-10-19 2004-06-29 Tivo, Inc. Method and apparatus for software failure diagnosis and repair
KR20020055789A (ko) * 2000-12-29 2002-07-10 구자홍 이동 통신용 단말기의 소프트웨어 유지 및 보수 방법
CN101482823A (zh) * 2009-01-19 2009-07-15 中兴通讯股份有限公司 一种单板应用版本的实现方法及系统

Also Published As

Publication number Publication date
US20140310560A1 (en) 2014-10-16
CN102436402A (zh) 2012-05-02
CN102436402B (zh) 2014-12-10

Similar Documents

Publication Publication Date Title
WO2012130009A1 (zh) 一种软件中的模块修复方法及装置
CN104040496B (zh) 终端和应用程序恢复方法
US7526678B2 (en) Methods, systems, and products for verifying integrity of web-server served content
CN102932197B (zh) 一种测试方法及测试系统
WO2017124808A1 (zh) 一种故障信息的重现方法和重现装置
CN106951345B (zh) 一种虚拟机磁盘数据的一致性测试方法及装置
US8209658B2 (en) Method of creating signatures for classifying program failures
US8904238B2 (en) System and method for capturing logging information
US8775551B2 (en) Testing a network system
US20090248887A1 (en) Export of metadata streams to applications
JP2009140155A (ja) アプリケーションプログラムのテストプログラム
US20170277622A1 (en) Web Page Automated Testing Method and Apparatus
WO2015131643A1 (zh) 软件检测方法及装置
CN102929732B (zh) 应用程序调用文件的方法和装置及客户端设备
US9176965B2 (en) Associating search terms with a downloaded file
CN102929733A (zh) 一种错误文件处理方法、装置和客户端设备
US9686310B2 (en) Method and apparatus for repairing a file
WO2023123901A1 (zh) 通信适配修复方法、装置、系统及存储介质
US20150143192A1 (en) Application server and method of error recovery when downloading data files
CN106557379B (zh) 一种静默安装包的生成方法和装置
CN112732471B (zh) 接口返回数据的纠错方法和纠错装置
CN112749078B (zh) 一种埋点测试方法和装置
CN113220304B (zh) 冗余类的检测方法、装置、电子设备以及可读存储介质
JP6361331B2 (ja) 情報処理装置、情報処理プログラム及び情報処理方法
KR20100130498A (ko) 악성 프로그램 탐지가 가능한 프로세스 관리 방법 및 장치

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 12764784

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 14008278

Country of ref document: US

122 Ep: pct application non-entry in european phase

Ref document number: 12764784

Country of ref document: EP

Kind code of ref document: A1