简述题(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;
用户输入文章时,通过选择下拉菜单选定文章分类
写出如何实现这个下拉菜单