네트워크 통신 및 파일 저장에서 데이터가 교환되는 경우가 많습니다. 네트워크 통신 트래픽, 파일 저장 크기 및 암호화된 통신 규칙을 줄이기 위해 데이터 보안을 보장하기 위해 데이터의 양방향 암호화 및 복호화를 수행해야 하는 경우가 많습니다.
PHP에서 이 기능을 구현하는 데 필요한 주요 기능은 주로 데이터를 비트 문자열로 압축하는 pack 및 unpack 함수
pack
입니다.
구문: 문자열 팩(문자열 형식, 혼합 [인수]...);
반환 값: 문자열
이 함수는 데이터를 문자열로 압축하고 압축하는 데 사용됩니다.
a - NUL - 패딩된 문자열 [패딩된 문자열] 문자열 공백을 NULL 문자로 패딩
A - SPACE - 패딩된 문자열 [패딩된 문자열]
h - 16진수 문자열, 낮은 "니블 우선"(낮은 니블 우선 )
H - 16진수 문자열, 높은 "니블" [높은 니블 우선](높은 니블 우선)
c - 부호 있는 문자
C – 부호 없는 문자
s – 부호 있는 짧은 패턴 [short] (일반적으로 16비트, 머신 바이트 순서)
S – 부호 없는 부호 있는 짧은 모드 [short](일반적으로 16비트, 머신 바이트 정렬)
n - 부호 없는 짧은 모드 [short](일반적으로 16비트, 빅 엔디안 바이트 정렬)
v - 부호 없는 짧은 패턴 [short](보통 16비트, 리틀 엔디안 바이트 정렬)
i - 부호 있는 정수(크기 및 바이트 순서로 결정됨)
I - 부호 없는 정수(크기 및 바이트로 결정됨) order)
l – 부호 있는 긴 패턴 [long](보통 32비트, 머신 바이트 순서)
L – 부호 없는 긴 모드 [long](보통 32비트, 머신 바이트 순서)
N – 부호 없는 long 모드 [long](보통 32비트, 빅 에디안 바이트 순서)
V – 부호 없는 긴 모드 [long](보통 32비트, 리틀 에디안 바이트 순서)
f – 부동 소수점(크기 및 바이트 순서)
d – double (크기 및 바이트 순서로 결정) 바이트 순서로 결정)
x – NUL 바이트 [NUL 바이트]
>
비트 문자열 데이터를 압축 해제합니다.
구문: 문자열 팩(문자열 형식, 혼합 [인수]...);반환 값: 배열이 함수는 비트 문자열 데이터의 압축을 풀 때 사용됩니다. 이 함수는 동일한 이름의 Perl 함수와 기능 및 사용법이 완전히 동일합니다.
사례 1, pack은 파일 데이터 저장 크기 감소를 구현합니다
<?php //存储整数1234567890 file_put_contents("test.txt", 1234567890);이 때 test.txt의 파일 크기는 10byte입니다. 참고로 이때 파일 크기는 10바이트이고 실제 차지하는 공간은 1KB입니다. 위에 저장된 정수들은 실제로 test.txt 파일에 문자열 형태로 저장됩니다.
단, 정수 바이너리 문자열로 저장하면 4바이트로 줄어듭니다.
<?php print_r(unpack("i", file_get_contents("test.txt")));
사례 2, 데이터 암호화
의미 있는 데이터를 문자열 7-110-abcdefg-117 형식으로 저장합니다.
문자 "-"를 나눈 후 첫 번째 숫자는 문자열의 길이, 두 번째 숫자는 저장 위치, 세 번째 숫자는 실제 저장된 문자열, 네 번째 숫자는 끝 위치를 나타냅니다. rree
위 방법의 단점:
2. 민감한 정보인 경우에는 접근이 안전하지 않을 수 있습니다. 3. 파일 저장 크기가 불규칙하게 증가합니다.
암호화:
<?php file_put_contents("test.txt", "7-110-abcdefg-117");는 데이터 조각을 저장합니다. 암호화 형식은 정수 2자리 문자열 10자리 길이 정수 1자리 길이입니다.
장점:
1. 데이터 크기 최적화
2. "i2a7i1"과 같은 압축 형식을 모르면 파일을 얻어도 제대로 읽을 수 없습니다. 바이너리 파일 변환 일반 텍스트의 경우. 3. 데이터가 증가하면 파일 저장 크기도 그만큼 늘어납니다. 매번 19바이트씩 증가합니다.
사례 3, 키-값 파일 저장
저장에서 생성되는 파일은 인덱스 파일, 데이터 파일 2가지
파일 내 데이터 저장 형식은 다음과 같다 :
코드 구현:
<?php file_put_contents("test.txt", pack("i2a7i1", 7, 110, "abcdefg", 117));

사례 4, 소켓 통신 암호화
두 통신 당사자 모두 암호화 형식을 정의합니다.
예:
<?php error_reporting(E_ALL); class fileCacheException extends Exception{ } //Key-Value型文件存储 class fileCache{ private $_file_header_size = 14; private $_file_index_name; private $_file_data_name; private $_file_index;//索引文件句柄 private $_file_data;//数据文件句柄 private $_node_struct;//索引结点结构体 private $_inx_node_size = 36;//索引结点大小 public function __construct($file_index="filecache_index.dat", $file_data="filecache_data.dat"){ $this->_node_struct = array( 'next'=>array(1, 'V'), 'prev'=>array(1, 'V'), 'data_offset'=>array(1,'V'),//数据存储起始位置 'data_size'=>array(1,'V'),//数据长度 'ref_count'=>array(1,'V'),//引用此处,模仿PHP的引用计数销毁模式 'key'=>array(16,'H*'),//存储KEY ); $this->_file_index_name = $file_index; $this->_file_data_name = $file_data; if(!file_exists($this->_file_index_name)){ $this->_create_index(); }else{ $this->_file_index = fopen($this->_file_index_name, "rb+"); } if(!file_exists($this->_file_data_name)){ $this->_create_data(); }else{ $this->_file_data = fopen($this->_file_data_name, "rb+");//二进制存储需要使用b } } //创建索引文件 private function _create_index(){ $this->_file_index = fopen($this->_file_index_name, "wb+");//二进制存储需要使用b if(!$this->_file_index) throw new fileCacheException("Could't open index file:".$this->_file_index_name); $this->_index_puts(0, '<'.'?php exit()?'.'>');//定位文件流至起始位置0, 放置php标记防止下载 $this->_index_puts($this->_file_header_size, pack("V1", 0)); } //创建存储文件 private function _create_data(){ $this->_file_data = fopen($this->_file_data_name, "wb+");//二进制存储需要使用b if(!$this->_file_index) throw new fileCacheException("Could't open index file:".$this->_file_data_name); $this->_data_puts(0, '<'.'?php exit()?'.'>');//定位文件流至起始位置0, 放置php标记防止下载 } private function _index_puts($offset, $data, $length=false){ fseek($this->_file_index, $offset); if($length) fputs($this->_file_index, $data, $length); else fputs($this->_file_index, $data); } private function _data_puts($offset, $data, $length=false){ fseek($this->_file_data, $offset); if($length) fputs($this->_file_data, $data, $length); else fputs($this->_file_data, $data); } /** * 文件锁 * @param $is_block 是否独占、阻塞锁 */ private function _lock($file_res, $is_block=true){ flock($file_res, $is_block ? LOCK_EX : LOCK_EX|LOCK_NB); } private function _unlock($file_res){ flock($file_res, LOCK_UN); } public function add($key, $value){ $key = md5($key); $value = serialize($value); $this->_lock($this->_file_index, true); $this->_lock($this->_file_data, true); fseek($this->_file_index, $this->_file_header_size); list(, $index_count) = unpack('V1', fread($this->_file_index, 4)); $data_size = filesize($this->_file_data_name); fseek($this->_file_data, $data_size); $value_size = strlen($value); $this->_data_puts(filesize($this->_file_data_name), $value); $node_data = pack("V1V1V1V1V1H32", ($index_count==0) ? 0 : $index_count*$this->_inx_node_size, 0, filesize($this->_file_data_name), strlen($value), 0, $key); $index_count++; $this->_index_puts($this->_file_header_size, $index_count, 4); $this->_index_puts($this->get_new_node_pos($index_count), $node_data); $this->_unlock($this->_file_data); $this->_unlock($this->_file_index); } public function get_new_node_pos($index_count){ return $this->_file_header_size + 4 + $this->_inx_node_size * ($index_count-1); } public function get_node($key){ $key = md5($key); fseek($this->_file_index, $this->_file_header_size); $index_count = fread($this->_file_index, 4); if($index_count>0) { for ($i=0; $i < $index_count ; $i++) { fseek($this->_file_index, $this->_file_header_size + 4 + $this->_inx_node_size * $i); $data = fread($this->_file_index, $this->_inx_node_size); $node = unpack("V1next/V1prev/V1data_offset/V1data_size/V1ref_count/H32key", $data); if($key == $node['key']){ return $node; } } }else{ return null; } } public function get_data($offset, $length){ fseek($this->_file_data, $offset); return unserialize(fread($this->_file_data, $length)); } } //使用方法 $cache = new fileCache(); $cache->add('abcdefg' , 'testabc'); $data = $cache->get_node('abcdefg'); print_r($data); echo $cache->get_data($data['data_offset'], $data['data_size']);
서버와 클라이언트는 COMMAND 형식을 구문 분석하여 해당 DATA 디코딩 방법을 찾고 올바른 데이터를 얻습니다.
위는 자세한 설명입니다. PHP 데이터 압축 및 처리 Decrypt(pack, unpack) 컨텐츠에 대한 자세한 내용은 PHP 중국어 웹사이트(www.php.cn)를 참고하세요!

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\ \;||\xc2\xa0)/","其他字符",$str)”语句。

查找方法:1、用strpos(),语法“strpos("字符串值","查找子串")+1”;2、用stripos(),语法“strpos("字符串值","查找子串")+1”。因为字符串是从0开始计数的,因此两个函数获取的位置需要进行加1处理。


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

Dreamweaver Mac版
시각적 웹 개발 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

SublimeText3 Linux 새 버전
SublimeText3 Linux 최신 버전

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음
