PHP新手面试题总100分

字体大小: 中小 标准 ->行高大小: 标准
简述题(50分)
1、用PHP打印出前一天的时间格式是2006-5-10 22:21:21(2分)
echo date('Y-m-d H:i:s', strtotime('-1 day'));echo date('Y-n-j H:i:s', time()-60*60*24);
2、echo(),print(),print_r()的区别(3分) 
echo, print 是语言结构,print_r是函数
echo 不返回值,其他返回值
等。
echo是PHP语句, print和print_r是函数,语句没有返回值,函数可以有返回值
print可以用于复杂的表达式echo不行(如:$b ? print "true" : print "false";)
print只能打印出简单类型变量的值(如int,string)
print_r可以打印出复杂类型变量的值(如数组,对象)

3、能够使HTML和PHP分离开使用的模板(1分)

现在当然是smarty
5、使用哪些工具进行版本控制?(1分)

SVN,CVS等
6、如何实现字符串翻转?(3分)string strrev ( string string)(

<?php
$str = 'test';
for($i = 1; $i <= strlen($str); $i++)
{
echo substr($str, -$i, 1);
}
?>

---------------------------------------------------------------
7、优化MYSQL数据库的方法。(4分,多写多得)

(1).建立适当的索引。
(2).使用连接(JOIN)来代替子查询(Sub-Queries)
(3).使用联合(UNION)来代替手动创建的临时表
8、PHP的意思(送1分)

PHP:Hypertext Preporcessor (是Preprocessor?)超文本预处理器
9、MYSQL取得当前时间的函数是?,格式化日期的函数是(2分)
NOW() FOMART_DATE()

now(), DATE_FORMAT(date,format)
10、实现中文字串截取无乱码的方法。(3分)

mb_substr()

mb_substr('中文乱码问题的解决方法', 0, 7, 'utf-8');//按字来切分字符 输出:中文乱码问题的
echo mb_strcut('中文乱码问题的解决方法', 0, 7, 'utf-8');//按字节来切分字符 输出:中文乱

做个循环便利每个字节,ord判断是否为中文,中文的话看情况截取2个或3个字符,英文直接继续。
---------------------------------------------------------------
11、您是否用过版本控制软件? 如果有您用的版本控制软件的名字是?(1分)
12、您是否用过模板引擎? 如果有您用的模板引擎的名字是?(1分)
13、请简单阐述您最得意的开发之作(4分)
14、对于大流量的网站,您采用什么样的方法来解决访问量问题?(4分)

缓存,静态化。

a。服务器硬件b.服务器软件配置(如防盗链 缓存设置等)c.php程序优化,页面最好生成静态
-----------------------------------------------------------------
15、用PHP写出显示客户端IP与服务器IP的代码1分)

服务器:$serverip = gethostbyname(SERVER['SERVER_NAME']);
客户端:
function real_ip()
{
if (isset(SERVER))
{
if (isset(SERVER["HTTP_X_FORWARDED_FOR"]))
{
$arr = explode(',',SERVER["HTTP_X_FORWARDED_FOR"]);
/* 取X-Forwarded-For中第一个非unknown的有效IP字符串 */
foreach ($arr AS $ip)
{
$ip = trim($ip);
if ($ip != 'unknown')
{
$realip = $ip;
break;
}
}
}
elseif (isset(SERVER["HTTP_CLIENT_IP"]))
{
$realip =SERVER["HTTP_CLIENT_IP"];
}
else
{
$realip =SERVER["REMOTE_ADDR"];
}
}
else
{
if (getenv('HTTP_X_FORWARDED_FOR'))
{
$realip = getenv('HTTP_X_FORWARDED_FOR');
}
elseif (getenv('HTTP_CLIENT_IP'))
{
$realip = getenv('HTTP_CLIENT_IP');
}
else
{
$realip = getenv('REMOTE_ADDR');
}
}
return $realip;
}
16、语句include和require的区别是什么?为避免多次包含同一文件,可用(?)语句代替它们? (2分)
发生异常时include产生警告require产生致命错误
只包含一次 include_once,require_once
17、如何修改SESSION的生存时间(1分).
session_set_cookie_params(生存秒数);
session_set_cookie_params();
18、有一个网页地址, 比如PHP开发资源网主页: http://www.phpres.com/index.html,如何得到它的内容?($1分)
file_get_contents();
file_get_contents($url)
19、在HTTP 1.0中,状态码401的含义是(?);如果返回“找不到文件”的提示,则可用 header 函数,其语句为(?);(2分)
401 未授权访问Unauthorized;header('HTTP/1.1 404 Not Found');
20、在PHP中,heredoc是一种特殊的字符串,它的结束标志必须?(1分)
必须顶格。
跟起始的一样,且要换行顶格,后面加上分号
21、谈谈asp,php,jsp的优缺点(1分)——此题禁止在本帖和版本讨论。
21、谈谈对mvc的认识(1分)
视图模型控制器
-------------------------------------------------------------------
22、写出发贴数最多的十个人名字的SQL,利用下表:members(id,username,posts,pass,email)(2分)
select * from `members` order by `posts` limit 10;
select members.username from members order by posts DESC limit 10
23. 请说明php中传值与传引用的区别。什么时候传值什么时候传引用?(2分)
传值是传递堆里一个值的拷贝,传引用是传递栈里一个指向某值的符号的拷贝。改变原值传引用,不改变就传值。
24. 在PHP中error_reporting这个函数有什么作用? (1分)
设定错误讯息回报的等级
25. 请写一个函数验证电子邮件的格式是否正确 (2分)
function isEmail($str)
{
return ereg('^[-_\.a-zA-Z0-9]+@[-a-zA-Z0-9]+\.[-\.a-zA-Z0-9]+, $str); }
$ismail= (preg_match("/^\w+([-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/", $Email))? 'Yse' : 'No'; 
26. 简述如何得到当前执行脚本路径,包括所得到参数。(2分) REQUEST_URI echo  SERVER['scrīpt_FILENAME']."?".SERVER['QUERY_STRING']; 
27.如何修改SESSION的生存时间. (1分) 
21、JS表单弹出对话框函数是?获得输入焦点函数是? (2分) alert(),prompt(),confirm()-- focus() 
22、JS的转向函数是?怎么引入一个外部JS文件?(2分) target.location.href <scrīpt src=""/> 
23、foo()和@foo()之间有什么区别?(1分) @可以屏蔽错误!
 24、如何声明一个名为”myclass”的没有方法和属性的类? (1分) class myclass{}; 
25、如何实例化一个名为”myclass”的对象?(1分) $newClass = new myclass(); 
26、你如何访问和设置一个类的属性? (2分) 通过-〉 $newClass = new myclass(); $testVar=$newClass->test; $newClass->test="my string"; 27、mysql_fetch_row() 和mysql_fetch_array之间有什么区别? (1分) mysql_fetch_row -- 从结果集中取得一行作为枚举数组 mysql_fetch_array -- 从结果集中取得一行作为关联数组,或数字数组,或二者兼有 -------------------------------------------------------------------- 28、GD库是做什么用的? (1分)GD库主要是用来做图片处理用的。 29、指出一些在PHP输入一段HTML代码的办法。(1分) echo "<table></table>"; print("<table></table>"); 30、下面哪个函数可以打开一个文件,以对文件进行读和写操作?(1分)(c) (a) fget() (b) file_open() (c) fopen() (d) open_file() 31、下面哪个选项没有将 john 添加到users 数组中? (1分)(c)(d) (a) $users[] = ‘john’; (b) array_add($users,’john’); (c) array_push($users,‘john’); (d) $users ||= ‘john’; 32、下面的程序会输入是否?(1分) <?php $num = 10; function multiply(){ $num = $num * 10; } multiply(); echo $num; ?> 否,局部变量 33、使用php写一段简单查询,查出所有姓名为“张三”的内容并打印出来 (2分) 表名User Name Tel Content Date 张三 13333663366 大专毕业 2006-10-11 张三 13612312331 本科毕业 2006-10-15 张四 021-55665566 中专毕业 2006-10-15 请根据上面的题目完成代码: $mysql_db=mysql_connect("local","root","pass"); @mysql_select_db("DB",$mysql_db); $result = mysql_query('select * from `user` where `name`=\'张三\''); while ($row = mysql_fetch_array($result)) { echo 'name:'.$row['name'].'tel:'.$row['tel'].'<br />'; } $mysql_db=mysql_connect("local","root","pass"); @mysql_select_db("DB",$mysql_db); $result=mysql_query("select * from User where Name='张三'"); while($row=mysql_fetch_array($result)) { echo $row['Name'].$row['Tel'].$row['Content'].$row['Date']; echo "<br>"; } 34、如何使用下面的类,并解释下面什么意思?(3) class test{ function Get_test($num){ $num=md5(md5($num)."En"); return $num; } } 双重md5加密 $testObject = new test(); $encryption = $testObject->Get_test("xiaotian_ls"); ---------------------------------------------------------------------------- 35、写出 SQL语句的格式 : 插入 ,更新 ,删除 (4分) 表名User Name Tel Content Date 张三 13333663366 大专毕业 2006-10-11 张三 13612312331 本科毕业 2006-10-15 张四 021-55665566 中专毕业 2006-10-15 (a) 有一新记录(小王 13254748547 高中毕业 2007-05-06)请用SQL语句新增至表中 (b) 请用sql语句把张三的时间更新成为当前系统时间 (c) 请写出删除名为张四的全部记录 (a) 有一新记录(小王 13254748547 高中毕业 2007-05-06)请用SQL语句新增至表中 INSERT INTO User('Name','Tel','Content','Date') VALUES('小王','13254748547','高中毕业','2007-05-06') (b) 请用sql语句把张三的时间更新成为当前系统时间 UPDATE User SET Date=DATE_FORMAT(NOW(),'%Y-%m-%d') WHERE Name='张三' (c) 请写出删除名为张四的全部记录 DELETE FROM User WHERE Name='张四' 36、请写出数据类型(int char varchar datetime text)的意思; 请问varchar和char有什么区别(2分) 37、MySQ自增类型(通常为表ID字段)必需将其设为(?)字段(1分) 38、写出以下程序的输出结果 (1分) 4 <? $b=201; $c=40; $a=$b>$c?4:5; echo $a; ?> 39、检测一个变量是否有设置的函数是否?是否为空的函数是?(2分) ----------------------------------------------------------------------------- 40、取得查询结果集总数的函数是?(1分)count() 41、$arr = array('james', 'tom', 'symfony'); 请打印出第一个元素的值 (1分)print $arr[0]; 42、请将41题的数组的值用','号分隔并合并成字串输出(1分) print $arr[0].","$arr[1].","$arr[2] ;//^_^ $arr1 = implode(",",$arr); 43、$a = 'abcdef'; 请取出$a的值并打印出第一个字母(1分) print substr($a, 0, 1); 44、PHP可以和sql server/oracle等数据库连接吗?(1分) 可以 45、请写出PHP5权限控制修饰符(3分) 46、请写出php5的构造函数和析构函数(2分) ------------------------------------------------------------------------------ 47、以下请用PHPMYADMIN完成 (一)创建新闻发布系统,表名为message有如下字段 (3分) id 文章id title 文章标题 content 文章内容 category_id 文章分类id hits 点击量 Create table message (id int auto_increment primary key,title varchar(50) not null,content text not null,category_id smallint default 1,hits int not null) (二)同样上述新闻发布系统:表comment记录用户回复内容,字段如下 (4分) comment_id 回复id id 文章id,关联message表中的id comment_content 回复内容现通过查询数据库需要得到以下格式的文章标题列表,并按照回复数量排序,回复最高的排在最前面文章id 文章标题 点击量 回复数量用一个SQL语句完成上述查询,如果文章没有回复则回复数量显示为0 (三)上述内容管理系统,表category保存分类信息,字段如下 (3分) category_id int(4) not null auto_increment; categroy_name varchar(40) not null; 用户输入文章时,通过选择下拉菜单选定文章分类写出如何实现这个下拉菜单
 

此文章由 http://www.ositren.com 收集整理 ,地址为: http://www.ositren.com/htmls/1173.html