字符串是 PHP 中重要的数据类型之一。在 Web 开发中,很多情况下都需要对字符串进行处理和分析,通常将涉及字符串的格式化、字符串的连接与分割、字符串的比较、查找等一系列操作。用户和系统的交互也基本上是用文字来进行的,因此系统对文本信息,即字符串的处理非常重要。
$str = "zhant";
// 字符串可以当做数组一样通过下标访问每一个字符
echo $str[0]; // z
echo $str{2}; // a
// 修改字符串内容
$str{4} = "g";
echo $str; // zhang
// 一个中文的汉字占三个字节
$title = "你好";
// strlen返回字符串的长度
echo strlen($title); // 6
// 那么访问的时候,我们需要进行拼接
echo $title{0}.$title{1}.$title{2}; // 你
生成一个随机的四位验证码
// 生成a-z A-Z 0-9 组成的字符串
$codes = implode("",range('a','z')).implode("",range('A','Z')).implode("",range(0,9));
$code = '';
for ($i=0; $i < 4; $i++) {
// 获取随机索引数
$index = mt_rand(0,strlen($codes)-1);
$code .= $codes[$index];
}
echo "<span style='color:red'>{$code}<span>";
strcmp和strcasecmp字符串比较函数
strcmp:https://www.php.net/manual/zh/function.strcmp.php
strcasecmp:https://www.php.net/manual/zh/function.strcasecmp.php
// 字符串比较函数 如果 str1 小于 str2 返回 < 0; 如果 str1 大于 str2 返回 > 0;如果两者相等,返回 0。
// strcmp ( string $str1 , string $str2 ) : int 严格区分大小写
echo strcmp('abc','ab'); // 1
echo strcmp('abc','abd'); // -1
echo strcmp('abc','ABC'); // 1
echo strcmp('abc','abc'); // 0
// 根据ASCII码逐个进行比较
// -------------------------------------
// strcasecmp 和上述返回值一样 但不区分大小写
echo strcasecmp('abc','ABC'); // 0
echo strcasecmp('abc','abc'); // 0
字符串的拆分与合并操作
implode() 数组的值转化为字符串 join()是该函数的别名: implode()
explode字符串转数组:https://www.php.net/manual/zh/function.explode.php
list() 把数组中的值赋给一组变量:https://www.php.net/manual/zh/function.list.php
$study = ['html','css','js','es6','jquery','vue','react'];
// 数组转字符串函数 第一个参数为分隔符 第二个参数为数组
echo implode('---',$study);
// html---css---js---es6---jquery---vue---react
echo join(',',$study);
// html,css,js,es6,jquery,vue,react
// explode 字符串转换为数组
$str = "html,css,js,es6,jquery,vue,react";
// 以什么来拆分字符串
print_r(explode(",", $str));
/*
Array ( [0] => html [1] => css [2] => js [3] => es6 [4] => jquery [5] => vue [6] => react )
*/
// 第三个参数指定拆分成几个数组
print_r(explode(",", $str,6));
/*
Array ( [0] => html [1] => css [2] => js [3] => es6 [4] => jquery [5] => vue,react )
*/
// -------------------------
// list() 将数组的值赋值给若干变量
list($localhost,$username,$password,,$port) = explode(":", 'localhost:root:root:utf8:3306');
echo "mysql:host={$localhost};username={$username};password={$password};port={$port}";
/* mysql:host=localhost;username=root;password=root;port=3306 */
// 关联数组 赋值给变量要以键值对的方式一一对应
$params = ['host'=>'localhost','username'=>'root','password'=>'root'];
list('host'=>$host,'username'=>$username,'password'=>$password) = $params;
printf("host=%s;username=%s;password=%s",$host,$username,$password);
/* host=localhost;username=root;password=root */
字符串截取
// substr()字符串截取函数
echo substr('abcdefg',3,2); // de
echo substr('abcdefg',3); // defg
echo substr('abcdefg',-3); // efg
// ASCII转换函数 chr() ord() 一般用于判断用户名是否以字母开头,截取第一个字符判断其ASCII的大小范围 A 65 a 97
// ASCII对照表http://c.biancheng.net/c/ascii/
// ucfirst 将首字母转换为大写
// ord() 字符串转ASCII码
// chr() ASCII码转字符
$username = 'admin';
echo ord(substr(ucfirst($username),0,1))>=65 && ord(substr(ucfirst($username),0,1))<=90?'用户名正确':'用户名请以字母开头';
echo strlen($username)<4||strlen($username)>10?'用户名长度需为6-10个字符':'用户名正确';
字符串替换函数(敏感词转义)
str_replace() 子字符串替换:https://www.php.net/manual/zh/function.str-replace.php
// 将window系统的目录分割符替换为Linux目录分隔符
$path = "D:\phpstudy_pro\Extensions\php\php7.3.9nts\php.exe";
// 查看当前操作系统支持的路径分隔符
echo DIRECTORY_SEPARATOR;
// 需要替换的字符内容 替换后的字符内容 字符串
echo str_replace('\\','/',$path);
/* D:/phpstudy_pro/Extensions/php/php7.3.9nts/php.exe */
// 第四个参数可以接收替换的次数
echo str_replace('转账','***','支持微信大额转账,支付宝转账,银行卡转账',$count);
// 支持微信大额***,支付宝***,银行卡***
echo "\'转账\'敏感词出现次数:{$count}";
// 第一个参数 需要替换的字符内容可以是一个数组
$vowels = array("赌博","美女",'发牌','澳门');
echo str_replace($vowels, "**", "欢迎访问赌博平台,澳门皇冠赌博网站,美女在线发牌");
// 欢迎访问**平台,**皇冠**网站,**在线**
// 敏感词和替换内容都可以为数组,将替换为对应的内容
$search = ['交友','广告','转账','直播','带货','陪聊','异性'];
$flag = ['***','---','&&&','000','*货*','聊天','同性'];
$news = '本公司承接各类广告代理,提供直播和带货教学服务,提供异性交友在线陪聊服务……';
echo str_replace($search,$flag,$news);
/* 本公司承接各类---代理,提供000和*货*教学服务,提供同性***在线聊天服务…… */
parse_str() 将字符串解析成数组
https://www.php.net/manual/zh/function.parse-str.php
parse_url() 解析 URL,返回其组成部分的数组
https://www.php.net/manual/zh/function.parse-url.php
http_build_query 生成URL_encode之后的请求字符串
https://www.php.net/manual/zh/function.http-build-query.php
// parse_str() 将字符串解析成数组
$str = "first=value&arr[]=foo+bar&arr[]=baz";
parse_str($str, $output);
extract($output);
echo $first; // value
echo $arr[0]; // foo bar
echo $arr[1]; // baz
$url = "id=1&name=zhang&gender=1";
parse_str($url,$result);
echo "<pre>";
print_r($result);
/*
Array
(
[id] => 1
[name] => zhang
[gender] => 1
)
*/
// --------------------------------
// parse_url() 解析 URL,返回其组成部分的数组
$url = 'http://zhang.com:password@hostname/0425/demo.php?id=1&name=zhang#anchor';
echo "<pre>";
print_r(parse_url($url));
/*
Array
(
[scheme] => http
[host] => hostname
[user] => zhang.com
[pass] => password
[path] => /0425/demo.php
[query] => id=1&name=zhang
[fragment] => anchor
)
*/
// 可以通过设置第二个参数来返回需要的部分
echo parse_url($url,PHP_URL_QUERY); // id=1&name=zhang
echo parse_url($url, PHP_URL_PATH); // /0425/demo.php
// -------------------------------------------
// http_build_query — 生成 URL-encode 之后的请求字符串
$url = "http://zhang.com?name=张珊&age=20&email=zhang@qq.com";
$query = parse_url($url,PHP_URL_QUERY);
// name=张珊&age=20&email=zhang@qq.com
// 获取到query在通过parse_str转换为数组
parse_str($query,$params);
echo "<pre>";
print_r($params);
/*
Array
(
[name] => 张珊
[age] => 20
[email] => zhang@qq.com
)
*/
// 请求参数转为Unicode
echo http_build_query($params);
// name=%E5%BC%A0%E7%8F%8A&age=20&email=zhang%40qq.com
// http_build_query参数不光可以为数组,也可以为一个对象
echo http_build_query(new class{
public $name = 'admin';
public $email = 'admin@php.cn';
private $gender = 'male'; // 私有成员
});
// name=admin&email=admin%40php.cn
html中输出一张图片
<img src='https://c-ssl.duitang.com/uploads/item/202006/20/20200620205947_kxnPk.thumb.1000_0.jpeg' alt='美女' width="300">
将 PHP 脚本伪装成image图片
// 伪装响应请求头
header('content-type:image/jpg');
// 打开文件
$file = file_get_contents('https://c-ssl.duitang.com/uploads/item/202006/20/20200620205947_kxnPk.thumb.1000_0.jpeg');
echo $file;
// 由于设置了响应头,当前脚本只能解析图片,html标签中可以通过链接该文件路径,从而显示图片内容
这样可以在html中通过img标签链接该脚本显示图片
<img src="http://zhang.com/0430/demo.php" width="300">
将图片进行base64编码处理
base64_encode(): 使用 MIME base64 对数据进行编码
https://www.php.net/manual/zh/function.base64-encode.php
base64_decode():对使用 MIME base64 编码的数据进行解码
https://www.php.net/manual/zh/function.base64-decode.php
<?php
$str = 'This is an encoded string';
echo base64_encode($str); // 编码后的字符串数据
// VGhpcyBpcyBhbiBlbmNvZGVkIHN0cmluZw==
$file = file_get_contents('https://c-ssl.duitang.com/uploads/item/202006/20/20200620205947_kxnPk.thumb.1000_0.jpeg');
$imgbs64 = base64_encode($file);
echo $imgbs64; // 输出60位的散列值
?>
// 通过img标签显示bs64位的图片
<img src="data:image/jpeg;base64,<?=$imgbs64 ?>" width="300">
图中我们可以看出,经过bs64编码处理的图片链接超级长,且用户无法获取图片真实的链接
md5() 返回32位散列值
https://www.php.net/manual/zh/function.md5.php
sha1() 返回40位散列值
https://www.php.net/manual/zh/function.sha1.php
由于以上函数依赖的算法已不足够复杂,不推荐使用对明文密码加密
password_hash — 创建密码的散列(推荐)
password_verify — 验证密码是否和散列值匹配
// md5() 和sha1() 由于是有机可循的,我们可以对其进行加盐处理
$salt = 'zhangshuai';
echo sha1('root'.$salt);
// 43f5582e40049d275977f9ed76c8972723e9b4b5
// --------------------------------------------
// password_hash 创建密码的散列
$pwd = password_hash('zhang',PASSWORD_DEFAULT);
echo $pwd; // 返回 60 个字符的字符串
// password_verify — 验证密码是否和散列值匹配
echo password_verify('zhang',$pwd)?'密码正确':'密码错误';
// ------------------------------------------
// md5_file() 对文件进行散列处理
// 生成md5进行存储文件中
$file_md5 = md5_file('demo.php');
file_put_contents('md5file.txt',$file_md5);
// 在另一个PHP文件中进行验证,当demo.php被修改时,无法与文件中存储的md5进行匹配
if(md5_file('demo.php') === file_get_contents('md5file.txt')){
echo "文件是安全的没有被恶意篡改";
}else{
echo "警告!文件已被篡改";
}
stripos() 用来查找字符串中某部分字符串首次出现的位置(不区分大小写)
strripos() 用来计算指定字符串在目标字符串中最后一次出现的位置(不区分大小写)
strpos() 用来查找字符串首次出现的位置
strrpos() 用来查找字符串中最后一次出现的位置
var_export(stripos('xyz', 'c'));; // 未发现将返回 false
echo stripos('ABCabc', 'c'); // 返回首次出现位置 2
echo strripos('ABCabcd', 'c'); // 最后一次出现位置 5
echo strpos('ABCabc','c'); // 5 区分大小写
echo strpos('ABCabc','C'); // 2
echo strrpos('ABCcabcAb','c'); // 6
PHP测试题答案
1-5:C ABD D C A
6-10:AD D B C A
11-15:A B ACD D A
16-20:B A D A B
21-23:C B C
作业内容:完成一个用户注册页面, 用xmind文件中总结的字符串函数库,对表单字段进行验证? 比如限制密码长度,两次密码须一致, 验证码验证,用户名首位需是字母等等?
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>用户注册页面</title>
<link rel="stylesheet" type="text/css" href="css/regist.css">
</head>
<body>
<div class="wrapper">
<article>
<h1><span>个人博客注册</span></h1>
<div class="main">
<form action="" method="post"onsubmit="return false">
<div class="tel">
<input type="email" name="email" placeholder="请输入邮箱" id="telephone" required >
</div>
<div class="userName">
<input type="text" name="userName" placeholder="请输入用户名" id="username" required>
</div>
<div class="password">
<input type="password" name="pwd" placeholder="请输入密码" id="pwd" required>
</div>
<div class="againpwd">
<input type="password" name="cpwd" placeholder="请再次输入密码" id="cmpwd" required>
</div>
<div class="captcha">
<input type="text" name="captcha" id="captcha" placeholder="请输入验证码" required>
<img width="60" height="37" onclick="this.src='gd_captcha.php?'+new Date().getTime();" style="margin: 10px auto;vertical-align: bottom;" src="gd_captcha.php">
<em id="captchainfo">提示信息……</em>
</div>
<button>注册</button>
</form>
</div>
</article>
</div>
<script type="text/javascript" src="js/reg.js"></script>
</body>
</html>
/* 登录页面样式 regist.css */
*{ margin: 0;padding: 0;font-family: 微软雅黑;}
em{display: block;font-style: normal;font-size: 14px;color:red}
li{list-style: none;display: inline-block;}
li a{text-decoration: none;}
html,body,.wrapper{
width: 100%;
height: 100%;
overflow: hidden;
}
.wrapper{
background: url(http://zhsh520.com/hero-bg.jpg);
background-size: 100% 100%;
position: relative;
}
article{
width: 1200px;
margin: 0 auto;
}
article{
width: 400px;
margin: 100px auto 0px auto;
}
article h1{width: 400px;color: #fff;text-align: center;margin-bottom: 15px;font-weight: normal;}
article h1 em{display: inline-block;color:#5593ce;font-size: 25px;}
.main{
padding: 40px 0px;
width: 100%;
background-color: rgba(0, 0, 0, 0.6);
}
form{
width: 297px;
margin: 0 auto;
}
.main form input{
margin: 10px 0;
width: 280px;
height: 35px;
border-radius: 3px;
display: inline-block;
border: 1px solid rgb(165, 161, 161);
padding-left: 10px;
}
.main form input[name="captcha"]{
width: 200px;
}
form button{width: 290px;height: 35px;background-color: red;color: #fff;border:none;margin-top: 15px;letter-spacing: 10px;font-size: 16px;text-align: center;}
footer{
width: 100%;
position: absolute;
left: 0;
bottom: 50px;
font-size: 14px;
color: #5593ce;
}
footer ul{width: 570px;height: 35px;}
footer p{width: 100%;text-align: center;}
footer ul li{display: inline-block;width: 90px;height: 13px;line-height: 13px;border-right: 1px solid #5593ce;text-align: center; }
footer ul li a{font-size: 14px;color:#5593ce; }
footer ul,footer p{margin: 0 auto;}
// 提交信息验证 reg.js
document.querySelector('button').addEventListener("click",function(e){
const formdata = new FormData(document.querySelector('form'));
const xhr = new XMLHttpRequest();
xhr.open("post", "regist_check.php");
xhr.onload = () => {
let json = JSON.parse(xhr.response);
if(json.status==0){
document.querySelector("#captchainfo").textContent = json.msg;
document.querySelector("#captchainfo").style.color = "red";
}else{
document.querySelector("#captchainfo").textContent = json.msg;
document.querySelector("#captchainfo").style.color = "green";
setTimeout(()=>{
window.location.href = "http://baidu.com";
},2000)
}
};
xhr.send(formdata);
});
document.querySelector('#captcha').addEventListener('blur',function(e){
// console.log(e.target.value);
const xhr = new XMLHttpRequest();
xhr.open("post", "captcha_check.php");
xhr.onload = () => {
let json = JSON.parse(xhr.response);
if(json.status==0){
document.querySelector("#captchainfo").textContent = json.msg;
document.querySelector("#captchainfo").style.color = "red";
e.target.focus();
}else{
document.querySelector("#captchainfo").textContent = json.msg;
document.querySelector("#captchainfo").style.color = "green"
}
};
xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
xhr.send("captcha="+e.target.value);
})
// 用户信息验证 regist_check.php
<?php
session_start();
$user = $_POST;
if(strlen($user['userName'])<4 || !preg_match("/^[A-Za-z]/i",$user['userName']) ){
echo json_encode(['status'=>0,'msg'=>'用户名长度需不小于四位且以字母开头']);
}else if(strcmp($user['pwd'],$user['cpwd'])!== 0){
echo json_encode(['status'=>0,'msg'=>'两次密码输入不一致']);
}else if(strcasecmp($_SESSION["captcha"],$user["captcha"])!== 0){
echo json_encode(['status'=>0,'msg'=>'验证码不正确']);
}else{
echo json_encode(['status'=>1,'msg'=>'注册成功,请稍后……']);
}
?>
// 验证码的验证 captcha_check.php
<?php
/**
* 接受用户登陆时提交的验证码
*/
session_start();
//1. 获取到用户提交的验证码
$captcha = $_POST["captcha"];
//2. 将session中的验证码和用户提交的验证码进行核对,当成功时提示验证码正确,并销毁之前的session值,不成功则重新提交
if(!empty($captcha) && strtolower($_SESSION["captcha"]) === strtolower($captcha)){
echo json_encode(['status'=>1,'msg'=>'验证码正确']);
}else{
echo json_encode(['status'=>0,'msg'=>'验证码不正确']);
}
// 验证码生成 gd_captcha.php
<?php
session_start();
$image = imagecreatetruecolor(100, 30);
$bgcolor = imagecolorallocate($image, 255, 255, 255);
imagefill($image, 0, 0, $bgcolor);
$content = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789";
$captcha = "";
for ($i = 0; $i < 4; $i++) {
// 字体大小
$fontsize = 10;
// 字体颜色
$fontcolor = imagecolorallocate($image, mt_rand(0, 120), mt_rand(0, 120), mt_rand(0, 120));
// 设置字体内容
$fontcontent = substr($content, mt_rand(0, strlen($content)), 1);
$captcha .= $fontcontent;
// 显示的坐标
$x = ($i * 100 / 4) + mt_rand(5, 10);
$y = mt_rand(5, 10);
// 填充内容到画布中
imagestring($image, $fontsize, $x, $y, $fontcontent, $fontcolor);
}
$_SESSION["captcha"] = $captcha;
//4.3 设置背景干扰元素
for ($$i = 0; $i < 200; $i++) {
$pointcolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200));
imagesetpixel($image, mt_rand(1, 99), mt_rand(1, 29), $pointcolor);
}
//4.4 设置干扰线
for ($i = 0; $i < 3; $i++) {
$linecolor = imagecolorallocate($image, mt_rand(50, 200), mt_rand(50, 200), mt_rand(50, 200));
imageline($image, mt_rand(1, 99), mt_rand(1, 29), mt_rand(1, 99), mt_rand(1, 29), $linecolor);
}
//5.向浏览器输出图片头信息
header('content-type:image/png');
//6.输出图片到浏览器
imagepng($image);
浏览地址:http://easys.ltd/regist/regist.html
显示效果: