不会影响代码的执行。碰到一次,执行一次
只要是因为提交到了本地仓库,只要不提交就可以忽略这些文件
function 函数Name(){
}
FUNCTION 输出函数名
会自动把全局变量放进这个超全局变量的数组里
$GLOBALS[‘全局变量名’] 来访问全局变量
$a="555555";
function test(){
global $a;
echo $a;
}
test();
$a="5555551";
function test(){
echo $GLOBALS['a'];
}
test();
function test()
{
echo "hellow";
}
$a = 'test';
$a();
$a=function(){
echo "hellow111";
};
$a();
(function(){
echo "hellow2222";
})();
use 就是讲外部的局部变量保存在函数内部使用
function func1(){
$num=20001;
$func2=function () use ($num){
echo $num;
};
$func2();
}
func1();
系统函数 | 作用 |
---|---|
print(); | 返回值是1 |
date(): | print_r(date(“Y-m-d,H:i:s”)); |
mt_rand(); | 随机数 |
cell(); | 向上取整 |
floor(); | 向下取整 |
function_exists() | 判断函数名是否在内存中存在 |
header('Content-type:text/html;charset=utf-8');
ini_set('display_errors', '1');//让浏览器显示错误信息
ini_set('error_reporting', E_ALL);
trigger_error(“errormsg”);
E_USER_NOTICE
E_USER_WARNING
E_USER_ERROR
E_USER_DEPRECATED
/**
* @param $errNum
* @param $errMsg
* @param $errFile
* @param $errLine
* @param $errContext
*/
function error_msg($errNum, $errMsg, $errFile, $errLine, $errContext)
{
//查看当前系统可以看到的错误
if (!(error_reporting() & $errNum)) {
return false;
}
switch ($errNum) {
case E_ERROR:
case E_USER_ERROR:
echo "在" . $errFile . "文件里的第" . $errLine . "行发生fatal Error,错误信息为:" . $errMsg;
break;
case E_WARNING:
case E_USER_WARNING:
echo "在" . $errFile . "文件里的第" . $errLine . "行发生Warning,错误信息为:" . $errMsg;
break;
case E_NOTICE:
case E_USER_NOTICE:
echo "在" . $errFile . "文件里的第" . $errLine . "行发生E_NOTICE,错误信息为:" . $errMsg;
break;
}
return true;
}
set_error_handler("error_msg");
$a=10;
echo $a/0;
‘’
“” 变量识别的规则
nowdoc
heredoc
方法名 | 作用 |
---|---|
strlen($a); | 拉丁文字符串长度,一个中文三个字节 |
mb_strlen($str); | 获取宽字符的长度,能准确获取中文+英文的真实长度 |
mb_strlen($a); | 字符创长度,指定字符集的时候一个中文一个字节 |
$list = [1, 2, 3,"hcy"];
echo implode($list);
echo implode('^',$list);//以什么连接
var_dump(str_split($str,1));//指定长度拆分字符串得到数组
trim($str);//去除两边的空格
echo substr($str,0,3);//指定截取开始位置和截取字符的个数
$str="6766555";
echo strstr($str,'7');//找到一个字符'7'并往后截取
$str="hcy2019";
echo strpos($str,'y');//查找字符串首次出现的位置
echo strrpos($str,'y');//查找目标字符在字符串中最后一次出现的位置
$str="hcyy2019";
echo str_replace("hcyy","cmj",$str);//将字符串的某个部分替换成另一个部分组成新的字符串
$arr=array('name'=>'hcy2019','age'=>123,'sex'=>'男');
include_once '../utils/LogUtils.php';
header('Content-Type:application/json');
$arr = array(array('src' => 'http://b167.photo.store.qq.com/psb?/V11vyccr1gMNFR/F*kE5fj7eH9HHF0OXtwJFw9zYygo0crvP1pTIvAL3H4!/b/dJpcjWPOHQAA&bo=nwEnAgAAAAABB5s!&rf=viewer_4',
'name' => '徐庶'),
array('src'=>'http://b168.photo.store.qq.com/psb?/V11vyccr1gMNFR/dCfQVrEZY2o7i.EhP.ro3MUyssdXx5H*rQwhJhN5lHs!/b/dACGKmSWHwAA&bo=owElAgAAAAABF7U!&rf=viewer_4','name'=>'孙策'),
array('src'=>'http://b169.photo.store.qq.com/psb?/V11vyccr1gMNFR/fElpooMWvcO8RFaHo2p*L9P.YwS*DG24khee42RlzFg!/b/dBcpxmSXBgAA&bo=nAEpAgAAAAABF4Y!&rf=viewer_4','name'=>'曹植'),
array('src'=>'http://b168.photo.store.qq.com/psb?/V11vyccr1gMNFR/xQIYvagK3b4ywurc48rSp0b404pUEHSJ300jYbW*IXI!/b/dLlZJGQeHAAA&bo=ngEjAgAAAAABF44!&rf=viewer_4','name'=>'蔡文姬'));
$json_str=json_encode($arr);
echo $json_str;
$arr=array('hcy','love','cmj','2019');
var_dump($arr);
var_dump(array_keys($arr)); 所有的key array
var_dump(array_values($arr)); 所有的value array
var_dump(array_key_exists("name",$arr));
isset($arr['name'])
empty($arr['name'])
//foreach ($arr as $key => $value) {
// echo $key, " ", $value, "
";
//}
//foreach ($arr as $value) {
//
// foreach ($value as $k=>$v){
// echo $k, " ", $v, "
";
// }
//}
for ($i=0;$i<count($arr);$i++){
var_dump($arr[$i]);
echo "
";
}
$arr = array(1, 4, 2, 9, 7, 5, 8,7,1);
function bubble_sort()
{
global $arr;
//确定轮数
//每轮最右边都会确定一位数字
for ($i = 0; $length = count($arr), $i < $length; $i++) {
for ($j=0;$j<$length-1-$i;$j++){
if ($arr[$j]>$arr[$j+1]){
$temp=$arr[$j+1];
$arr[$j+1]=$arr[$j];
$arr[$j]=$temp;
}
}
}
print_r($arr);
}
bubble_sort();
function select_sort()
{
//从小往大排序
global $arr;
for ($i = 0; $len = count($arr), $i < $len; $i++) {
$min_pos = $i;//假设最小元素的位置
for ($j = $min_pos; $j < $len; $j++) {
if ($arr[$j] < $arr[$min_pos]) {
$min_pos = $j;
}
}
//找到最小的那个数的位置了,与假设的位置坐交换
$temp=$arr[$min_pos];
$arr[$min_pos]=$arr[$i];
$arr[$i]=$temp;
}
print_r($arr) ;
}
select_sort();
readfile()
file_exists($filepath)
$handle = fopen($filename, "a+");
$str = fwrite($handle, $userinfo);
fclose($handle);
file_put_contents($filename, $userinfo, FILE_APPEND);
sudo chmod -R 777 目标文件夹/文件
/private/etc/apache2/extra/httpd-vhosts.conf
#加一个虚拟主机
#把任意IP的80端口绑定上
#一台虚拟主机的根目录
DocumentRoot “/Users/hcy/PhpstormProjects/MyPHP”
#开启目录结构浏览(Indexes)和软链接目录访问(FollowSymLinks)
Options Indexes FollowSymLinks
#不允许目录内.htaccess 文件覆盖此处配置
AllowOverride None
#允许所有人访问该目录
Require all granted
#虚拟主机的域名
ServerName hcy2019.io
ServerAlias www.hcy2019.io
#错误日志目录
ErrorLog “/Users/hcy/PhpstormProjects/MyPHP/errorlog/hcy2019.io-error_log”
#自定义日志 common是错误级别
CustomLog “/Users/hcy/PhpstormProjects/MyPHP/errorlog/hcy2019.io-access_log” common
重启apache
sudo apachectl restart
mac host路径
/private/etc/hosts
php.ini打开扩展
phpinfo 查看扩展
查看httpd_config php.ini的配置路径
控制台 php -a
方法 | 作用 |
---|---|
time(); | 获取秒 |
echo date(“Y-m-d,H:i:s”); | 获取年月日,时分秒 |
date_default_timezone_set(“PRC”); | 设置时区 |
//先转为时间戳,对时间格式化
$time='2019-05-30,15:25';
$timestmp=strtotime($time);
echo date("Y?m?d===H:i:s",$timestmp);
定义后不能被修改,也是临时存放的容器
一般程序的配置信息需要用到常量
define("PI",3.14);
常量不需要$
可以提交的input type=‘submit/image’
提交2 也可以提交 默认type=‘submit’
持久化
响应
get 的url长度是有限的2000个字符
对标签的解释说明
<form action="'PHP_SELF'] ?>" method="post" enctype="multipart/form-data">form>
body>
$files = $_FILES['avatar'];
if ($files['error']==0){
echo '上传成功';
}
UPLOAD_ERR_OK=0 常量 代表上传成功
error :1 文件上传大小的限制
参数一:临时目录 参数二:网站目录下
move_uploaded_file($files['tmp_name'], '../file/' . $files['name']);
此方法有返回值,判断是否返回成功
php.ini
upload_max_filesize = 2M