最近用PHP写的一个DES加密算法
1. example.php
<?php include 'Des.class.php'; $str = "aabcdefqrssdfsdfsdfsdfsdfasreguiowefisdfsdfsdfhldfsnasdhfuit"; $Des = new Des('12345678'); $encode = $Des->encode($str); echo "<br/>Des加密结果:<br/>"; echo $encode; $decode = $Des->decode($encode); echo "<br/>Des解密结果:<br/>"; echo $decode; $TripleDes = new TripleDes('12345678','abcdefgh'); $encode = $TripleDes->encode($str); echo "<br/>3Des加密结果:<br/>"; echo $encode; $decode = $TripleDes->decode($encode); echo "<br/>3Des解密结果:<br/>"; echo $decode; ?>
2. TripleDes.class.php
<?php /** * TripleDes 三次Des加密 * @author CuZn * @last-modified 2013-4-18 */ class TripleDes { private $DesArr = array(); public function __construct($key1, $key2) { $this->DesArr[] = new Des($key1); $this->DesArr[] = new Des($key2); } public function encode($content) { return $this->DesArr[0]->encode( $this->DesArr[1]->decode( $this->DesArr[0]->encode($content) ) ); } public function decode($content) { return $this->DesArr[0]->decode( $this->DesArr[1]->encode( $this->DesArr[0]->decode($content) ) ); } } ?>
3.Des.class.php
<?php /** * Des 主要操作类 * @author CuZn * @last-modified 2013-4-18 */ //加载分组密钥类和辅助函数 include 'DesKey.class.php'; include 'TripleDes.class.php'; include 'toolFunction.php'; class Des { private $DesKey; //DesKey分组密钥对象 private $contentAdd = 'a'; //文字不足时的添加 private $permutationETable = array(//置换表E 32, 1, 2, 3, 4, 5, 4, 5, 6, 7, 8, 9, 8, 9, 10, 11, 12, 13, 12, 13, 14, 15, 16, 17, 16, 17, 18, 19, 20, 21, 20, 21, 22, 23, 24, 25, 24, 25, 26, 27, 28, 29, 28, 29, 30, 31, 32, 1 ); private $permutationPTable = array(//置换表P 16, 7, 20, 21, 29, 12, 28, 17, 1, 15, 23, 26, 5, 18, 31, 10, 2, 8, 24, 14, 32, 27, 3, 9, 19, 13, 30, 6, 22, 11, 4, 25 ); private $sBox = array(//S盒子 array( 14, 4, 13, 1, 2, 15, 11, 8, 3, 10, 6, 12, 5, 9, 0, 7, 0, 15, 7, 4, 14, 2, 13, 1, 10, 6, 12, 11, 9, 5, 3, 8, 4, 1, 14, 8, 13, 6, 2, 11, 15, 12, 9, 7, 3, 10, 5, 0, 15, 12, 8, 2, 4, 9, 1, 7, 5, 11, 3, 14, 10, 0, 6, 13 ), array( 15, 1, 8, 14, 6, 11, 3, 4, 9, 7, 2, 13, 12, 0, 5, 10, 3, 13, 4, 7, 15, 2, 8, 14, 12, 0, 1, 10, 6, 9, 11, 5, 0, 14, 7, 11, 10, 4, 13, 1, 5, 8, 12, 6, 9, 3, 2, 15, 13, 8, 10, 1, 3, 15, 4, 2, 11, 6, 7, 12, 0, 5, 14, 9 ), array( 10, 0, 9, 14, 6, 3, 15, 5, 1, 13, 12, 7, 11, 4, 2, 8, 13, 7, 0, 9, 3, 4, 6, 10, 2, 8, 5, 14, 12, 11, 15, 1, 13, 6, 4, 9, 8, 15, 3, 0, 11, 1, 2, 12, 5, 10, 14, 7, 1, 10, 13, 0, 6, 9, 8, 7, 4, 15, 14, 3, 11, 5, 2, 12 ), array( 7, 13, 14, 3, 0, 6, 9, 10, 1, 2, 8, 5, 11, 12, 4, 15, 13, 8, 11, 5, 6, 15, 0, 3, 4, 7, 2, 12, 1, 10, 14, 9, 10, 6, 9, 0, 12, 11, 7, 13, 15, 1, 3, 14, 5, 2, 8, 4, 3, 15, 0, 6, 10, 1, 13, 8, 9, 4, 5, 11, 12, 7, 2, 14 ), array( 2, 12, 4, 1, 7, 10, 11, 6, 8, 5, 3, 15, 13, 0, 14, 9, 14, 11, 2, 12, 4, 7, 15, 1, 5, 0, 15, 10, 3, 9, 8, 6, 4, 2, 1, 11, 10, 13, 7, 8, 15, 9, 12, 5, 6, 3, 0, 14, 11, 8, 12, 7, 1, 14, 2, 13, 6, 15, 0, 9, 10, 4, 5, 3 ), array( 12, 1, 10, 15, 9, 2, 6, 8, 0, 13, 3, 4, 14, 7, 5, 11, 10, 15, 4, 2, 7, 12, 9, 5, 6, 1, 13, 14, 0, 11, 3, 8, 9, 14, 15, 5, 2, 8, 12, 3, 7, 0, 4, 10, 1, 13, 11, 6, 4, 3, 2, 12, 9, 5, 15, 10, 11, 14, 1, 7, 6, 0, 8, 13 ), array( 4, 11, 2, 14, 15, 0, 8, 13, 3, 12, 9, 7, 5, 10, 6, 1, 13, 0, 11, 7, 4, 9, 1, 10, 14, 3, 5, 12, 2, 15, 8, 6, 1, 4, 11, 13, 12, 3, 7, 14, 10, 15, 6, 8, 0, 5, 9, 2, 6, 11, 13, 8, 1, 4, 10, 7, 9, 5, 0, 15, 14, 2, 3, 12 ), array( 13, 2, 8, 4, 6, 15, 11, 1, 10, 9, 3, 14, 5, 0, 12, 7, 1, 15, 13, 8, 10, 3, 7, 4, 12, 5, 6, 11, 0, 14, 9, 2, 7, 11, 4, 1, 9, 12, 14, 2, 0, 6, 10, 13, 15, 3, 5, 8, 2, 1, 14, 7, 4, 10, 8, 13, 15, 12, 9, 0, 3, 5, 6, 11 ) ); public function __construct($key) { $this->DesKey = new DesKey($key); } public function encode($content) { return $this->authCode($content , 'encode' ); } public function decode($content) { return $this->authCode($content , 'decode'); } /** * 加密的启动函数 * @param string $type 加密类型 * @param type $content 加密内容 * @return type 加密结果 */ public function authCode( $content , $type = 'encode') { if ($type != 'encode') { $type = 'decode'; } $contentEncodeArr = array(); $contentArr = str_split($content, 8); $encodeContent = ''; for ($index = 0; $index < count($contentArr); $index++) { $content = $contentArr[$index]; if (strlen($content) < 8) { $content .= str_repeat($this->contentAdd, ( 8 - strlen($content))); } $contentBitArr = bytesToBitArr($content); list($L, $R) = array_chunk($contentBitArr, 32); $contentEncodeArr = $this->_run($L, $R, $type); $byteArr = array_chunk($contentEncodeArr, 8); for ($index1 = 0; $index1 < count($byteArr); $index1++) { $byte = 0; for ($i = 0; $i < count($byteArr[$index1]); $i++) { $byte += $byteArr[$index1][$i] * pow(2, 7 - $i); } $encodeContent .= chr($byte); } } return $encodeContent; } /** * Feistel 结构加密算法中的迭代函数 * @param type $L 32位的左半部分输入 * @param type $R 32位的右半部分输入 * @param type $method encode(加密)或decode(解密) * @param type $round 迭代的轮数 * @return type */ private function _run($L, $R, $method = "encode", $round = 0) { $nextL = ''; //下轮左半部分输入 $nextR = ''; //下轮右半部分输入 $subKey48Bit = $this->DesKey->getSubKeyAt($round, $method); //子密钥 $FResult32Bit = $this->_F($subKey48Bit, $R); //轮函数结果 //异或 for ($index = 0; $index < count($FResult32Bit); $index++) { $FResult32Bit[$index] = $FResult32Bit[$index] === $L[$index] ? false : true; } $nextL = $R; $nextR = $FResult32Bit; //轮数将会停在15,共加密16轮 if ($round >= 15) { return array_merge($nextR, $nextL); } else { return $this->_run($nextL, $nextR, $method, ++$round); } } /** * Feitel架构中的轮函数 * @param type $subKey48Bit 48位的子密钥 * @param type $R 当前轮的右部分输入 * @return 32位结果 */ public function _F($subKey48Bit, $R) { $tmp48Bit = array(); //E表置换 for ($index = 0; $index < count($this->permutationETable); $index++) { $tmp48Bit[] = $R[$this->permutationETable[$index] - 1]; } //与子密钥异或 for ($index = 0; $index < count($tmp48Bit); $index++) { $tmp48Bit[$index] = $tmp48Bit[$index] === $subKey48Bit[$index] ? false : true; } //代替/选择(s盒) $tem32Bit = array(); $tem6BitArr = array_chunk($tmp48Bit, 6); for ($index = 0; $index < count($tem6BitArr); $index++) { $tem6Bit = $tem6BitArr[$index]; $line = $tem6Bit[0] * 2 + $tem6Bit[5] * 1; $field = $tem6Bit[1] * 2 * 2 * 2 + $tem6Bit[2] * 2 * 2 + $tem6Bit[3] * 2 + $tem6Bit[4]; $selectPos = $line * 6 + $field; $select = $this->sBox[$index][$selectPos]; if ($select >= 8) { $tem32Bit[] = true; } else { $tem32Bit[] = false; } $select %= 8; if ($select >= 4) { $tem32Bit[] = true; } else { $tem32Bit[] = false; } $select %= 4; if ($select >= 2) { $tem32Bit[] = true; } else { $tem32Bit[] = false; } $select %=2; if ($select >= 1) { $tem32Bit[] = true; } else { $tem32Bit[] = false; } } //置换P $FResult32Bit = array(); for ($index = 0; $index < count($this->permutationPTable); $index++) { $FResult32Bit[] = $tem32Bit[$this->permutationPTable[$index] - 1]; } return $FResult32Bit; } }
4. DesKey.class.php
<?php /** * Des 生成加密分组密钥 * @author CuZn * @last-modified 2013-4-18 */ class DesKey { private $key = ''; private $subKeyArr = array(); private $keyAdd = 'a'; private $CkeyArr = array(); private $dkeyArr = array(); private $leftShiftArr = array(1, 1, 2, 2, 2, 2, 2, 2, 1, 2, 2, 2, 2, 2, 2, 1); private $permutationTable = array( 14, 17, 11, 24, 1, 5, 3, 28, 15, 6, 21, 10, 23, 19, 13, 4, 26, 8, 16, 7, 27, 20, 13, 2, 41, 52, 31, 37, 47, 55, 30, 40, 51, 45, 33, 48, 44, 49, 39, 56, 34, 53, 46, 42, 50, 36, 29, 32 ); //置换表 public function __construct($key) { $this->_initKey($key); $this->_generateSubKey(); } /** * 获取指定位置的子密钥 * @param type $index 位置 * @param type $method 决定是正序还是逆序 * @return type 48bit的子密钥 */ public function getSubKeyAt($index, $method = 'encode') { if ($method == 'encode') { return $this->subKeyArr[$index]; } else { return $this->subKeyArr[15 - $index]; } } /** * 初始化64位的密钥 * @param type $key 字符密钥 */ private function _initKey($key) { $key = substr($key, 0, 8); $keyLen = strlen($key); //补全64位 if ($keyLen < 8) { $key .= str_repeat($this->keyAdd, 8 - $keyLen); } $this->key = $key; $bitArr = bytesToBitArr($this->key); //初始化C0,左边取28位 for ($index = 0; $index < 32; $index++) { if ($index % 8 === 7) { continue; } $this->CkeyArr[] = $bitArr[$index]; } //初始化D0,右边取28位 for ($index = 32; $index < 64; $index++) { if ($index % 8 === 7) { continue; } $this->DkeyArr[] = $bitArr[$index]; } } /** * 16轮生成16个子密钥 * @param type $round 当前轮数 */ private function _generateSubKey($round = 0) { //左移 $tmp28BitC = array_shift($this->CkeyArr); $tmp28BitD = array_shift($this->DkeyArr); $this->CkeyArr[] = $tmp28BitC; $this->DkeyArr[] = $tmp28BitD; //是否继续左移 if ($this->leftShiftArr[$round] == 2) { $tmp28BitC = array_shift($this->CkeyArr); $tmp28BitD = array_shift($this->DkeyArr); $this->CkeyArr[] = $tmp28BitC; $this->DkeyArr[] = $tmp28BitD; } $tem56BitCDkey = array_merge($this->CkeyArr, $this->DkeyArr); $tem48BitSubkey = array(); //置换&压缩 for ($index = 0; $index < count($this->permutationTable); $index++) { $tem48BitSubkey[] = $tem56BitCDkey[$this->permutationTable[$index] - 1]; } $this->subKeyArr[] = $tem48BitSubkey; if ($round < 15) { $this->_generateSubKey(++$round); } } }
5. toolFunction.php
<?php /** * 将字节流转换成数组 * @param type $bytes * @return boolean 数组 */ function bytesToBitArr($bytes) { $boolArr = array(); for ($i = 0; $i < strlen($bytes); $i++) { $byte = substr($bytes, $i, 1); for ($index = 0; $index < 8; $index++) { if (((ord($byte) << $index) % 256) >= 128) { $boolArr[] = true; } else { $boolArr[] = false; } } } return $boolArr; } /** * 测试用 * @param type $bitArr */ function dumpBit($bitArr) { for ($index = 0; $index < count($bitArr); $index++) { if ($bitArr[$index]) { echo '1'; } else { echo '0'; } } echo '<br />'; } /** * 测试用 * @param type $num * @param type $str */ function testDesTime($num = 100, $str = '测试测试') { $startPoint = microtimeFloat(); for ($index = 0; $index < $num; $index++) { $Des = new Des('12345678'); $encode = $Des->encode($str); } $endPoint = microtimeFloat(); $allTime = $endPoint - $startPoint; return $allTime; } /** * 测试用 * @param type $num * @param type $str */ function testMd5Time($num = 100, $str = '测试测试') { $startPoint = microtimeFloat(); for ($index = 0; $index < $num; $index++) { $encode = md5($str); } $endPoint = microtimeFloat(); $allTime = $endPoint - $startPoint; return $allTime; } /** * 测试用 * @param type $num * @param type $str */ function microtimeFloat() { list($usec, $sec) = explode(" ", microtime()); return ((float) $usec + (float) $sec); }

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











네트워크 기술이 지속적으로 발전함에 따라 웹 애플리케이션이 점점 더 대중화되고 있으며, 웹 애플리케이션의 정보 보안이 점점 더 중요해지고 있습니다. 웹 애플리케이션의 정보 보안 문제를 해결하기 위해 사람들은 많은 암호화 알고리즘을 개발했으며 그 중 가장 유명한 것은 RSA, DES 및 기타 알고리즘입니다. 그러나, 암호화 알고리즘의 복호화에는 많은 계산과 시간이 소요되어 시스템 부담이 커지게 되므로, 단시간에 빠르게 암호화하고 복호화할 수 있는 일종의 암호화 알고리즘, 즉 고속 암호화 알고리즘이 등장하게 되었다. 이 기사에서는 PHP의 고급 기능을 소개합니다.

네트워크 보안 분야에서 암호화 기술은 데이터 보안을 보장하기 위해 데이터를 암호화하고 복호화할 수 있는 매우 중요한 기술적 수단입니다. 널리 사용되는 서버측 프로그래밍 언어인 PHP는 다양한 애플리케이션 시나리오의 요구 사항을 충족하기 위해 대칭 및 비대칭 암호화도 지원합니다. 대칭 암호화 대칭 암호화란 암호화와 복호화에 동일한 키를 사용하는 암호화 방법을 말합니다. DES, 3DES, AES 등과 같은 많은 대칭 암호화 알고리즘이 있습니다. PHP에서는 mcrypt 확장 라이브러리에서 제공하는 기능을 사용하여 이를 수행할 수 있습니다.

Python을 사용하여 RSA 암호화 알고리즘을 작성하는 방법은 무엇입니까? 소개: RSA는 정보 보안 분야에서 널리 사용되는 비대칭 암호화 알고리즘입니다. 현대 통신에서는 RSA 암호화 알고리즘이 일반적으로 민감한 데이터를 암호화하고 해독하는 데 사용됩니다. 이 기사에서는 Python을 사용하여 RSA 암호화 알고리즘을 작성하는 방법을 소개하고 특정 코드 예제를 제공합니다. Python 라이브러리 설치 RSA 암호화 알고리즘 작성을 시작하기 전에 Python 암호화 라이브러리를 설치해야 합니다. 다음 명령을 사용하여 설치할 수 있습니다: pipinstallrsa generate

PHP 암호화 알고리즘에는 MD5 알고리즘, SHA 알고리즘, AES 알고리즘, RSA 알고리즘, Base64 인코딩, DES 알고리즘, RC4 알고리즘, Blowfish 알고리즘 등이 포함됩니다. 자세한 소개: 1. MD5 알고리즘은 모든 길이의 데이터를 고정 길이 해시 값으로 변환하는 데 사용됩니다. PHP에서는 md5() 함수를 사용하여 문자열의 MD5 해시 값을 계산할 수 있습니다. SHA -1. SHA-256, SHA-512 등. 이 알고리즘은 PHP 3. AES 알고리즘 등에서 해당 기능을 갖습니다.

PHP 웹사이트의 사용자 데이터를 보호하기 위해 암호화 알고리즘을 사용하는 방법은 무엇입니까? 인터넷의 급속한 발전으로 인해 웹사이트의 사용자 데이터 보호가 점점 더 중요해지고 있습니다. PHP 개발에서는 암호화 알고리즘을 사용하여 사용자 데이터의 보안을 보호할 수 있습니다. 이 기사에서는 일반적으로 사용되는 암호화 알고리즘과 이를 PHP 웹사이트에서 사용하여 사용자 데이터를 암호화하는 방법을 소개합니다. 1. 암호화 알고리즘 선택 PHP 웹사이트의 경우 사용자 데이터 보안을 보호하기 위해 일반적으로 사용되는 다음 암호화 알고리즘을 선택할 수 있습니다. 1. 대칭 암호화 알고리즘: 이 알고리즘은 동일한 암호화 알고리즘을 사용합니다.

인터넷 기술의 비약적인 발전과 함께 네트워크 보안은 오늘날 글로벌 정보화 발전의 중요한 요소 중 하나로 자리 잡았습니다. 사이버 공격과 사이버 범죄가 지속적으로 발생함에 따라 네트워크 보안을 보호하는 것은 우리에게 불가피한 선택이 되었습니다. 이 기사에서는 네트워크 보안 기술의 개발 역사에 중점을 둘 것입니다. 1. 암호동물학 시대(1960년대~1980년대) 암호시대의 네트워크 보안 기술은 주로 암호학적 아이디어를 기반으로 개발되었다. 이 시기에는 컴퓨터는 단지 거대한 기계에 불과했고, 인터넷의 사용도 지금처럼 널리 보급되지 않았으므로 제한적이었습니다.

인터넷의 발달로 인해 데이터 보안은 일상 업무에서 주의를 기울여야 하는 심각한 문제가 되었습니다. 민감한 개인 정보나 비즈니스 데이터의 경우 암호화가 특히 중요합니다. PHP 개발에서는 일부 암호화 알고리즘이 널리 사용됩니다. PHP에서 일반적으로 사용되는 암호화 알고리즘을 살펴보겠습니다. 1. Base64 인코딩 Base64 인코딩은 웹 페이지나 이메일에서 바이너리 데이터를 전송할 때 자주 사용됩니다. 웹 페이지나 이메일은 문자열 형식의 데이터만 전송할 수 있고 바이너리 데이터를 직접 전송할 수 없기 때문입니다. Base64는 솔루션입니다

웹 개발에서 보안은 항상 가장 중요한 문제 중 하나였습니다. 키 유출, 데이터 변조, 도난 등의 위험은 항상 존재하므로 데이터 보안을 보호하는 것이 특히 중요합니다. 데이터 보안을 보장하기 위해 당사는 일반적으로 데이터 처리에 암호화 및 암호 해독을 사용합니다. PHP에서는 암호화와 복호화도 매우 중요한 부분입니다. 1. PHP의 암호화 방법 PHP에는 많은 암호화 방법이 있습니다. 아래에서는 일반적으로 사용되는 몇 가지 암호화 방법을 소개합니다. md5 암호화 md5는 일반적으로 사용되는 암호화 방법입니다. 그것
