obfuscation software

      Obfuscation (software) GudangMovies21 Rebahinxxi LK21

      In software development, obfuscation is the practice of creating source or machine code that is intentionally difficult for humans or computers to understand. Similar to obfuscation in natural language, code obfuscation may involve using unnecessarily roundabout ways to write statements. Programmers often obfuscate code to conceal its purpose, logic, or embedded values. The primary reasons for doing so are to prevent tampering, deter reverse engineering, or to create a puzzle or recreational challenge to deobfuscate the code, a challenge often included in crackmes. While obfuscation can be done manually, it is more commonly performed using obfuscators.


      Overview


      The architecture and characteristics of some languages may make them easier to obfuscate than others. C, C++, and the Perl programming language are some examples of languages easy to obfuscate. Haskell is also quite obfuscatable despite being quite different in structure.
      The properties that make a language obfuscatable are not immediately obvious.


      Techniques



      Types of obfuscations include simple keyword substitution, use or non-use of whitespace to create artistic effects, and self-generating or heavily compressed programs.
      According to Nick Montfort, techniques may include:

      naming obfuscation, which includes naming variables in a meaningless or deceptive way;
      data/code/comment confusion, which includes making some actual code look like comments or confusing syntax with data;
      double coding, which can be displaying code in poetry form or interesting shapes.


      = Automated tools

      =
      A variety of tools exist to perform or assist with code obfuscation. These include experimental research tools developed by academics, hobbyist tools, commercial products written by professionals, and open-source software. Additionally, deobfuscation tools exist, aiming to reverse the obfuscation process.
      While most commercial obfuscation solutions transform either program source code or platform-independent bytecode (as used by Java and .NET), some also work directly on compiled binaries.

      Some Python examples can be found in the official Python programming FAQ and elsewhere.
      The movfuscator C compiler for the x86_32 ISA uses only the mov instruction in order to obfuscate.


      = Recreational

      =
      Writing and reading obfuscated source code can be a brain teaser. A number of programming contests reward the most creatively obfuscated code, such as the International Obfuscated C Code Contest and the Obfuscated Perl Contest.
      Short obfuscated Perl programs may be used in signatures of Perl programmers. These are JAPHs ("Just another Perl hacker").


      = Cryptographic

      =

      Cryptographers have explored the idea of obfuscating code so that reverse-engineering the code is cryptographically hard. This is formalized in the many proposals for indistinguishability obfuscation, a cryptographic primitive that, if possible to build securely, would allow one to construct many other kinds of cryptography, including completely novel types that no one knows how to make. (A stronger notion, black-box obfuscation, is known to be impossible in general.)


      Disadvantages of obfuscation


      While obfuscation can make reading, writing, and reverse-engineering a program difficult and time-consuming, it will not necessarily make it impossible.
      It adds time and complexity to the build process for the developers.
      It can make debugging issues after the software has been obfuscated extremely difficult.
      Once code is no longer maintained, hobbyists may want to maintain the program, add mods, or understand it better. Obfuscation makes it hard for end users to do useful things with the code.
      Certain kinds of obfuscation (i.e. code that isn't just a local binary and downloads mini binaries from a web server as needed) can degrade performance and/or require Internet.


      = Notifying users of obfuscated code

      =
      Some anti-virus softwares, such as AVG AntiVirus, will also alert their users when they land on a website with code that is manually obfuscated, as one of the purposes of obfuscation can be to hide malicious code. However, some developers may employ code obfuscation for the purpose of reducing file size or increasing security. The average user may not expect their antivirus software to provide alerts about an otherwise harmless piece of code, especially from trusted corporations, so such a feature may actually deter users from using legitimate software.
      Mozilla and Google disallow browser extensions containing obfuscated code in their add-ons store.


      = Obfuscation and copyleft licenses

      =
      There has been debate on whether it is illegal to skirt copyleft software licenses by releasing source code in obfuscated form, such as in cases in which the author is less willing to make the source code available. The issue is addressed in the GNU General Public License by requiring the "preferred form for making modifications" to be made available. The GNU website states "Obfuscated 'source code' is not real source code and does not count as source code."


      Decompilers


      A decompiler is a tool that can reverse-engineer source code from an executable or library. This process is sometimes referred to as a man-in-the-end (mite) attack, inspired by the traditional "man-in-the-middle attack" in cryptography. The decompiled source code is often hard to read, containing random function and variable names, incorrect variable types, and logic that differs from the original source code due to compiler optimizations.


      Model obfuscation


      Model obfuscation is a technique to hide the internal structure of a machine learning model. Obfuscation turns a model into a black box. It is contrary to explainable AI. Obfuscation models can also be applied to training data before feeding it into the model to add random noise. This hides sensitive information about the properties of individual and groups of samples.


      See also




      References




      Further reading




      External links


      The International Obfuscated C Code Contest
      Protecting Java Code Via Code Obfuscation, ACM Crossroads, Spring 1998 issue
      Can we obfuscate programs?
      Yury Lifshits. Lecture Notes on Program Obfuscation (Spring'2005)
      c2:BlackBoxComputation

    Kata Kunci Pencarian: obfuscation software

    obfuscation softwareobfuscation software toolsobfuscation software downloadsoftware obfuscation is a technique often used to slow downsoftware obfuscation with non linear mixed boolean arithmetic expressionsobfuscation in software developmentobfuscation meaning softwarehardware software obfuscation against timing side channel attack on a gpumeasuring software obfuscation quality a systematic literature review