teakowa/cryptomute 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

teakowa/cryptomute

Composer 安装命令:

composer require teakowa/cryptomute

包简介

Encrypt numeric data (binary, decimal, hex) preserving it's format (eg. 16-digits card number to 16-digits encrypted number).

README 文档

README

A small PHP class implementing Format Preserving Encryption via Feistel Network.

Latest Version on Packagist PHP from Packagist LICENSE LICENSE 996.icu Total Downloads

1. Installation

You can install Cryptomute via Composer (packagist has teakowa/cryptomute package). In your composer.json file use:

{
    "require": {
        "teakowa/cryptomute": "^1.4"
    }
}

And run: php composer.phar install. After that you can require the autoloader and use Cryptomute:

2. Usage

use Cryptomute\Cryptomute;

$cryptomute = new Cryptomute(
    'aes-256-cbc',      // cipher
    '0123456789zxcvbn', // base key
    7,                  // number of rounds
);

$password = '0123456789qwerty';
$iv = '0123456789abcdef';

$plainValue = '2048';
$encoded = $cryptomute->encrypt($plainValue, 10, false, $password, $iv);
$decoded = $cryptomute->decrypt($encoded, 10, false, $password, $iv);

var_dump([
  'plainValue' => $plainValue,
  'encoded'    => $encoded,
  'decoded'    => $decoded,
]);
array(3) {              
  ["plainValue"]=>       
  string(4) "2048"       
  ["encoded"]=>          
  string(9) "309034283"  
  ["decoded"]=>          
  string(4) "2048"       
}                        

3. Options

3.1 Cipher

Cipher is the first constructor argument. Supported cipher methods are:

Cipher IV
aes-128-cbc yes
aes-192-cbc yes
aes-256-cbc yes
camellia-128-cbc yes
camellia-192-cbc yes
camellia-256-cbc yes

3.2 Key

Key is the second constructor argument. Base key from which all round keys are derrived.

3.3 Rounds

Rounds is the third constructor argument. Must be an odd integer greater or equal to 3. More rounds is more secure, but also slower. Recommended value is at least 7.

4. Public methods

4.1 setValueRange($minValue, $maxValue)

Sets minimum and maximum values. If the result is out of range it will be re-encrypted (or re-decrypted) until output is in range.

4.2 encrypt($plainValue, $base, $pad, $password, $iv)

Encrypts data. Takes following arguments:

  • $plainValue (string) input data to be encrypted
  • $base (int) input data base, accepted values is 2 (binary), 10 (decimal) or 16 (hexadecimal)
  • $pad (bool) pad left output to match $maxValue's length?
  • $password (string) encryption password
  • $iv (string) initialization vector - only if cipher requires it

4.2 decrypt($cryptValue, $base, $pad, $password, $iv)

Decrypts data. Takes following arguments:

  • $cryptValue (string) input data to be decrypted
  • $base (int) input data base, accepted values is 2 (binary), 10 (decimal) or 16 (hexadecimal)
  • $pad (bool) pad left output to match $maxValue's length?
  • $password (string) encryption password
  • $iv (string) initialization vector - only if cipher requires it

LICENSE

The code in this repository, unless otherwise noted, is under the terms of both the Anti 996 License and the Apache License (Version 2.0).

统计信息

  • 总下载量: 28.36k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 4
  • 点击次数: 2
  • 依赖项目数: 3
  • 推荐数: 0

GitHub 信息

  • Stars: 4
  • Watchers: 0
  • Forks: 5
  • 开发语言: PHP

其他信息

  • 授权协议: Apache-2.0
  • 更新时间: 2020-08-28

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固