[PHP字符串]⑦--邮箱校验

strpos 查找字符串首次出现的位置

stripos 忽略大小写

strrpos 最后一次出现的位置

strripos 最后一次出现的位置 并忽略大小写

Paste_Image.png
Paste_Image.png
<?php

$email = '38@2771946@qq.com';
var_dump(strpos($email, '@')) . "<br/>";//int 2

$str = 'abcdef';
var_dump(strpos($str, 'ab')) . "<br/>";//int 0

var_dump(strpos($str, 'ar')) . "<br/>";//boolean false

var_dump(strpos($str, 'F')) . "<br/>";//boolean false

var_dump(stripos($str, 'F')) . "<br/>";//int 5

//strrpos 最后一次出现的位置
var_dump(strrpos($str, 'd')) . "<br/>";//int 3

//strripos 忽略大小写最后一次出现的位置
var_dump(strripos($str, 'D')) . "<br/>";//int 3

?>

修改代码

if (strpos($email, '@') == false) {
    exit("非法邮箱<br/>" . $redirectUrl);
}

doAction.php

<?php
header("content-type:text/html;charset=utf-8");

$username = $_POST['username'];
$password = $_POST['password'];
$password1 = $_POST['password1'];
$email = $_POST['email'];
//    $fav=$_POST['fav'];
//    $verify=$_POST['verify'];
$redirectUrl = '<a href="reg.php" > 重新注册</a > ';

//$char = $username{0};
$char = substr($username, 0, 1);
$ascii = ord($char);
if (!(($ascii >= 65 && $ascii <= 90) || ($ascii >= 97 && $ascii <= 122))) {
    exit('用户名首字母不是以字母开始' . $redirectUrl);
}

$userLen = strlen($username);
if ($userLen < 6 || $userLen > 10) {
    exit('用户名长度不符合规范 <br/>' . $redirectUrl);
}

$pwdLen = strlen($password);
if ($pwdLen == 0) {
    exit('密码不能为空<br/>' . $redirectUrl);
}
if ($pwdLen < 6 || $pwdLen > 10) {
    die("密码长度不符合规范" . $redirectUrl);
}

//if ($password !== $password1) {
//    exit("两次密码不一致<br/>" . $redirectUrl);
//}
if (strcmp($password, $password1) !== 0) {
    exit("两次密码不一致<br/>" . $redirectUrl);
}

//位置0也是false
if (strpos($email, '@') == false) {
    exit("非法邮箱<br/>" . $redirectUrl);
}


?>
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容