1.$array['anykey']和$array[anykey]的区别?
答:单引号和没有单引号区别,就是字符串和常量。而单引号和双引号的区别,就是字符串和变量吧。
不加单引号的话,php会首先认为他是常量,然后去搜寻是否存在这个常量,若不存在,则理解为字符串,所以在效率上就慢了。
2.echo 输出语句时候的连接符号: "." 和 ","。点号和逗号的区别?
答:echo用点号时先把语句连接再输出,而用逗号就等于给它传多个参数,不需要进行字符串拼接这一步,效率高! // 本文来自技术世界www.js4j.com 技术教程//
3.echo,print,print_r的区别?
答:echo,直接输出单个或者多个字符串,是PHP语句!
print,打印输出简单类型,是PHP函数!有整型返回值。我试验了下,都返回1。
print_r,格式化打印输出,常用于比较复杂的类型,如数组,对象之类的,可以输出完整结构,是PHP函数,返回值类型为布尔型!
4.获取前天的日期,格式如:2009-01-12 17:15:20
答:echo date('Y-m-d h:i:s',time()-2*24*60*60);
echo date('Y-m-d h:i:s',strtotime('2 days ago')); 未来几天的话把 ago 去掉就行了 // 来自www.js4j.com 技术BBS论坛//
5.如何将字符串翻转过来?
答:$str = '7654321';
echo strrev($str); //1234567
另一种方法:
$strlen = strlen($str);
for ($i = 1; $i <= $strlen; $i++) {
echo substr($str,-$i,1);
} // 内容来自js4j.com//
6.优化MySQL数据库的方法?
答:①选取最适用的字段属性。
②是用连接(JOIN)来代替子查询(Sub-Queries)。
③是用联合(UNION)来代替手动创建的临时表。
④事务
⑤锁定表
⑥使用外键
⑦使用索引
⑧优化的查询语句
上面8条优化的详细说明请点击该链接查看完全优化MySQL数据库性能的八大巧方法
7.PHP的意思?(送一分)
答:Hypertext preprocessor 超文本预处理语言。(汗!我google了才知道滴。。送一分都得不到啊,撞墙!!)
8.MYSQL取得当前时间的函数是?格式化日期的函数是?
答:当前日期函数为 NOW();
格式化日期函数是:
SELECT DATE_FORMAT('2009-01-11 17:25:36',"%H:%i:%s %m/%d/%Y");
->17:25:36 01/11/2009
其它时间函数:详细请查看该页面 MySql 格式化时间函数
SELECT DAYOFWEEK('1998-02-03');
->3
SELECT WEEKDAY('1997-10-04 22:23:00');
->5
SELECT WEEKDAY('1997-11-05');
->2
SELECT DAYOFMONTH('1998-02-03');
->3
SELECT DAYOFYEAR('1998-02-03');
->34
SELECT MONTH('1998-02-03');
->2
SELECT DAYNAME('1998-02-05');
->'February'
SELECT QUARTER('1998-04-01');
->2
SELECT WEEK('1998-02-20');
->7
SELECT WEEK('1998-02-20',0);
->7
SELECT WEEK('1998-02-20',1);
->8
SELECT YEAR('98-02-03');
->1998
SELECT HOUR('10:05:03');
->10
SELECT MINUTE('98-02-03 10:05:03');
->5
SELECT SECOND('10:05:03');
->3
SELECT PERIOD_ADD(9801,2);
->199803
SELECT PERIOD_DIFF(9802,199703);
->11
SELECT TO_DAYS('1997-10-07');
->729669
SELECT TO_DAYS(950501);
->728779
SELECT FROM_DAYS(729669);
->'1997-10-07'
SELECT UNIX_TIMESTAMP('1997-10-04 22:23:00');
->875996580
SELECT FROM_UNIXTIME(875996580);
->'1997-10-04 22:23:00'
SELECT SEC_TO_TIME(2378);
->00:39:38
SELECT TIME_TO_SEC('00:39:38');
->2378 // 本文来自技术世界www.js4j.com 技术教程//
9.怎样截取中文且不出现乱码?
答:如果安装了mb扩展可使用mb_substr();
可以使用以下函数:
function cutstr($sourcestr, $startlength, $cutlength)
{
$returnstr='';
$i=0;
$n=0;
$str_length=strlen($sourcestr); //字符串的字节数
while (($n<$cutlength) and ($i<=$str_length))
{
$temp_str=substr($sourcestr,$i,1); // 内容来自js4j.com//
$ascnum=Ord($temp_str); //得到字符串中第$i位字符的ascii码
if ($ascnum>=224) { //如果ASCII位高与224,
$returnstr=$returnstr.substr($sourcestr,$i,3); //根据UTF-8编码规范,将3个连续的字符计为单个字符
$i=$i+3; //实际Byte计为3
$n++; //字串长度计1
} elseif ($ascnum>=192){ //如果ASCII位高与192,
$returnstr=$returnstr.substr($sourcestr,$i,2); //根据UTF-8编码规范,将2个连续的字符计为单个字符
$i=$i+2; //实际Byte计为2
$n++; //字串长度计1 // 来自www.js4j.com 技术BBS论坛//
} elseif ($ascnum>=65 && $ascnum<=90){ //如果是大写字母,
$returnstr=$returnstr.substr($sourcestr,$i,1);
$i=$i+1; //实际的Byte数仍计1个
$n++; //但考虑整体美观,大写字母计成一个高位字符
} else { //其他情况下,包括小写字母和半角标点符号, // 内容来自技术世界www.js4j.com 技术爱好者//
$returnstr=$returnstr.substr($sourcestr,$i,1);
$i=$i+1; //实际的Byte数计1个
$n=$n+0.5; //小写字母和半角标点等与半个高位字符宽...
}
if ($n <= $startlength){
$returnstr = '';
continue;
}
}
if ($str_length>$cutlength){
$returnstr = $returnstr . "..."; //超过长度时在尾处加上省略号
}
return $returnstr;
}
10.对于大流量的网站,您采用什么样的方法来解决访问量问题?
答:①最根本的是服务器硬件条件。服务器硬件设备如果太差,那不管怎么优化都是徒劳!
②对数据库进行优化。主要是减少对数据库的访问量。访问过多会造成服务器CPU过度消耗,导致服务器受访能力严重下降,解决方法是是前台使用静态或者动态缓存!
③防盗链。对于Apache服务器,主要是是用model_rewrite 模块通过对URL的正则,进行限制和重定向!
④控制大文件下载。不提供超过2MB的文件下载,或使用专门的下载服务器,或者上传到web2.0共享网站上。
⑤多主机分流。将不同文件放置在不同的主机,提供镜像之类的文件下载方式。
⑥是用专业的流量分析软件。如google流量分析。对网站进行精细的流量控制!
11.用PHP写出显示客户端IP与服务器IP的代码? // 本文来自技术世界www.js4j.com 专业技术门户网站//
答:客户端IP获取 $_SERVER['REMOTE_ADDR'];
服务端IP获取 $_SERVER['SERVER_NAME'];
12.如何修改SESSION的生存时间?
答:$lifeTime = 24*3600;
session_set_cookie_params($lifeTime);
session_start();
详细的设置请查看这篇文章:PHP对session生存时间的设置详细介绍。
13.有一个网页地址, 比如PHP研究室主页: http://www.163fly.com/index.php如何得到它的内容?
答:$src = 'http://www.163fly.com/index.php';
$file = 'D:\index.html';
①$content = file_get_contents($src);
$hfile = fopen($file,w);
$result = fwrite($hfile,$content);
②$opsrc = fopen($src,r);
$wfile = fopen($file,w);
$result = stream_copy_to_stream($opsrc,$wfile);
14.在HTTP 1.0中,状态码401的含义是?;如果返回“找不到文件”的提示,则可用 header 函数,其语句为?
答:①HTTP/1.0 401 代表:未授权。 ②可用 header("HTTP/1.0 404 Not Found");
15.在PHP中,heredoc是一种特殊的字符串,它的结束标志必须?
答:<<<标识符
......
标识符;
结束标识符前不能有任何其它字符!