暂无描述

d98762625 bca73b496f add Merge (without Fork). Add flowcontrol setter to Operation 7 年之前
.github e5a32ac57d Added links to Gitter chat room 7 年之前
docs dba0b104ab Added docs to GH Pages 8 年之前
src bca73b496f add Merge (without Fork). Add flowcontrol setter to Operation 7 年之前
test bca73b496f add Merge (without Fork). Add flowcontrol setter to Operation 7 年之前
.babelrc cc20ad9567 Add OperationError error type and use for errors to be printed to the output panel 7 年之前
.editorconfig 0011e9caa8 Added .editorconfig 7 年之前
.eslintignore 041cd9fb8e ESM: Added remaining Base64 ops and created a Base64 library. Added the prefer-const eslint rule. 7 年之前
.eslintrc.json 041cd9fb8e ESM: Added remaining Base64 ops and created a Base64 library. Added the prefer-const eslint rule. 7 年之前
.gitignore e99331f305 ESM: Tidied up Set operations 7 年之前
.npmignore d6895537ac Added more keywords and bug link to package.json 8 年之前
.travis.yml 9b4fc3d3aa Converted the core to ES modules 7 年之前
CODE_OF_CONDUCT.md 685f7a4f00 Create CODE_OF_CONDUCT.md 8 年之前
Gruntfile.js ebcc5bd9c8 ESM: Added generateConfig calls to relevant grunt tasks 7 年之前
LICENSE b1d73a725d Initial commit 8 年之前
README.md f6b2783f8b File overlays now show a blurred representation of the file in the background. 7 年之前
package-lock.json 3f08fa3b23 update package-lock 7 年之前
package.json 3fd1f4e6d9 ESM: Ported all Hash and Checksum operations 7 年之前
postcss.config.js 488d54493a Added modern browser warning for theme support 8 年之前
webpack.config.js 3fd1f4e6d9 ESM: Ported all Hash and Checksum operations 7 年之前

README.md

CyberChef

Build Status dependencies Status npm Gitter

The Cyber Swiss Army Knife

CyberChef is a simple, intuitive web app for carrying out all manner of "cyber" operations within a web browser. These operations include simple encoding like XOR or Base64, more complex encryption like AES, DES and Blowfish, creating binary and hexdumps, compression and decompression of data, calculating hashes and checksums, IPv6 and X.509 parsing, changing character encodings, and much more.

The tool is designed to enable both technical and non-technical analysts to manipulate data in complex ways without having to deal with complex tools or algorithms. It was conceived, designed, built and incrementally improved by an analyst in their 10% innovation time over several years. Every effort has been made to structure the code in a readable and extendable format, however it should be noted that the analyst is not a professional developer.

Live demo

CyberChef is still under active development. As a result, it shouldn't be considered a finished product. There is still testing and bug fixing to do, new features to be added and additional documentation to write. Please contribute!

Cryptographic operations in CyberChef should not be relied upon to provide security in any situation. No guarantee is offered for their correctness.

A live demo can be found here - have fun!

How it works

There are four main areas in CyberChef:

  1. The input box in the top right, where you can paste, type or drag the text or file you want to operate on.
  2. The output box in the bottom right, where the outcome of your processing will be displayed.
  3. The operations list on the far left, where you can find all the operations that CyberChef is capable of in categorised lists, or by searching.
  4. The recipe area in the middle, where you can drag the operations that you want to use and specify arguments and options.

You can use as many operations as you like in simple or complex ways. Some examples are as follows:

Features

  • Drag and drop
    • Operations can be dragged in and out of the recipe list, or reorganised.
    • Files can be dragged over the input box to load them directly into the browser.
  • Auto Bake
    • Whenever you modify the input or the recipe, CyberChef will automatically "bake" for you and produce the output immediately.
    • This can be turned off and operated manually if it is affecting performance (if the input is very large, for instance).
  • Breakpoints
    • You can set breakpoints on any operation in your recipe to pause execution before running it.
    • You can also step through the recipe one operation at a time to see what the data looks like at each stage.
  • Save and load recipes
    • If you come up with an awesome recipe that you know you’ll want to use again, just click "Save recipe" and add it to your local storage. It'll be waiting for you next time you visit CyberChef.
    • You can also copy the URL, which includes your recipe and input, to easily share it with others.
  • Search
    • If you know the name of the operation you want or a word associated with it, start typing it into the search field and any matching operations will immediately be shown.
  • Highlighting
  • Save to file and load from file
    • You can save the output to a file at any time or load a file by dragging and dropping it into the input field. Files up to around 500MB are supported (depending on your browser), however some operations may take a very long time to run over this much data.
  • CyberChef is entirely client-side
    • It should be noted that none of your recipe configuration or input (either text or files) is ever sent to the CyberChef web server - all processing is carried out within your browser, on your own computer.
    • Due to this feature, CyberChef can be compiled into a single HTML file. You can download this file and drop it into a virtual machine, share it with other people, or use it independently on your local machine.

Browser support

CyberChef is built to support

  • Google Chrome 40+
  • Mozilla Firefox 35+
  • Microsoft Edge 14+

Contributing

An installation walkthrough, how-to guides for adding new operations and themes, descriptions of the repository structure, available data types and coding conventions can all be found in the project wiki pages.

Licencing

CyberChef is released under the Apache 2.0 Licence and is covered by Crown Copyright.