简体   繁体   中英

I have a problem with the strpos & substr function on PHP

I have a problem with the strpos & substr function, thank you for your help:

$temp = "U:hhp|E:123@gmail.com,P:h123";

$find_or = strpos($temp,"|");
$find_and = strpos($temp,",");

$find_user = substr($temp,2,$find_or-2);
$find_email = substr($temp,$find_or+3,$find_and);
$find_passeord = substr($temp,$find_and+3,strlen($temp));

echo("$find_user+$find_email+$find_passeord<br/>");

/************************************/

Why is the output like this??

hhp+123@gmail.com,P:h123 +h123

but i want this:

hhp+123@gmail.com,h123

The problem is that $find_and is the index of , , but the third argument to substr() needs to be the length of the substring, not the ending index. So

$find_email = substr($temp,$find_or+3,$find_and);

should be

$find_email = substr($temp,$find_or+3,$find_and-$find_or-3);

For $find_passeord you can omit the 3rd argument, since the default is the end of the string.

However, this would be simpler with a regular expression:

if (preg_match('/^U:(.*?)\|E:(.*?),P:(.*)/', $temp, $match)) {
    list($whole, $user, $email, $password) = $match;
}

if you have control over the input I would suggest

$temp = "U:hhp|E:123@gmail.com|P:h123";
list($user, $email, $password) = explode("|",$temp);
$user = explode(":",$user)[1];
$email = explode(":",$email)[1];
$password = explode(":",$password)[1];

if not then I still recommend exploding the string into parts and work your way down to what you need. https://3v4l.org/ is a great site for testing php code... here is an example of this working https://3v4l.org/upEGG

Echoing what Barmar just said in a comment, regular expressions are definitely the best way to "break up a string." (It is quite-literally much of what they are for.) This is the preg_ family of PHP functions. (eg preg_match , preg_match_all , preg_replace .)

The million-dollar idea behind a "regular expression" is that it is a string-matching pattern. If the string "matches" that pattern, you can easily extract the exact substrings which matched portions of it.

In short, all of the strpos/substr logic that you are right now wrestling with... "goes away!" Poof.

For example, this pattern: ^(.*)|(.*),(.*)$ ...

It says: "Anchored at the beginning of the string ^ , capture () a pattern consisting of "zero or more occurrences of any character (.*) , until you encounter a literal | . Now, for the second group, proceed until you find a , . Then, for the third group, proceed to take any character until the end of the string $ ."

You can "match" that regular expression and simply be handed all three of these groups. (As well as "the total string that matched.") And you didn't have to "write" a thing!

There are thousands of web pages by now which discuss this "remarkable 'programming language' within a single cryptic string." But it just might be the most pragmatically-useful technology for any practitioner to know, and every programming language somehow implements it, more-or-less following the precedent first set by the (still active) programming language, Perl .

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM