可以将人员身份证图片通过修改字节加密,并且可将身份证信息也写入图片中。 可以直接将以下代码复制到一个php文件中进行测试。详情请看代码。
<?php
class Encrypt
{
/**
* 图片对称加密
*
* @param [string] $filePath 图片路径
* @return void
*/
public function enc($filePath)
{
// 文档中建议:为移植性考虑,强烈建议在用 fopen() 打开文件时总是使用 'b' 标记。
$fileId = fopen($filePath, 'rb+');
// 取出文件大小的字节数 (29124)
$fileSize = fileSize($filePath);
// 读取文件,返回所读取的字符串 (读出来的为二进制序列)
$img = fread($fileId, $fileSize);
// 使用“无符号字符”,从二进制字符串对数据进行解包
// (pack、unpack用法)https://segmentfault.com/a/1190000008305573
$imgUnpack = unpack('C*', $img); // $fileSize 长度的一维数组 [ 1=>255, 2=>216, 3=>255, ……, 29124=>217 ]
// 关闭一个已打开的文件指针
fclose($fileId);
$tempArr = [];
// 自定义加密规则
for ($i = 1; $i <= $fileSize; $i++) {
$value = 0;
if ($i % 3 == 0) {
$value = 2;
} elseif ($i % 5 == 0) {
$value = 4;
} elseif ($i % 7 == 0) {
$value = 6;
}
$byte = $imgUnpack[$i]; // 图片原始字节
$byte = $byte + $value; // 经过加密规则之后的字节
// 打包成二进制字符串
$tempArr[] = pack('C*', $byte);
}
$img = implode('', $tempArr); // 将解包之后的一维数组装换成字符串
file_put_contents($filePath, $img); // 重写图片
}
/**
* 图片对称解密
*
* @param [string] $filePath 图片路径
* @return void
*/
public function dec($filePath)
{
$fileId = fopen($filePath, 'rb+');
$fileSize = filesize($filePath);
$img = fread($fileId, $fileSize);
$imgUnpack = unpack('C*', $img);
fclose($fileId);
$tempArr = [];
// 开始解密
for ($i = 1; $i <= $fileSize; $i++) {
$value = 0;
if ($i % 3 == 0) {
$value = 2;
} elseif ($i % 5 == 0) {
$value = 4;
} elseif ($i % 7 == 0) {
$value = 6;
}
$byte = $imgUnpack[$i];
$byte = $byte - $value;
$tempArr[] = pack('C*', $byte);
}
$img = implode('', $tempArr);
file_put_contents($filePath, $img);
}
/**
* 图片追加信息
*
* @param [string] $filePath 图片路径
* @param [array] $cardmsg 需要添加的信息数组
* @param [array] $separate 分隔数组(类似于做一个加密分隔 key)
* @return void
*/
public function encmsg($filePath, $cardmsg, $separate)
{
// 文档中建议:为移植性考虑,强烈建议在用 fopen() 打开文件时总是使用 'b' 标记。
$fileId = fopen($filePath, 'rb+');
// 取出文件大小的字节数 (29124)
$fileSize = fileSize($filePath);
// 读取文件,返回所读取的字符串 (读出来的为二进制序列)
$img = fread($fileId, $fileSize);
// 使用“无符号字符”,从二进制字符串对数据进行解包
// (pack、unpack用法)https://segmentfault.com/a/1190000008305573
$imgUnpack = unpack('C*', $img); // $fileSize 长度的一维数组 [ 1=>255, 2=>216, 3=>255, ……, 29124=>217 ]
// 关闭一个已打开的文件指针
fclose($fileId);
// 处理身份信息
$cardmsgJson = json_encode($cardmsg, JSON_UNESCAPED_UNICODE);
$cardmsgUnpack = unpack('C*', $cardmsgJson);
// 合并图片字节、自定义分隔数组(类似手动加 key 值)、身份信息字节
$mergeArr = array_merge($imgUnpack, $separate, $cardmsgUnpack);
$pack = [];
foreach ($mergeArr as $k => $v) {
$pack[] = pack('C*', $v);
}
$packStr = join('', $pack);
file_put_contents($filePath, $packStr); // 重写图片
}
/**
* 获取追加进图片的信息
*
* @param [string] $filePath 图片路径
* @param [array] $separate 定义的分隔数组(分隔 key)
* @return [string] 追加进的图片信息
*/
public function decmsg ($filePath, $separate)
{
// 文档中建议:为移植性考虑,强烈建议在用 fopen() 打开文件时总是使用 'b' 标记。
$fileId = fopen($filePath, 'rb+');
// 取出文件大小的字节数 (29192)
$fileSize = fileSize($filePath);
// 读取文件,返回所读取的字符串 (读出来的为二进制序列)
$img = fread($fileId, $fileSize);
// 使用“无符号字符”,从二进制字符串对数据进行解包
$imgUnpack = unpack('C*', $img); // $fileSize 长度的一维数组 [ 1=>255, 2=>216, 3=>255, ……, 29192=>217 ]
// 关闭一个已打开的文件指针
fclose($fileId);
$imgUnpackStr = join(',',$imgUnpack); // 将一维数组转换为字符串
$separateStr = implode(',', $separate); // 将一维数组转换为字符串
$imgAndCardmsgArr = explode($separateStr, $imgUnpackStr); // 以自定义分隔符分隔出图片字节和身份信息字节
$cardmsgArr = explode(',', $imgAndCardmsgArr[1]); // 取出身份信息字节
unset($cardmsgArr[0]); // 去除身份信息字节首位空白 (字符串转数组时所留)
$cardmsg = '';
foreach ($cardmsgArr as $k => $v) {
$cardmsg .= pack('C*', $v); // 打包成二进制文件字符串
}
return json_decode($cardmsg, true);
}
}
$encrypt = new Encrypt();
$path = './001.jpg';
$separate = [255, 0, 255, 0, 255, 0, 255, 206, 210, 202, 199, 183, 214, 184, 244]; // 15字节
$cardmsg = ['name' => '张三', 'gender' => '男', 'idcard' => 12345678910]; // 53字节
来自:https://segmentfault.com/a/1190000019534963
通常在api开发中,为了保证数据在一定程度上的安全性,我们需要采用一些加密手段,这篇文章主要介绍下使用ase来进行加密、解密。AES加密是一种对称加密算法,需要保证客户端和服务端使用的相同秘钥,而且加密的padding和mode 需要两端相对应。
近来,加密数字货币已经在世界上很流行,几乎所有人都听说过它。随着价格的不断提升,越来越多的人愿意在加密数字货币上投资了。尽管大名鼎鼎,但多数人都不太了解它们。
RSA加密是一种非对称加密。可以在不直接传递密钥的情况下,完成解密。这能够确保信息的安全性,避免了直接传递密钥所造成的被破解的风险。是由一对密钥来进行加解密的过程,分别称为公钥和私钥。
对称加密采用了对称密码编码技术,它的特点是文件加密和解密使用相同的密钥加密。对称加密算法不同,非对称加密算法需要两个密钥:公开密钥(publickey)和私有密钥(privatekey)。
rsa加密方式:首先引入一下js文件,路径根据实际情况自行修改;Md5加密方式;Sha256加密方式;总体而言,rsa加密会比其他两种方式复杂,需要注意的是,rsa在初始化时一定要先赋给它一个公钥。
AES:高级加密标准 ( Advanced Encryption Standard ),AES是一种对称加密算法:加密需要密钥,且加密密钥和解密密钥相同,下面是AES加密的Node实现:
HTTP压缩,在HTTP协议中,其实是内容编码的一种。在http协议中,可以对内容(也就是body部分)进行编码, 可以采用gzip这样的编码。 从而达到压缩的目的。 也可以使用其他的编码把内容搅乱或加密
最近遇到的几个网站在提交密码时提交的已经是密文,也就是说在网络上传输的密码是密文,这样提升了密码在网络传输中的安全性。前端的话Google之前出过一个crypto-js,为浏览器的js提供了加解密方案。
crypto 模块提供了加密功能,包含对 OpenSSL 的哈希、HMAC、加密、解密、签名、以及验证功能的一整套封装。我们这里讲crypto AES算法加密
CryptoJS (crypto.js) 为 JavaScript 提供了各种各样的加密算法。目前已支持的算法包括:MD5,SHA-1,SHA-256,AES,Rabbit,MARC4,HMAC,HMAC-MD5
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!