打开网站出现hack语言 by 3n_byt3 :P是什么意思

发送私信成功
满足所有需求,助您轻松工作
PHP中级程序员常见面试题(有参考答案)
14:55 && 浏览量(4614) &&
写一个函数,尽可能高效的,从一个标准url里取出文件的扩展名例如: .cn/abc/de/fg.php?id=1需要取出php或.php
答: 1、$a=".cn/abc/de/fg.php?id=1";&&&&
2、$b=parse_url($a);
3、Echosubstr($b['path'],strpos($b['path'],'.')); 或者:
4、Echoend(explode('.',$b['path']));2
描述一下大流量高并发量网站的解决方案
答: 1、确认服务器硬件是否足够支持当前的流量。
2、使用memcache缓存技术,将动态数据缓存到内存中,动态网页直接调用这些文件,而不必在访问数据库。
3、禁止外部的盗链。
4、外部网站的图片或者文件盗链往往会带来大量的负载压力,因此应该严格限制外部对自身图片或者文件盗链,目前可以简单的通过refer来控制盗 链,apache自己就可以通过配置来禁止盗链。
5、控制大文件的下载。 大文件的下载会占用很大的流量,对于非SCSI硬盘来说会消耗,使得网站响应能力下降。
6、使用不同的主机分流主要流量
7、使用流量统计软件。 在网站上安装一个流量统计软件,可以即时知道哪些地方耗费了大量流量,哪些页面需要再进行优化。
8、分库分表。
9、Sphinx全文索引引擎。
如何设计或配置Mysql,才能达到高效使用的目的。
1、数据库设计方面,设计结构良好的数据库,允许部分数据冗余。 选取最适用的字段属性,尽可能把字段设置为NOTNULL,这样在查询的时候,数据库不用去比较NULL值。
2、系统架构设计方面,表散列,把海量数据散列到几个不同的表里面,集群,数据库查询和写入分开。 写高效sql语句,以提高效率。使用连接(join)来代替子查询使用联合(union)来代替手动创建的临时表所得皆必须,只从数据库取必须的数据。必 要的时候用不同的存储引擎,比如Innodb可以减少死锁,HEAP可以提高一个数量级的查询速度。
使用事务使用外键使用索引24.如何进行防SQL注 入?
1、过滤掉一些常见的数据库操作关键字:select,insert,update,delete,and,*等或者通过系统函 数:addslashes(需要被过滤的内容)来进行过滤。
2、在PHP配置文件中Register_globals=设置为关闭状态 //作用将注册全局变量关闭。比如:接收POST表单的值使用$_POST['user'],如果将register_globals=直接使 用$user可以接收表单的值。
3、SQL语句书写的时候尽量不要省略小引号(tab键上面那个)和单引号
4、提高数据库命名技巧,对于一些重要的字段根据程序的特点命名,取不易被猜到的
5、对于常用的方法加以封装,避免直接暴漏SQL语句
6、开启PHP安全模式Safe_mode=
7、打开magic_quotes_gpc来防止SQL注入 Magic_quotes_gpc=默认是关闭的,它打开后将自动把用户提交的sql语句的查询进行转换,把'转为\',这对防止sql注入有重 大作用。因此开启:magic_quotes_gpc=
8、控制错误信息关闭错误提示信息,将错误信息写到系统日志。
9、使用mysqli或pdo预处理。
用PHP写出一个安全的用户登录系统需要注意哪些方面。
1、密码要使用MD5(密码+字符串)进行加 密。
2、登录表单的名称不要跟数据库字段一样,以免暴漏表字段。
3、用户表的表名、字段名、密码尽量用不容易被猜到的。
4、要使用验证码验证登陆,以防止 暴力破解。
5、验证提交的数据是不是来自本网站。
6、登录后台处理代码数据库部分使用预处理,做好过滤,防止sql注入。
使用过哪些PHP框架。试 描述其优劣点。
1、BroPHP框架:优点:轻量级学习型框架,配置简单,操作简单,容易上手,提供了比较全面的文档。缺点:
2、ThinkPHP框 架:优点:功能比较全面,配置相对比较简单,操作相对比较简单,有很多使用示例程序。缺点:提供的操作方法太多,新手不知如何选择,文档不够全面。
用过哪些版本控制工具?
答:使用过SVN版本控制器。
输出为Mozilla/4.0(MSIE5.01;Window NT 5.0)时,可能的输出语句是:B
A.$_SERVER['HTTP_USER_AGENT_TYPE'];
B. $_SERVER['HTTP_USER_AGENT'];
C. $_SERVER['USER_AGENT'];
D. $_SERVER['AGENT'];
下面功能PHP无法实现的是:D
A. 服务器端脚本运行
B. 命令行脚本运行
C. 客户端图形界面(GUI)程序
D. 浏览器端执行DOM操作
下面说法不正确的是:C
A. PHP有四种标量类型:布尔型(boolean),整型(integer),浮点型(float),字符串(string)
B. 浮点型(float)与双精度型(double)是同一种类型
C. 符合类型包括:数组(array),对象(object),资源(resource)
D. 伪类型:混合型(mixed),数字型(number),回调(callback)
下面不是PHP语法的组成部分的函数是:AD
A. array B. eval C. each D. list
执行下面的代码的结果是什么?A
A. boolean
B. boolean0
C. booleanFALSE
D. booleanfalse
SESSION与 COOKIE的区别是什么,请从协议,产生的原因与作用说明?
答:1、http无状态协议,不能区分用户是否是从同一个网站上来的,同一个用户请求不同的 页面不能看做是同一个用户。
2、SESSION保存在服务器端,COOKIE保存在客户端,SESSION依赖COOKIE进行传输,如果COOKIE被 禁用了,SESSION将不能继续使用。
HTTP状态中302、403、 500代码含义?
300重定向、403服务器拒绝访问、500服务器内部错误。
Linux 下建立压缩包,解压缩包的命令。
答:1、压缩:gzip 、tar -cvfz、zip、bzip22、解压:gunzip、tar -zxvf、unzip、bunzip2$a=3;$b=4; if($a||$b=5){ ||或和|的区别 echo 'todo'; } $b的值是(a):A a. 4; b. 5; c. 3; d. false
什么是面向对象?主要特征是什么?
答:1、面向对象是程序的一种设计方式,它利于提高程序的重用性,是程序结构更加清晰。2、主要特征:封装、继承、多态。
& 收藏(0) 收藏 +1 已收藏 取消
& 推荐上头条 推荐 +1 推荐上头条 已推荐
文章上传作者
ling00018的热门文章
开发者交流群:
DevStore技术交流群2:
运营交流群:
产品交流群:
深圳尺子科技有限公司
深圳市南山区蛇口网谷万海大厦C栋504
Copyright (C) 2015 DevStore. All Rights Reserved
DevStore用户登录
还没有DevStore帐号?
快捷登录:php工程师面试题_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
php工程师面试题
上传于|0|0|文档简介
&&php工程师面试题
阅读已结束,如果下载本文需要使用1下载券
想免费下载本文?
定制HR最喜欢的简历
你可能喜欢width:100%">
听人生若初见ゥ一席话,省我十本书!
width:100%">
好多兽医在广场上义诊,楼主去看看吧!
width:100%">
很好!很强大!
width:100%">
介是神马?!!
width:100%">
人生若初见ゥ有内涵!
width:100%">
读了楼主人生若初见ゥ的帖子,顿时马桶就通了。。。
width:100%">
勤奋灌水,天天向上!
width:100%">
人生若初见ゥ好聪明啊!
width:100%">
人生若初见ゥ的回贴低调奢华有内涵
width:100%">
12345678910
Comsenz Inc. Design: Dean. DiscuzFans.php牛逼的面试题分享
字体:[ ] 类型:转载 时间:
群友发的php牛逼的面试题,喜欢的朋友可以看看
1.nginx使用哪种网络协议? nginx是应用层 我觉得从下往上的话 传输层用的是tcp/ip 应用层用的是http fastcgi负责调度进程 2. &? echo 'hello tusheng' ; ?& 没有输出结果, 可能是什么原因, 简述的解决此问题的过程(提示: 语法没有问题) 可能服务器上面没有开启短标签short_open_tag =设置为Off,,php.ini开启短标签控制参数: short_open_tag = On 3. 简述下面程序的输出结果, 简要说明为什么, 如何解决这类问题? &?php $tmp = 0 == "a"? 1: 2; echo $ ?& 结果 1 int和string类型强制转换造成的,0==="a" 0 == 0 肯定是true啊 PHP是弱类型。。 $tmp = 0 === "a"? 1: 2; echo $ 这样就是2 4. 已知一个字符串如下: $str = "1109063 milo 1"; 用一行代码将该字符串里面的1109063赋值给$uid, milo赋值给$user, 1赋值给$type 空格如下 list($uid, $user, $type) = explode(" ", $str); \t如下 list($uid, $user, $type) = explode("\t", $str); list($uid, $user, $type) = sscanf($str, "%d %s %d"); $n = sscanf($auth, "%d\t%s %s", $id, $first, $last); 5. 分别列出如下类型的有符号和无符号范围 TINYINT SMALLINT MEDIUMINT INT TINYINT-2^7 - 2^7-10 ~ 2^8-1 SMALLINT-2^15 - 2^15-1 0 ~ 2^16-1 MEDIUMINT-2^23 - 2^23-1 0 ~ 2^24-1 INT-2^31 - 2^31-1 0 ~ 2^32-1 6. 将下面的数组用一行拼装成一个字符串i am milo! day day up! &?php $arr = array( 'I', 'AM', 'MILO!', 'DAY', 'DAY', 'UP!' ); ?& $str = strtolower(implode(" ",$arr)); 7. 调用如下函数获取函数并获取count的值 &?php function get_list($cnd = array(), &$count = false) { // 伪代码 处理$cnd 并赋值datas $datas = 'i am call back'; $count && $count = rand(1, 10000); return $ } ?& $count=1; $data = get_list($cnd,&$count); echo $ 8. 几种方式去取代session机制, 简单描述各自的优劣 mysql、memcache、cookie保持一种唯一状态标识码 9. 下列HTTP状态码出现的可能原因, 如何处理 200, 301, 404, 502, 503 200   请求已成功,请求所希望的响应头或数据体将随此响应返回。 301   被请求的资源已永久移动到新位置,并且将来任何对此资源的引用都应该使用本响应返回的若干个 URI 之一。如果可能,拥有链接编辑功能的客户端应当自动把请求的地址修改为从服务器反馈回来的地址。除非额外指定,否则这个响应也是可缓存的。   新的永久性的 URI 应当在响应的 Location 域中返回。除非这是一个 HEAD 请求,否则响应的实体中应当包含指向新的 URI 的超链接及简短说明。   如果这不是一个 GET 或者 HEAD 请求,因此浏览器禁止自动进行重定向,除非得到用户的确认,因为请求的条件可能因此发生变化。   注意:对于某些使用 HTTP/1.0 协议的浏览器,当它们发送的 POST 请求得到了一个301响应的话,接下来的重定向请求将会变成 GET 方式。 404   请求失败,请求所希望得到的资源未被在服务器上发现。没有信息能够告诉用户这个状况到底是暂时的还是永久的。假如服务器知道情况的话,应当使用410状态码来告知旧资源因为某些内部的配置机制问题,已经永久的不可用,而且没有任何可以跳转的地址。404这个状态码被广泛应用于当服务器不想揭示到底为何请求被拒绝或者没有其他适合的响应可用的情况下。 502   作为网关或者代理工作的服务器尝试执行请求时,从上游服务器接收到无效的响应。 503   由于临时的服务器维护或者过载,服务器当前无法处理请求。这个状况是临时的,并且将在一段时间以后恢复。如果能够预计延迟时间,那么响应中可以包含一个 Retry-After 头用以标明这个延迟时间。如果没有给出这个 Retry-After 信息,那么客户端应当以处理500响应的方式处理它。   注意:503状态码的存在并不意味着服务器在过载的时候必须使用它。某些服务器只不过是希望拒绝客户端的连接。 200 OK 一切正常,对GET和POST请求的应答文档跟在后面。 301 Moved Permanently 客户请求的文档在其他地方,新的URL在Location头中给出,浏览器应该自动地访问新的URL 404 Not Found 无法找到指定位置的资源。这也是一个常用的应答。 502 Bad Gateway 服务器作为网关或者代理时,为了完成请求访问下一个服务器,但该服务器返回了非法的应答。 503 Service Unavailable 服务器由于维护或者负载过重未能应答。例如,Servlet可能在数据库连接池已满的情况下返回503。服务器返回503时可以提供一个Retry-After头。 10. 有如下数据库, 用原生态mysql扩展去连接并查询user表的前十行 host: 192.168.0.254 port: 3306 user: one pass: piece database: db_user table: user $link = mysql_connect("192.168.0.254:3306","one","piece") or die('Could not connect: '.mysql_error()); mysql_select_db('db_user',$link); $query = mysql_query("select * from user limit 10"); while($rs = mysql_fetch_array($query,MYSQL_ASSOC)) {} 11. 用autoload($class) 实现Lib目录下的类的自动加载并可以兼容子目录 $request-&action = lcfirst(implode(array_map( 'ucfirst', explode('-', strtolower($request-&action)) ))); ------------------------------------------------------------ function __autoload($class) { $cls = strtolower(str_replace("_","/",$class)); if(file_exsits(LIB.$cls.'.php')) { include_once(LIB.$cls.'.php'); } else { die("not found {$class} class"); } } defined("LIB",'/data/wwwroot//lib/'); $author = new Lib_Author(); ----------------------------------------------------------- function __authload($class) { $cls = explode("_",$class); if(@is_dir($cls[1])) { if(@is_file($cls[2])) { include_once("CON_PATH".$cls[1].'/'.$cls[2].".php"); } else { dir('error'); } } else if(@is_file($cls[1].".php")) { include_once("CON_PATH".$cls[1].".php"); } else { dir('error'); } } --------------------------------------- function __autoload($class) { $cls = explode("_",$class); $file = get_file($cls); if($file=='error') { die('error'); } include_once($file); } function get_file($dir) { if(is_array($dir)) { foreach($dir as $k=&$v) { $tmpdir .= $v.'/'; if(is_dir('CON_PATH'.$tmpdir)) { continue(); } else if(is_file('CON_PATH'.$tmpdir.".php")) { return 'CON_PATH'.$tmpdir.".php"; } else { return 'error'; } } return 'error'; } return 'error'; } defined("CON_PATH","/data/wwwroot//app/cntroller/"); $sb = new controller_sb(); ------------------------------------ function __autoload_my_classes($classname) { # ... your logic to include classes here } spl_autoload_register('__autoload_my_classes'); ----------------------------------------------------------- 12. 用set_error_handle 去捕获错误并输出, 级别自己定 set_error_handle(callback,level) function callback(int $errno , string $errstr [, string $errfile [, int $errline [, array $errcontext ]]] ){ } function dealErrorHandler($errno,$errstr,$errfile,$errline) { switch($errno){ case E_USER_ERROR: echo "error [$errno] $errstr fatal error on line $errline in file $errfile";
case E_USER_WARNING: echo "my warning [$errno] $errstr":
case E_USER_NOTICE: echo "my notice[$errno] $errstr";
default: echo "unkonwn error type :[$errno] $errstr";
} } set_erro_handler(dealErrorHandler); trigger_error("notice", E_USER_NOTICE); trigger_error("warning", E_USER_WARNING); trigger_error("error", E_USER_ERROR); 13. 简述两种屏蔽php程序的notice警告的方法 初始化变量,文件开始设置错误级别或者修改php.ini 设置error_reporting set_error_handler 和 @抑制错误 1.在程序中添加:error_reporting (E_ALL & ~E_NOTICE); 2.或者修改php.ini中的:error_reporting = E_ALL 改为:error_reporting = E_ALL & ~E_NOTICE 3.error_reporting(0);或者修改php.inidisplay_errors=Off 14. instanceof的作用, 经常在什么设计模式中使用 单例模式,但是其他的模式也会用到 15. 1023用二进制表示, 并简述计算过程 10-2
511%2 =1 255%2 =1 127%2 =1 63%2 =1 31%2 =1 15%2 =1 7%2 =1 3%2 =1 1%2 =1 0 =0 ------------------------------------------- 1023 2^9=&N&2^10 511 k=9 10 9 8 7 6 5 4 3 2 1 1 1 1 1 1 1 1 1 1 1 ---------------------- 1023 1 =511 1 511-1/2=255 1 255-1/2=127 1 127-1/2=63 1 63-1/2=31 1 31-1/2=15 1 15-1/2=7 1 7-1/2=3 1 3-1/2=1 1 ----------------------------------------------- 2-10 只需用将二进制数的各个位上的数从最右边开始,最右边的第一个数乘以二的零次方,第二个数乘以二的一次方,第三个数乘以二的二次方,依次类推可得第n个数乘以二的(n-1)次方,然后把得到的结果相加即可 例如:*2^0+1*2^1+0*2^2+0*2^3+1*2^4+1*2^5=51 这也可以算是一个公式就是An*2^(n-1) An表示二进制数最右边开始的第n个数, 将第一项第二项第三项一直到第n项用式子An*2^(n-1) 计算出来并加在一起即可 16. 下面php程序输出的内容是什么? 为什么? &?php $str = "aa\tbb\tcc"; @list($a, $b, $c) = explode('\t', $str); echo $a,$b,$c; ?& //'\t'不会以\t切割字符串,explode之后申城一个array(0=&"aa\tbb\tcc")所以。。。,'\t'换成"\t"就被切割 17. include和require 分别返回什么错误级别 include会系统警告并继续执行,require会发出系统警告但是会引致致命错误令脚本终止运行 18. 现有一个函数, 有不确定多少个的参数(可能有5个也可能有50个), 如何去定义这个函数 方法一: 不借助php内置函数 方法二: 提示func_num_args() func_get_arg() unc_get_args() function param() { $numargs = func_num_args(); echo "Number of arguments: $numargs&br /&\n"; if ($numargs &= 2) { echo "Second argument is: " . func_get_arg(1) . "&br /&\n"; } $arg_list = func_get_args(); for ($i = 0; $i & $ $i++) { echo "Argument $i is: " . $arg_list[$i] . "&br /&\n"; } } param(1,2,3,4,5); /** 2 * 例子写完后,本来认为完事了,结果遇到有人问call_user_func_array(),看了一下手册 3 * 原来,我上面的那个test函数还可以精简成如下的例子, 4 */ 5 function otest1 ($a) 6 { 7 echo( '一个参数' ); 8 } 9 10 function otest2 ( $a,$b) 11 { 12 echo( '二个参数' ); 13 } 14 15 function otest3 ( $a,$b,$c) 16 { 17 echo( '三个啦' ); 18 } 19 20 function otest () 21 { 22 $args=func_get_args(); 23 $num=func_num_args(); 24 call_user_func_array( 'otest'.$num,$args ); 25 } 26 27 otest(1,2); 19. 在一个函数(该函数没有return语句)里面去处理全局变量, 并且改变他的值, 用两种方法去实现(global和引用&) $var=1; function get_pra() { global $ $var = 'xxx'; echo $ } echo $var.'--'; get_pra(); echo $ ---------------------------------- $test = 1; $test1 = 2; function get_yinyong() { global $test1; $GLOBALS["test"] = &$test1; } echo $test."\n"; get_yinyong(); echo $ ---------------------------- 20. 应用中我们经常会遇到在user表随机调取10条数据来展示的情况, 简述你如何实现该功能, 不能使用sql函数以及order by等语句 表 user 字段uid, username 估计一个user表中的区间,在此区间用php去一个随机数,sql语句大于或者小于此id去limit几十条(保证10条数据),再不够散乱的话,取出来的数据shuffle函数打乱数组,array_rand随即取出10个 21. 假设下面的sql语句里面的uid都能获取到具体值, 经过下面语句查询后uid的顺序是什么, 如何去按照uid in 输入的顺序去排序 select uid from user where uid in(10, 1, 3, 8, 11, 4, 7); 可观的结果是1,3,4,7,8,10,11升序,有种情况特殊就是不确定因为中间的某些id人为直接修改可能不是升序了,如果按照uid in的顺序需要重新循环一次根据id获取查询结果数组中的值放进新数组中即可 22. 用PHP将一个字符串中的字母替换成** preg_replace('/[a-zA-Z]*/','**',$str); 如果指定的字符就可以str_replace('ooxx','**',$str); 23. 下面2.php中打印结果是什么? 为什么? 执行顺序1.php-&2.php cookie,cookie时间就有问题time()+3600 24. 简述php常用的json编码函数, 如何将json解码的时候返回数组 25. mysql 在sql语句中有' / 等词的时候, 要对sql语句的每个具体值做些什么处理 mysql_real_escape_string 26. 如何在php中设置header头信息 header(''); 27.有如下几个脚本, 请问2.php的输出结果 1.php &?php setcookie('test', 'cookie_test', 3600); ?& 2.php &?php $cookie = isset($_COOKIE['test'])? $_COOKIE['test']: 'cookie'; echo $ ?& i am here 1 总结 a.如果include或include_once不是在函数或方法中被调用,则输出结果均一样。 b.如果include或 include_once在函数或方法中被调用,则如果想让第二次及以后调用时有结果,则必须用include,而不能用include_once,这一点一定要注意。 28. 简述call_user_func的功能 调用函数或者类里面的函数,返回第一个参数的值。类似的功能call_user_func_array 29. 访假设nginx已经配置server_name www.120.net xxx.120.net 访问问http://www.120.net/index.php和http://xxx.120.net/index.php之后 $_SERVER["SERVER_NAME"] 和 $_SERVER["REQUEST_URI"]分别是什么 www.120.net xxx.120.net /index.php /index.php 30. linux下某文件的属性为 drwxr-xr-x 用数字表示其权限是 目录权限为755所有者u拥有读写修改权限所属组g拥有读、修改权限所属组之外o的拥有读和修改权限 31. 宽带的1Mbps理论上的下载速度是多少KBps, 计算的方法 1*1024/8 1M=1024KB 1KB=1024B 1B=8bit 第二部分 1. 简单实现一个单例+工厂的设计模式abstract class Example{ // The parameterized factory method public static function factory($type) { if (include_once 'Drivers/' . $type . '.php') { $classname = 'Driver_' . $ return new $ } else { throw new Exception ('Driver not found'); } }}// Load a MySQL Driver$mysql = Example::factory('MySQL'); // Load a SQLite Driver $sqlite = Example::factory('SQLite'); definded('DRIVER','/data/wwwroot//core/driver/');abstract class Example(){ private function __construct() { } public static function factory($type) { if(include_once(DRIVER.$type.'.php')) { return ExampleSon::singleton($type); } else { throw new Exception("Driver is not found!"); } } }class ExampleSon implements Example{ // Hold an instance of the class private static $ //静态私有的类实例 // A prevents direct creation of object private function __construct() { echo 'I am constructed'; } // The singleton method public static function singleton() { if (!isset(self::$instance)) { //如果没有设置静态私有类实例,创建之 $c = __CLASS__; //获得类名称 self::$instance = new $c } return self::$ } // Example method public function bark() { echo 'Woof!'; } // Prevent users to clone the instance public function __clone() //不允许被克隆 { trigger_error('Clone is not allowed.', E_USER_ERROR); }}关键词: 1 私有静态成员变量 2 __CLASS__获取当前类名 3 公共静态方法获取单例 4 覆盖__clone()方法 ----十个字:私有静态量,公共静态法-------- 2. 例举几个常用的魔术方法, 并说明作用? 如何在打印一个对象的时候展示我们自定义的内容? 魔术函数 1。__construct() 实例化对象时被调用, 当__construct和以类名为函数名的函数同时存在时,__construct将被调用,另一个不被调用。 2。__destruct() 当删除一个对象或对象操作终止时被调用。 3。__call() 对象调用某个方法, 若方法存在,则直接调用; 若不存在,则会去调用__call函数。 4。__get() 读取一个对象的属性时, 若属性存在,则直接返回属性值; 若不存在,则会调用__get函数。 5。__set() 设置一个对象的属性时, 若属性存在,则直接赋值; 若不存在,则会调用__set函数。 6。__toString() 打印一个对象的时被调用。如echo $或print $ 7。__clone() 克隆对象时被调用。如:$t=new Test();$t1=clone $t; 8。__sleep() serialize之前被调用。若对象比较大,想删减一点东东再序列化,可考虑一下此函数。 9。__wakeup() unserialize时被调用,做些对象的初始化工作。 10。__isset() 检测一个对象的属性是否存在时被调用。如:isset($c-&name)。 11。__unset() unset一个对象的属性时被调用。如:unset($c-&name)。 12。__set_state() 调用var_export时,被调用。用__set_state的返回值做为var_export的返回值。 13。__autoload() 实例化一个对象时,如果对应的类不存在,则该方法被调用。 魔术常量 1。__LINE__ 返回文件中的当前行号。 2。__FILE__ 返回文件的完整路径和文件名。如果用在包含文件中,则返回包含文件名。自 PHP 4.0.2 起,__FILE__ 总是包含一个绝对路径,而在此之前的版本有时会包含一个相对路径。 3。__FUNCTION__ 返回函数名称(PHP 4.3.0 新加)。自 PHP 5 起本常量返回该函数被定义时的名字(区分大小写)。在 PHP 4 中该值总是小写字母的。 4。__CLASS__ 返回类的名称(PHP 4.3.0 新加)。自 PHP 5 起本常量返回该类被定义时的名字(区分大小写)。在 PHP 4 中该值总是小写字母的。 5。__METHOD__ 返回类的方法名(PHP 5.0.0 新加)。返回该方法被定义时的名字(区分大小写)。 3. 类静态方法和实例化类方法比较及优缺点 4. 有一个论坛 threads表记录主题以及标题等信息 posts表记录主题内容以及回复内容等信息 threads 表主键为 tid posts 表主键为 pid, 所属主题标记为tid 通过tid将threads和posts 一对多关联起来 现在数据量posts表达到了1亿, threads表2000万, 大约一个主题有5篇回复 请你设计一下分表, 将posts表和threads表进行mysql分表 5. 现在有一个mysql 主库/丛库, 请问php mysql查询的时候怎么在php程序中实现主从分离? 主从分离有什么好处配置主从数组文件,自己封转几个model函数,查询的加载slave配置实例化,破坏数据的操作加载master进行实例化优点:并发负载能力提高,利于数据维护和安全,提高可用性缺点:数据同步有些延迟 6. 简述UCenter的单点登录机制 所谓单点登录,无非就是几个站点共用一个用户中心,实现同步登陆,同步退出。 其实最终还是用户去登录,只是采用了ajax (javascript利用src异步跨域调用)用户不会发现。 而且利用了p3p头实现了,不同域名,单点登录(ucenter用的cookie) 缺点就是采用ajax 客服端请求 ,如果有10个以上应用,登录速度就慢下来了。 7. linux相关 有一个包 http://www.120.net/test-1.0.0.tar.gz a. 将它下载到/usr/local/src b. 将其源码编译安装到/usr/local/test 目录 c. 他依赖mysql包, 位于/usr/local/mysql 目录 写出下载编译安装过程 wget - c http://www.120.net/test-1.0.0.tar.gz/usr/local/srctar zxvf /usr/local/src/test-1.0.0.tar.gzcd /usr/local/src/test-1.0.0./configure --prefix=/usr/local/test --exec--prefix=/usr/local/mysqlmake testmake install 8. 使用php 的memcache扩展编写一个获取数据的函数(缓存即将过期超时加锁) a. 数据超时之后去mysql获取, 获取完后更新memcache b. 去mysql获取数据的时候加锁, 让一个进程去mysql拉数据, 其他人返回memcache中的数据 public function get_cache($key) { if($this-&memcahe) { $var = $this-&memcahe-&get($this-&pre.$key); $valid = $this-&memcahe-&get($this-&pre.$key.'_valid'); if($var && !$valid) { $lock = $this-&memcahe-&get($this-&pre.$key.'_lock'); if(!$lock) { $this-&memcahe-&set($this-&pre.$key.'_lock', true, 0, 60); } } return $ } } public function set_cache($key, $var = null, $expire = 0) { if($this-&memcahe) { $expire = (int)$ $expire = ($expire ? $expire : $this-&expire); $this-&memcahe-&set($this-&pre.$key, $var, 0, $expire+300); $this-&memcahe-&set($this-&pre.$key.'_lock', false, 0, $expire); $this-&memcahe-&set($this-&pre.$key.'_valid', true, 0, $expire); } } 9. 简述队列, 堆栈的原理 都可以看做是一维数组来操作,队列先进先出,出列只能在列头,进列只能在列尾,堆栈是后进先出,进栈和出栈都是从栈顶 堆栈的工作原理是什么? 堆栈是一种抽象数据结构,其操作机理是后进先出。当你把新条目推进堆栈时,已经在堆栈内的任何条目都会压到堆栈的深处。同样的,把一个条目从堆栈移出则会让堆栈内的其他条目都向堆栈的顶部移动。只有堆栈最顶端的条目能从堆栈中取出,条目离开堆栈的顺序和它们被推进堆栈的顺序一样。你不妨回想下自动售货机的装货和取货过程就明白了。 10. arrayaccess 定义如下 用它实现一个数组 ArrayAccess { /* Methods */ abstract public boolean offsetExists ( string $offset ) abstract public mixed offsetGet ( string $offset ) abstract public void offsetSet ( string $offset , string $value ) abstract public void offsetUnset ( string $offset ) } class Single implements ArrayAccess{ private $ private static $_Instance = private function __construct() { } static function load() { if(null == self::$_Instance) { self::$_Instance = new Single(); } return self::$_I } public function setName($name) { $this-&name = $ } public function getName() { return $this-& } /** * 实现四个方法 * offsetExists(),用于标识一个元素是否已定义 * offsetGet(),用于返回一个元素的值 * offsetSet(),用于为一个元素设置新值 * offsetUnset(),用于删除一个元素和相应的值 **/ public function offsetSet($offset, $value) { if (is_null($offset)) { $this-&container[] = $ } else { $this-&container[$offset] = $ } } public function offsetGet($offset) { return isset($this-&container[$offset]) ? $this-&container[$offset] : } public function offsetExists($offset) { return isset($this-&container[$offset]); } public function offsetUnset($offset) { unset($this-&container[$offset]); }}$s = Single::load();$s-&setName("jack");$s["name"] = "mike";echo $s-&getName(); //jackecho $s["name"]; //mike 11. 假设coreseek安装目录为/usr/local/coreseek 配置文件为/usr/local/coreseek/etc/test.conf 索引名为 post a. 创建索引 b. 启动服务 c. 重建索引(重建过程中保证搜索服务仍然可用) indexer -c /usr/local/coreseek/etc/test.conf --allsearchd -c /usr/local/coreseek/etc/test.conf indexer -c /usr/local/coreseek/etc/test.conf --all --rotate12. 假设您有一张posts帖子表 对该表进行sphinx增量准实时索引, 描述你的方案 使用“主索引+增量索引”方法有个简单的实现,在数据库中增加一个计数表,记录每次重新构建主索引时,被索引表的最后一个数据id,这样在增量索引时只需要索引这个id以后的数据即可,每次重新构建主索引时都更新这个表。 13. php代码: $i = 97;$a = ($i++) + (++$i) + $$b = (--$i) + ($i--) + $i + 6; echo "$i, $a, $b";输出结果是什么 97, 295, 299 97 97+99+99 98+98+97+6 14. 以下代码,用于取得客户端IP: if(getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')) { $onlineip = getenv('HTTP_CLIENT_IP');} elseif(getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')) { $onlineip = getenv('HTTP_X_FORWARDED_FOR');} elseif(getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), 'unknown')) { $onlineip = getenv('REMOTE_ADDR');} elseif(isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')) { $onlineip = $_SERVER['REMOTE_ADDR'];}但是以HTTP_开始的请求header均属于客户端可以伪造的信息,在反向代理环境下,如何保证PHP不会接收到伪造的HTTP_CLIENT_IP, HTTP_X_FORWARDED_FOR值? 15. 例如google,baidu等大型网站,当使用不同客户端(如手机和PC机)访问同样的URL时,呈现的页面却不相同,这是何原理? 如果能给出实际解决方案,可加分。 简单的可以用user_agent判断,但是及其初步 可以的话通过服务器或者手机终端特征或者wap网关accept信息等 16. 生产环境php.ini中magic_quotes_gpc及magic_quotes_runtime值应该设置为什么?onoff17. PHP调用远程http接口时可使用file_get_contents, 但当远程主机不可达或响应过慢,会导致本地PHP进程被长时间挂起,从而影响本地服务器稳定性,如何避免超时时,PHP进程长时间被挂起? file_get_contents可以设置下超时时间$ctx = stream_context_create(array( 'http' =& array( 'timeout' =& 1 ) ) ); file_get_contents("/", 0, $ctx); curl实现获取远程http接口也可以,同样需要设置超时时间curl_setopt($s,CURLOPT_TIMEOUT,$timeout); 18. 同上题,如何避免DNS查询过慢导致超时?19. mysql字符集set names * 命令设置哪几个系统变量的值?(ACE) A、Character_set_client B、Character_set_system C、Character_set_results D、Character_set_server E、Character_set_connection F、Character_set_database20. 以下哪种校对规则不区分大小写?(A) A、utf8_general_ci B、utf8_general_cs C、utf8_general_bin21. 如何杜绝XSS攻击? strip_tags可以初步过滤,也可以自己写过滤函数针对特殊标签进行处理,用ascii码进行替换23. 如何杜绝CSRF攻击? 在Web应用程序侧防御CSRF漏洞,一般都是利用referer、token或者验证码,tokenf方式还是比较可信
您可能感兴趣的文章:
大家感兴趣的内容
12345678910
最近更新的内容
常用在线小工具}

我要回帖

更多关于 11平台全图trehack 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信