定制 janfish/security 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

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

janfish/security

Composer 安装命令:

composer require janfish/security

包简介

Encrypt、Decrypt、Sign、Verify with RSA

README 文档

README

RSA

Generate Rsa keys

the available key lengths are 1024 and 2048

$ openssl genrsa -out rsa_private_key.pem 1024
$ openssl rsa -in rsa_private_key.pem -pubout -out rsa_public_key.pem

Encrypt & Sign

  • prepare keys
$pri = file_get_contents('keys/rsa_private_key.pem');
$pub = file_get_contents('keys/rsa_public_key.pem');
  • encrypt
$rsa = new RSA();
$rsa->setPubKey($pub);
$encodedData = $rsa->encrypt("hello", RSA::OPENSSL_PKCS1_PADDING);
  • decrypt
$rsa = new RSA();
$rsa->setPriKey($pri);
$sourceData = $rsa->decrypt($encodedData, RSA::OPENSSL_PKCS1_PADDING);
  • sign
$rsa = new RSA();
$rsa->setPriKey($pri);
$signedData = $rsa->sign('hello',Rsa::OPENSSL_ALGO_SHA256);
  • verify
$rsa = new RSA();
$rsa->setPubKey($pri);
$result = $rsa->verify('hello',$signedData,Rsa::OPENSSL_ALGO_SHA256);

Support Params

  • Signature Algorithm Type
name default value
OPENSSL_ALGO_SSHA1 yes 1
OPENSSL_ALGO_SMD5 2
OPENSSL_ALGO_SMD4 3
OPENSSL_ALGO_SMD2 4
OPENSSL_ALGO_SDSS1 5
OPENSSL_ALGO_SSHA224 6
OPENSSL_ALGO_SSHA256 7
OPENSSL_ALGO_SSHA384 8
OPENSSL_ALGO_SSHA512 9
OPENSSL_ALGO_SRMD160 10
  • Encryption Padding Type
name default value
PKCS1_PKCS1_PADDING yes 1
PKCS1_SSLV23_PADDING 2
PKCS1_NO_PADDING 3
PKCS1_OAEP_PADDING 4

Tips

  • When OpenSSL is used "OPENSSL_NO_PADDING" to padding parameter, you need to manually fill in the original data
$str = str_pad("hello", 256); //128 or 256 
$rsa = new RSA();
$rsa->setPubKey($pub);
$encodedData = $rsa->encrypt($str, RSA::OPENSSL_NO_PADDING);

Other Encryption

$encryption= new Crypt(['cipher' => 'aes-256-cbc']);
$encode = $encryption->encrypt("hello", 'keyToMyHeart');
$decode = $encryption->decrypt($encode, 'keyToMyHeart');
var_dump([
    $encryption->getIv(),
    $encode,
    $decode
]);

$en = new Crypt(['cipher' => 'aes-256-cbc']); //des-ede3;
$iv = '0123456789abcdef';
//$iv = $en->makeIv();
$clientSecret = 'nuasndu89382j3d3d9238';

$encode = $en->encrypt("hello", $clientSecret, $iv);
$decode = $en->decrypt($encode, $clientSecret, $iv);

var_dump([
    $en->getIv(),
    $en->ivSize,
    $encode,
    $decode
]);

统计信息

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

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2020-11-18

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固