条件1:第一个字符必须是英文或数字或下划线 用哪个字符串函数?
条件2:必须包含一个@ 字符串函数是?
条件3:包含一个以上 . 符
条件4:@符在.符前
条件5:不能以@或.符结尾
条件6:长度不能长于30 这个知道 用mb_strlen
回复讨论(解决方案)
很想了解下,这样的应用场景,还有什么比正则更加合适呢?
很想了解下,这样的应用场景,还有什么比正则更加合适呢?
逐字符分析其实很简单,正则表达式看似简洁但是效率很低
测试一下客户端
<meta charset="utf-8"><?php// 条件1:第一个字符必须是英文或数字或下划线 用哪个字符串函数?// 条件2:必须包含一个@ 字符串函数是?// 条件3:包含一个以上 . 符// 条件4:@符在.符前// 条件5:不能以@或.符结尾// 条件6:长度不能长于30 这个知道 用mb_strlenfunction is_ok_email($email){ $s = substr($email,0,1);//载取第一个字符 $x = ord($s);//第一个字符转为ASCII码 //查ASCII码表得知: //小写英文的ASCII码范围是97-122 //大写英文的ASCII码范围是65-90 //0-9数字的ASCII码范围是48-57 //下划线的ASCII码是95 //因此可以用下面的条件判断 if ( ($x > 96 && $x < 123) || ($x > 64 && $x < 91 ) || ($x > 47 && $x < 58 ) || $x == 95 ) {//过了第一关 $x1 = strpos($email,'@'); if($x1) {//过了第二关 $x2 = strpos($email,'.'); if($x2) {//过了第三关 if($x2 > $x1) {//过了第四关 $s = substr($email,strlen($email)-1,1);//载取最后一字符 if($s != '.' && $s != '@') {//过了第五关 if(strlen($email)< 30) {//过了第六关 return true; } } } } } } return false;}$test[] = '测试qqq@qq.com';$test[] = 'qqqqq.com';$test[] = 'qqqqqcom';$test[] = 'qqqqq.@com';$test[] = 'qqqqq.@com@';$test[] = 'qqqqq.@com@.';$test[] = '123456@qq.com.';$test[] = '123456@qq.com';$test[] = '123456@qq.comcomcomcomcomcomcomcomcomcomcomcom';foreach($test as $v){ echo $v; if(is_ok_email($v)) { echo '是正确的email'; }else { echo '不是正确的email'; } echo '<br>';}
很想了解下,这样的应用场景,还有什么比正则更加合适呢?
逐字符分析其实很简单,正则表达式看似简洁但是效率很低
其实这是种想象,在实际的线上环境 因为正则而影响效率的事情几乎不存在 不但不存在反而提高了开发的速度。
谢谢大神,我知道用正则很容易,我是为了练习字符串函数
闲了练练手,不一定对
<?phpfunction is_email_string($s){ if (!is_string($s) || (($len = strlen($s)) < 3)) { return false; } if($len > 30) { return false; } $lb = $len - 1; $state = 0; $dot_count = [0, 0]; for ($i = 0; $i < $len; $i++) { $c = $s[$i]; if ($c == '.') { if ($i == 0 || $i == $lb) { return false; } $dot_count[$state]++; } elseif ($c == '@') { if ($state != 0 || $i == 0 || $i == $lb) { return false; } $state = 1; continue; } } if ($dot_count[0] > 0 || $dot_count[1] < 1) { return false; // 按楼主要求,.出现在@前或没有.出现在@后就算错误 } return true;}$x = '12@163com';var_dump(is_email_string($x));
上面代码少了判断其他字符必须是英文或数字或下划线
<meta charset="utf-8"><?php// 条件1:第一个字符必须是英文或数字或下划线 用哪个字符串函数?// 条件2:必须包含一个@ 字符串函数是?// 条件3:包含一个以上 . 符// 条件4:@符在.符前// 条件5:不能以@或.符结尾// 条件6:长度不能长于30 这个知道 用mb_strlenfunction is_ok_email($email){ $s = substr($email,0,1);//载取第一个字符 $x = ord($s);//第一个字符转为ASCII码 //查ASCII码表得知: //小写英文的ASCII码范围是97-122 //大写英文的ASCII码范围是65-90 //0-9数字的ASCII码范围是48-57 //下划线的ASCII码是95 //因此可以用下面的条件判断 if ( ($x > 96 && $x < 123) || ($x > 64 && $x < 91 ) || ($x > 47 && $x < 58 ) || $x == 95 ) {//过了第一关 $x1 = strpos($email,'@'); if($x1) {//过了第二关 $x2 = strpos($email,'.'); if($x2) {//过了第三关 if($x2 > $x1) {//过了第四关 $s = substr($email,strlen($email)-1,1);//载取最后一字符 if($s != '.' && $s != '@') {//过了第五关 if(strlen($email)< 30) {//过了第六关 return true; } } } } } } return false;}$test[] = '测试qqq@qq.com';$test[] = 'qqqqq.com';$test[] = 'qqqqqcom';$test[] = 'qqqqq.@com';$test[] = 'qqqqq.@com@';$test[] = 'qqqqq.@com@.';$test[] = '123456@qq.com.';$test[] = '123456@qq.com';$test[] = '123456@qq.comcomcomcomcomcomcomcomcomcomcomcom';foreach($test as $v){ echo $v; if(is_ok_email($v)) { echo '是正确的email'; }else { echo '不是正确的email'; } echo '<br>';}
大神啊,刚刚发现个问题,strpos是查找字符串首次出现的位置 比如说我输入个地址:123@qq.@.con 这样也会通过哦.
再来个,可以继续改进
<?phpfunction is_email_string($s){ if (!is_string($s) || (($len = strlen($s)) < 3) || $len > 30) { return false; } $lb = $len - 1; $state = 0; $dot_count = [0, 0]; for ($i = 0; $i < $len; $i++) { $c = $s[$i]; if ($c == '.') { if ($i == 0 || $i == $lb) { return false; } $dot_count[$state]++; } elseif ($c == '@') { if ($state != 0 || $i == 0 || $i == $lb) { return false; } $state = 1; continue; } elseif (!($c == '_' || ($c >= 'a' && $c <= 'z') || ($c >= 'A' && $c <= 'Z') || ($c >= '0' && $c <= '9'))) { return false; } } if ($dot_count[0] > 0 || $dot_count[1] < 1) { return false; } return true;}$x = '12@163.com';var_dump(is_email_string($x));
条件1:第一个字符必须是英文或数字或下划线 用哪个字符串函数?
if($email{0} == '_' || ($email{0} >= '0' && $email{0} = 'A' || strtoupper($email{0})
条件2:必须包含一个@ 字符串函数是?
if(substr_count($email, '@') == 1)
条件3:包含一个以上 . 符
if(substr_count($email, '.') >= 1)
条件4:@符在.符前
if(strpos($email, '@')
条件5:不能以@或.符结尾
if(substr($email, -1) != '@' && substr($email, -1) != '.')
条件6:长度不能长于30 这个知道 用mb_strlen
if(strlen($eamil)
判断这些,其实并不一定要一项一项来,它们是可以关联到一起的,思路不用太窄。
如果一定要用各种函数,像explode('@', $email),得到的数组长度是二说明必只有一个@,再简单判断两个元素的内容,就可以达到目的。
大神就是大神啊,太给力了.

phpsessionscanstorestrings, 숫자, 배열 및 객체 1.Strings : TextDatalikeUsernames.2.numbers : integorfloatsforcounters.3.arrays : listslikeshoppingcarts.4.objects : complexStructuresThatareserialized.

세션 재생은 세션 고정 공격의 경우 사용자가 민감한 작업을 수행 할 때 새 세션 ID를 생성하고 이전 ID를 무효화하는 것을 말합니다. 구현 단계에는 다음이 포함됩니다. 1. 민감한 작업 감지, 2. 새 세션 ID 생성, 3. 오래된 세션 ID 파괴, 4. 사용자 측 세션 정보 업데이트.

PHP 세션은 응용 프로그램 성능에 큰 영향을 미칩니다. 최적화 방법은 다음과 같습니다. 1. 데이터베이스를 사용하여 세션 데이터를 저장하여 응답 속도를 향상시킵니다. 2. 세션 데이터 사용을 줄이고 필요한 정보 만 저장하십시오. 3. 비 차단 세션 프로세서를 사용하여 동시성 기능을 향상시킵니다. 4. 사용자 경험과 서버 부담의 균형을 맞추기 위해 세션 만료 시간을 조정하십시오. 5. 영구 세션을 사용하여 데이터 읽기 및 쓰기 시간의 수를 줄입니다.

phpsessionsareser-side, whilecookiesareclient-side.1) sessions stessoredataontheserver, andhandlargerdata.2) cookiesstoredataonthecure, andlimitedinsize.usesessionsforsensitivestataondcookiesfornon-sensistive, client-sensation.

phpidifiesauser의 sssessionusessessioncookiesandssessionids.1) whensession_start () iscalled, phpgeneratesauniquessessionStoredInacookienamedPhpsSessIdonSeuser 'sbrowser.2) thisidallowsphptoretrievessessionDataTromServer.

PHP 세션의 보안은 다음 측정을 통해 달성 할 수 있습니다. 1. Session_REGENEREAT_ID ()를 사용하여 사용자가 로그인하거나 중요한 작업 일 때 세션 ID를 재생합니다. 2. HTTPS 프로토콜을 통해 전송 세션 ID를 암호화합니다. 3. 세션 _save_path ()를 사용하여 세션 데이터를 저장하고 권한을 올바르게 설정할 보안 디렉토리를 지정하십시오.

phpsessionfilesarestoredInTheRectorySpecifiedBysession.save_path, 일반적으로/tmponunix-likesystemsorc : \ windows \ temponwindows.tocustomizethis : 1) austession_save_path () toSetacustomDirectory, verlyTeCustory-swritation;


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

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

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

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

Dreamweaver Mac版
시각적 웹 개발 도구
