这篇文章介绍的内容是关于php的常用函数,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 <?php /** * @StrHidtel 字符串打码 * =========================== * @Str 字符串 * @Percen 百分比 * @Count 次数 * @ToStr 替换的字符串 */ function StrHidtel($Str, $Percen = 30, $Count = 1, $ToStr = "0") { // 判断字符串长度 $StrLen = mb_strlen($Str, "UTF-8"); // 计算中间百分比值 $MaxLen = ceil($StrLen * $Percen / 100); $StartLen = $StrLen - $MaxLen; // 生成同等长度的* $Blurry = str_repeat($ToStr, $MaxLen); // 截取要替换的字符串 $ShifText = mb_substr($Str, $StartLen / 2, $MaxLen, "UTF-8"); // 替换字符串 return str_replace($ShifText, $Blurry, $Str, $Count); } /** * @SaveLog 存储日志 * ========================= * @Text 储存内容 * @Type 类型 */ function SaveLog ($Type, $Text) { // 初始化 date_default_timezone_set("PRC"); $day=date("Y-m-d",time()); $Time = "[".date("Y-m-d H:i:s",time())."]"; $hade="[".$_SERVER['REQUEST_URI']."]"; $LogPath = './'; $FilePath = $LogPath.$Type.$day.".log"; // 判断文件是否存在 $f = fopen ($FilePath, "ab+"); // 写入 fwrite($f, "$Time-$hade-$Text"."\r\n"); fclose($f);}/** * @GetIP 获取客户端IP */ function getIP() { if (getenv('HTTP_CLIENT_IP')) { $ip = getenv('HTTP_CLIENT_IP'); } elseif (getenv('HTTP_X_FORWARDED_FOR')) { $ip = getenv('HTTP_X_FORWARDED_FOR'); } elseif (getenv('HTTP_X_FORWARDED')) { $ip = getenv('HTTP_X_FORWARDED'); } elseif (getenv('HTTP_FORWARDED_FOR')) { $ip = getenv('HTTP_FORWARDED_FOR'); } elseif (getenv('HTTP_FORWARDED')) { $ip = getenv('HTTP_FORWARDED'); } else { $ip = $_SERVER['REMOTE_ADDR']; } preg_match("/^(\d|\.)+$/si", $ip, $isip); if($isip == NULL) { F404("系统无法验证您的身份:$ip"); exit; } return $ip; } /** * @IntIp 获取客户端的Int型IP */ function IntIp() { // 转换为数字IP $IntIP = ip2long(getIP()); // 判断是否转换失败 if ($IntIP) { return $IntIP; } else { return false; }} /** * @OrderGenerate 订单号生成 * =========================== * @UserID 用户ID * @Type 订单类型 1:充值, 2:提现, 或获取具体类型 * @ID 相关ID */ function OrderGenerate($UserID, $Type, $ID = "0") { // 初始化 $Time = time(); $IP = str_pad(abs(IntIp()), 10, "0"); // 生成随机数3位 $RandSub = RandomStr(3, 1); // 填补用户ID $UserText = str_pad($UserID, 10, "0", STR_PAD_LEFT); // 初始化8 $OrderID = date("Ymd", $Time); // 截取最后一位相关ID9 $OrderID .= substr($ID, -1); // 填补类型ID14 $OrderID .= str_pad($Type, 5, "0"); // 填充随机数17 $OrderID .= $RandSub; // 填充IP前半段19 $OrderID .= mb_substr($IP, 3, 2); // 填补时间戳后5位24 $OrderID .= mb_substr($Time, 4, 5); // 填充IP前后段29 $OrderID .= mb_substr($IP, 7, 3); // 截取用户后4位ID31 $OrderID .= mb_substr($UserText, 6, 4); // 输出 return $OrderID; } /** * @IsString 判断变量是否存在且为字符串 * ======================================= * @Variable 实际传入变量 Array * @KeyName 键名 Array * @Exclude 排除 */ function IsString ($IsString, $KeyName, $Exclude = array()) { // 判断条数是否相等 if((is_array($IsString) && is_array($KeyName) && count($IsString) == count($KeyName)) || (count($IsString) == (count($KeyName) + count($Exclude)))) { // 循环实际传入变量 foreach($KeyName as $List => $As) { // 判断是否存在于传入之中,且为字符串 if(!(isset($IsString[$As]) && (is_string($IsString[$As]) || is_int($IsString[$As])))) { if (!in_array($As, $Exclude)) { return false; } } } // 无误输出 return true; } else { return false; } } $date=['a'=>123,'b'=>456,'c'=>789,'d'=>'<script>alert(111111)</script>']; /** * @IsUtf8 编码转换 * @Str 传入字符串 */ function IsUtf8($Str) { $encode = mb_detect_encoding($Str, array("ASCII",'UTF-8',"GB2312","GBK","BIG5")); if($encode != 'UTF-8') { $Str = iconv($encode,"UTF-8",$Str);; } return $Str;} /********************php验证身份证号码是否正确函数*********************/ function is_idcard( $id ){ $id = strtoupper($id); $regx = "/(^\d{15}$)|(^\d{17}([0-9]|X)$)/"; $arr_split = array(); if(!preg_match($regx, $id)) { return FALSE; } if(15==strlen($id)) //检查15位 { $regx = "/^(\d{6})+(\d{2})+(\d{2})+(\d{2})+(\d{3})$/"; @preg_match($regx, $id, $arr_split); //检查生日日期是否正确 $dtm_birth = "19".$arr_split[2] . '/' . $arr_split[3]. '/' .$arr_split[4]; if(!strtotime($dtm_birth)) { return FALSE; } else { return TRUE; } } else //检查18位 { $regx = "/^(\d{6})+(\d{4})+(\d{2})+(\d{2})+(\d{3})([0-9]|X)$/"; @preg_match($regx, $id, $arr_split); $dtm_birth = $arr_split[2] . '/' . $arr_split[3]. '/' .$arr_split[4]; if(!strtotime($dtm_birth)) //检查生日日期是否正确 { return FALSE; } else { //检验18位身份证的校验码是否正确。 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。 $arr_int = array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); $arr_ch = array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); $sign = 0; for ( $i = 0; $i <br> 推荐 관련 추천: <p></p><p>학습 노트의 PHP 기능 </p><p></p>
위 내용은 PHP에서 자주 사용되는 함수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

phpsession 실패 이유에는 구성 오류, 쿠키 문제 및 세션 만료가 포함됩니다. 1. 구성 오류 : 올바른 세션을 확인하고 설정합니다. 2. 쿠키 문제 : 쿠키가 올바르게 설정되어 있는지 확인하십시오. 3. 세션 만료 : 세션 시간을 연장하기 위해 세션을 조정합니다 .GC_MAXLIFETIME 값을 조정하십시오.

PHP에서 세션 문제를 디버그하는 방법 : 1. 세션이 올바르게 시작되었는지 확인하십시오. 2. 세션 ID의 전달을 확인하십시오. 3. 세션 데이터의 저장 및 읽기를 확인하십시오. 4. 서버 구성을 확인하십시오. 세션 ID 및 데이터를 출력, 세션 파일 컨텐츠보기 등을 통해 세션 관련 문제를 효과적으로 진단하고 해결할 수 있습니다.

Session_Start ()로 여러 통화를하면 경고 메시지와 가능한 데이터 덮어 쓰기가 발생합니다. 1) PHP는 세션이 시작되었다는 경고를 발행합니다. 2) 세션 데이터의 예상치 못한 덮어 쓰기를 유발할 수 있습니다. 3) Session_status ()를 사용하여 반복 통화를 피하기 위해 세션 상태를 확인하십시오.

SESSION.GC_MAXLIFETIME 및 SESSION.COOKIE_LIFETIME을 설정하여 PHP에서 세션 수명을 구성 할 수 있습니다. 1) SESSION.GC_MAXLIFETIME 서버 측 세션 데이터의 생존 시간을 제어합니다. 2) 세션 .Cookie_Lifetime 클라이언트 쿠키의 수명주기를 제어합니다. 0으로 설정하면 브라우저가 닫히면 쿠키가 만료됩니다.

데이터베이스 스토리지 세션 사용의 주요 장점에는 지속성, 확장 성 및 보안이 포함됩니다. 1. 지속성 : 서버가 다시 시작 되더라도 세션 데이터는 변경되지 않아도됩니다. 2. 확장 성 : 분산 시스템에 적용하여 세션 데이터가 여러 서버간에 동기화되도록합니다. 3. 보안 : 데이터베이스는 민감한 정보를 보호하기 위해 암호화 된 스토리지를 제공합니다.

SessionHandlerInterface 인터페이스를 구현하여 PHP에서 사용자 정의 세션 처리 구현을 수행 할 수 있습니다. 특정 단계에는 다음이 포함됩니다. 1) CustomsessionHandler와 같은 SessionHandlerInterface를 구현하는 클래스 만들기; 2) 인터페이스의 방법 (예 : Open, Close, Read, Write, Despare, GC)의 수명주기 및 세션 데이터의 저장 방법을 정의하기 위해 방법을 다시 작성합니다. 3) PHP 스크립트에 사용자 정의 세션 프로세서를 등록하고 세션을 시작하십시오. 이를 통해 MySQL 및 Redis와 같은 미디어에 데이터를 저장하여 성능, 보안 및 확장 성을 향상시킬 수 있습니다.

SessionId는 웹 애플리케이션에 사용되는 메커니즘으로 사용자 세션 상태를 추적합니다. 1. 사용자와 서버 간의 여러 상호 작용 중에 사용자의 신원 정보를 유지하는 데 사용되는 무작위로 생성 된 문자열입니다. 2. 서버는 쿠키 또는 URL 매개 변수를 통해 클라이언트로 생성하여 보낸다. 3. 생성은 일반적으로 임의의 알고리즘을 사용하여 독창성과 예측 불가능 성을 보장합니다. 4. 실제 개발에서 Redis와 같은 메모리 내 데이터베이스를 사용하여 세션 데이터를 저장하여 성능 및 보안을 향상시킬 수 있습니다.

JWT 또는 쿠키를 사용하여 API와 같은 무국적 환경에서 세션을 관리 할 수 있습니다. 1. JWT는 무국적자 및 확장 성에 적합하지만 빅 데이터와 관련하여 크기가 크다. 2. 쿠키는보다 전통적이고 구현하기 쉽지만 보안을 보장하기 위해주의해서 구성해야합니다.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

WebStorm Mac 버전
유용한 JavaScript 개발 도구

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

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