Rumah > Artikel > pembangunan bahagian belakang > PHP常见的一些问题总结(收藏)
本篇文章给大家带来的内容是关于PHP常见的一些问题总结(收藏),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
单引号加载速度比双引号加载速度快
(1)echo 是语法,Output one or more strings,没有返回值;
(2)print 是函数,不能输出数组和对象,Outputastring,print
有返回值;
(3)print_r 是函数,可以输出数组。print_r 是个比较有意思 的函数,可以输出 stirng、int、float、array、object 等,输 出 array 时会用结构表示,print_r 输出成功时返回 true;而 且 print_r 可以通过 print_r($str,true)来,使 print_r 不输出而 返回 print_r 处理后的值。此外,对于 echo 和 print,基本以 使用 echo 居多,因为其效率比 print 要高。
A. 字符串输出函数
(1)echo $a,$b,$c......; 是一个语言结构,而不是一个真正的
函数。
(2)print($a) 本函数输出字符串。若成功则返回 1,失败 返回 0
(3)print_r($a)
(4)var_dump($a); 能输出类型、长度、值
B. 去除字符串首尾空格的函数: trim ltrim rtrim(别名: chop) 使用第二个参数,还可以去除指定的字符。
C. 转义字符串函数:addslashes()
D. 获取字符串长度的函数:strlen()
E. 截取字符串长度的的函数:substr()
F. 检索字符串函数: strstr() , strpos()
G. 替换字符串函数:str_replace()
1).$arr = array('james', 'tom', 'symfony');请将$arr 数组的值 用 ’,’ 分 割 并 合 并 成 字 符 串 输 出 ?
echo implode(‘,’,$arr);
2).$str = ‘jack,james,tom,symfony’; 请将$str 用’,’分 割 , 并 把 分 割 后 的 值 放 到 $arr 数 组 中 ?
$arr = explode(‘,’,$str);
3).$arr=array(3,7,2,1,’d’,’abc’);请将$arr按照从大到小的顺序排序,并保持其键值不变?
arsort($arr); print_r($arr);
4).$mail = “gaofei@163.com”;请将此邮箱的域(163.com)取出来并打印,看最多能写出几种方法?
echostrstr($mail,'163'); echosubstr($mail,7); $arr=explode("@",$mail);echo$arr[1];
1.首先考虑当前文件是不是设置了字符集。查看是不是 meta 标签中写了 charset,如果是 php 页面还可以看看是不是
在 header()函数中指定了 charset;
例如:
<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> header(“content-type:text/html;charset=utf-8”);
2.如果设置了字符集(也就是 charset),那么判断当前文件
保存的编码格式是否跟页面设置的字符集保持一致,
两者必须保持统一;
3.如果涉及到从数据库提取数据,那么判断数据库查询时的
字符集是否跟当前页面设置的字符集一致,两者必须统一,
例如:
mysql_query(“set names utf8”)。
正则表达式是用于描述字符排列模式的一种语法规则。正则表达式也叫做模式表达式。网站开发中正则表达式最常用于表单提交信息前的客户端验证。
比如验证用户名是否输入正确,密码输入是否符合要求, email、手机号码等信息的输入是否合法
在 php 中正则表达式主要用于字符串的分割、匹配、查找和
替换操作。
preg 系列函数可以处理。具体有以下几个:
stringpreg_quote(stringstr[,stringdelimiter])
转义正则表达式字符 正则表达式的特殊字符包括:.\\+*? [^]$(){}=!a8093152e673feb7aba1828c43532094|:。
preg_replace-- 执行正则表达式的搜索和替换
mixed preg_replace ( mixed pattern, mixed replacement, mixed subject[,intlimit]
preg_replace_callback -- 用回调函数执行正则表达式的搜索
和替换
mixed preg_replace_callback ( mixed pattern, callback callback, mixedsubject[,intlimit])
preg_split-- 用正则表达式分割字符串
array preg_split ( string pattern, string subject [, int limit [, int flags]])
常用的正则表达式写法:
中文:/^[\u4E00-\u9FA5]+$/
手机号码:/^(86)?0?1\d{10}$/
EMAIL:
/^[\w-]+[\w-.]?@[\w-]+\.{1}[A-Za-z]{2,5}$/
密码(安全级别中) :
/^(\d+[A-Za-z]\w*|[A-Za-z]+\d\w*)$/
密码(安全级别高) :
/^(\d+[a-zA-Z~!@#$%^&(){}][\w~!@#$%^&(){}]*|[a-zA-Z~! @#$%^&(){}]+\d[\w~!@#$%^&(){}]*)$/
preg_replace — 执行正则表达式的搜索和替换
str_ireplace — str_replace() 的 忽 略 大 小 写 版 本 str_replace — 子字符串替换
preg_split — 用正则表达式分割字符串
split — 用正则表达式将字符串分割到数组中
echodate("Y-m-dH:i:s",strtotime(‘-1,days’)); date('Y-m-dH:i:s',time()); $unix_time = strtotime("2009-9-2 10:30:25");//变成 unix 时间戳 echodate("Y-m-dH:i:s",$unix_time);//格式化为正常时间格式
用户在网站表单提交数据的时候,为了防止脚本攻击(比如 用户输入3f1c4e4b6b16bbbd69b2ee476dc4f83aalert(111);2cacc6d41bbb37262a98f745aa00fbf0),php 端接收数据的
时候,应该如何处理?
使用 urlencode()对中文进行编码,使用 urldecode()来解码。
使用 htmlspecialchars($_POST[‘title’])来过滤表单传参就可以避免脚本攻击。
第一个是返回结果集中的一行作为索引数组,第二个是返回
关联数组,而第三个既可以返回索引数组也可以返回关联数 组,取决于它的第二个参数 MYSQL_BOTH MYSQL_NUM MYSQL_ASSOC 默认为 MYSQL_BOTH
$sql=”select*fromtable1”; $result=mysql_query($sql); mysql_fetch_array($result,MYSQL_NUM);
答:fopen(打开文件)
imagecreatefromjpeg(png gif) — 从 JPEG
文件新建一图像
imagecreatetruecolor — 新建一个真彩色
图像
imagecopymerge — 拷贝并合并图像的一
部分
imagecopyresized — 拷贝部分图像并调
整大小
mysql_connect — 打开一个到 MySQL MySQL MySQL MySQL
服务器的连接
mysql_query();只有这执行 select 的时候成功,才返回资源, 失败返回 FALSE
1.首现要在 php.ini 中开启文件上传;
2.在 php.ini 中有一个允许上传的最大值,默认是2MB。必要
的时候可以更改;
3. 上 传 表 单 一 定 要 记 住 在 form 标 签 中 写 上 enctype="multipart/form-data";
4. 提交方式 method 必须是 post;
5. 设定 type="file" 的表单控件;
6.要注意上传文件的大小 MAX_FILE_SIZE、文件类型是否符合要求,上传后存放的路径是否存在。可以通过上传的文件名获取到文件后缀,然后使用时间戳+文件后缀的方式为文件重新命名,这样就避免了重名。可以自己设置上传文件的保存目录,与文件名拼凑形成一个文件 路径,使用 move_uploaded_file(),就可以完成将文件保存到指定目录。
二维数组。第一维是上传控件的 name,二维下标分别为 name/type/tmp_name/size/error.
答:
header()发送 http 头信息 -header("content-type:text/html; charset=utf-8");-------------------//当前页面输出内容是 html,编 码为 utf-8格式 -<meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> -header("content-type:image/png gif jpeg");----------------------------------//当前页面输出内容的格式是图片 -header("refresh:5;url=http://www.1004javag.com/five/string.ph p");--//页面5秒后要跳转到新网址 -header("location:http://1004javag.com/five/string.php");----------//页面重定向
答 : header("content-type: application/octet-stream;charset=UTF-8"); //在这里加 utf-8和
在上面定义有什么区别?、??
header("accept-ranges:bytes"); header("accept-length: ".filesize($filedir.$filename)); header("content-disposition: attachment; filename=".$filedir.$filename);
ajax 是 asynchronous JavaScript JavaScript JavaScript JavaScript and xml 的 缩 写 , 是 javascript、xml、css、DOM 等多个技术的组合。'$'是 jQuer jQuer jQuer jQuery y y y 的别名.
页面中用户的请求通过 ajax 引擎异步地与服务器进行通 信,服务器将请求的结果返回给这个 ajax 引擎,
最后由这个ajax引擎来决定将返回的数据显示到页面中的 指定位置。Ajax 最终实现了在一个页面的指定位置可以加载 , 另一个页面所有的输出内容。
这样就实现了一个静态页面也能获取到数据库中的返回数 据信息了。所以 ajax 技术实现了一个静态网页在不刷新整个
页面的情况下与服务器通信,
减少了用户等待时间,同时也从而降低了网络流量,增强了
客户体验的友好程度。
Ajax 的优点是:
1. 减轻了服务器端负担,将一部分以前由服务器负担的工
作转移到客户端执行,利用客户端闲置的资源进行处理;
2. 在只局部刷新的情况下更新页面,增加了页面反应速度,
使用户体验更友好。
Ajax 的缺点是不利于 seo 推广优化,因为搜索引擎无法直接 访问到 ajax 请求的内容。
ajax 的核心技术是 XMLHttpRequest,它是 javascript 中的
一个对象。
jQuery 是 Javascript 的一种框架。
$.get(),$.post(),$.ajax()。$是 jQuery 对象的别名。
代码如下:
$.post(异 步 访 问 的 url 地 址 , {' 参 数 名' : 参 数 值} , function(msg){ $("#result").html(msg); }); $.get( 异 步 访 问 的 url 地 址 , {' 参 数 名 ' : 参 数 值 } , function(msg){ $("#result").html(msg); }); $.ajax({ type:"post", url:loadUrl, cache:false, data:"参数名=" + 参数值, success:function(msg){ $("#result").html(msg); } });
简单地说会话控制就是跟踪和识别用户信息的机制。会话控制的思想就是能够在网站中跟踪一个变量,通过这个变量,系统能识别出相应的用户信息,根据这个用户信息可以得知用户权限,从而展示给用户适合于其相应权限的页面内容。 目前最主要的会话跟踪方式有 cookie,session。
1).访问与当前请求相关的会话对象
2).查找与会话相关的信息
3).存储会话信息
4).废弃会话数据
1) setcookie()之前不可以有任何页面输出,就是空格,空白行也不可以;
2) setcookie()后,在当前页面调用$_COOKIE['cookiename'] 不会有输出,必须刷新或到下一个页面才可以看到 cookie值;
3)不同的浏览器对 cookie 处理不同,客户端可以禁用 cookie,浏览器也可以闲置 cookie 的数量,一个浏览器能创 建的 cookie 数量最多300个,并且每个不可以超过4kb,每个 web 站点能设置的 cookie 总数不能超过20个。
4) cookie 是保存在客户端的,用户禁用了 cookie,那么 setcookie 就不会起作用了。所以不可以过度依赖 cookie。
sessionid , 通 过 session_id() 函 数 可 以 取 得 当 前 的 session_id。
1. cookie 是保存在客户端机器的,对于未设置过期时间的 cookie,cookie 值会保存在机器的内存中,只要关闭浏览器 则 cookie 自动消失。如果设置了 cookie 的过期时间,那么 浏览器会把 cookie 以文本文件的形式保存到硬盘中,当再次 打开浏览器时 cookie 值依然有效。
2. session 是把用户需要存储的信息保存在服务器端。每个用户 的 session 信息就像是键值对一样存储在服务器端,其中的 键就是 sessionid,而值就是用户需要存储信息。服务器就是通过 sessionid 来区分存储的 session 信息是哪个用户的。
两者最大的区别就是 session 存储在服务器端,而 cookie 是 在客户端。session 安全性更高,而 cookie 安全性弱。
3. session 在 web 开发中具有非常重要的份量。它可以将用户正确登录后的信息记录到服务器的内存中,当用户以此身份访问网站的管理后台时,无需再次登录即可得到身份确认。而没有正确登录的用户则不分配session 空间,即便输入了 管理后台的访问地址也不能看到页面内容。通过session 确定了用户对页面的操作权限。
使用 session 的步骤:
1. 启动 session:使用 session_start()函数来启动。
2. 注册会话:直接给$_SESSION 数组添加元素即可。
3. 使用会话:判断 session 是否为空或者是否已经注册,如果已经存在则像普通数组使用即可。
4. 删除会话:
1.可以使用 unset 删除单个 session;
2.使用$_SESSION=array()的方式,一次注销所有的会话变量;
3.使用 session_destroy()函数来彻底销毁 session。
cookie 怎么使用?
1. 记录用户访问的部分信息
2. 在页面间传递变量
3. 将所查看的 internet 页存储在 cookies 临时文件夹中,可以提高以后的浏览速度。
创建 cookie:setcookie(stringcookiename,stringvalue,int expire);
读取 cookie:通过超级全局数组$_COOKIE 来读取浏览器端 的 cookie 的值。
删除 cookie:有两种方法
1.手工删除方法:
右击浏览器属性,可以看到删除 cookies,执行操作即可将所 有 cookie 文件删除。
2.setcookie()方法:
跟设置 cookie 的方法一样,不过此时将 cookie 的值设置为 空,有效时间为0或小于当前时间戳。
可以直接在php.ini中开启session.auto_start=1或者在页面 头部session_start();
开启 session,session_start()前面不能有任何输出,包括空行。
session 用来存储用户登录信息和用在跨页面传值。
1)常用在用户登录成功后,将用户登录信息赋值给 session;
2)用在验证码图片生成,当随机码生成后赋值给 session。
unset() $_SESSION=array(); session_destroy();
相关推荐:
php服务nginx不能使用file_get_contents的解决方法
Atas ialah kandungan terperinci PHP常见的一些问题总结(收藏). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!