1、请选择以下代码运行的结果:
A无任何输出结果BLOLC不执行且报错
解析:1e3是科学计数法实数的指数形式为1乘以10的三次方,故‘1e3’=='1000'是成立的,输出echo‘LOL’;
2、请选出以下代码运行的结果:
AbBaabbzzCaabcaa
解析:字符串字母相加其实就是在末尾字母加一如:$a="a";$a++;答应结果就是b,$a=''aa';结果就是ab故$a="aabb";打印结果就是aabc,如$a="aabbz";结果就是aabca,因为Z是末尾字母故加一变为a,向前一位进一,b就变为c,故结果为C;
3,写出一下程序的输出结果: $data=['a','b','c']; foreach($dataas$k=>$v){ $v=&$data[$k]; } > A$data=['a','b','c'];B$data=['b','b','c'];C$data=['b','c','c']; 解析:这里有个考点要记得就是&是引用;修改引用变量的值,那么空间的值也会改变,第一次循环得到$v=&$data[0]=>'a',第二次循环$v=&$data[1]=>'b',可见第一次引用的$data[0]的值已经被改变,所以此时的$data[0]=b,此时$v引用的$data[1],进入第三次循环此时$v又变为$v=&$data[2]=>'c',,$v又一次改变,引用的$data[1]的值也被改变为C,所以此时的$data[1]=c,这样循环结束$data[0]=>'b',$data[1]=>'c',$data[2]=>'c', 3,写出一下程序的输出结果: A空;Btrue;Cfalse;D、1;E、0;F:报错 解析:这里的考点有两个:1,echofalse和true的值;2、浮点类型不能用于精确计算;首先浮点类型的数据不能用于计算,他会将浮点类型转为二进制,所以有一定的损耗,故它无限接近于0.8,也就是0.79999999...,所以echo应该是个false;echofalse;结果是空;echotrue;结果是1; 4,用PHP写出显示客户端的IP和服务端的IP echo$_SERVER[‘REMOTE_ADDR’];//客户端IP echogethostbyname(“www.baidu.com”)//服务端 5,以下表达式的结果是: $a=0; $b=0; if($a=3>0||$b=3>0){ $a++; $b++; echo$a,$b; A报错;B:1,1;(要是真的只有两个选项该多好肯定大家都选B) 解析:此题考查的是运算符的优先级问题,首先在此题中比较运算符>逻辑运算符>赋值,所以1,先看3>0为true,2,因为是||运算所以后面的$b=3>0形成短路作用,这时的$a=true,$b=0; 故$a++;为1;$b++;为1这里解释下布尔类型运算不影响布尔类型结果;但是$b=0;$b++;就改变为1,echotrue;结果为1, 6.PHP中如何优化多个if...esleif语句的情况解析:首先尽可能将表达式可能性越大的越往前面放,其次如果我们判断的内容比较复杂且判断的值只是字符串,整型,浮点那么就可以用switch...case来代替 7. 8.用正则写出以139开头的手机号码$str='13812345678';$pattern='/^139\d{8}$/';preg_match($pattern,$str,$macth);var_dump($macth); 9.用PHP方式对目录进行遍历$dir='./test';functionloopDir($dir){$handle=opendir($dir);while(false!==($file=readdir($handle))){if($file!='.'&&$file!='..'){echo$file." ---------------------------------------------------------------------------------------------------------------------------------- 1,冒泡排序很实用要记得 按值传递:函数范围内对值的任何改变在函数外部都会被忽略 按引用传递:函数范围内对值的任何改变在函数外部也能反映出这些修改 优缺点:按值传递时,php必须复制值。特别是对于大型的字符串和对象来说,这将会是一个代价很大的操作。 按引用传递则不需要复制值,对于性能提高很有好处。 4、MySQL数据库中的字段类型varchar和char的主要区别是什么 char和varchar最大的不同就是一个是固定长度,一个是可变长度.由于是可变长度,因此存储的是实际字符串再加上一个记录字符串长度的字节。如果分配给char或varchar列的值超过列的最大长度,则对值进行裁剪. varchar(M)和char(M),M都表示字符数.varchar的最大长度为65535个字节,不同的编码所对应的最大可存储的字符数不同.char最多可以存放255个字符,不同的编码最大可用字节数不同 5、对于大流量的网站,采用什么样的方法来解决访问量问题? 6、什么是面向对象?主要特征是什么? 面向对象是程序的一种设计方式,它利于提高程序的重用性,使程序结构更加清晰。主要特征:封装、继承、多态。 7、SESSION与COOKIE的区别是什么? SESSION存储在服务器端,COOKIE保存在客户端。Session比较安全,cookie用某些手段可以修改,不安全。Session依赖于cookie进行传递。禁用cookie后,session还可以使用,在存储session的文件中,生成sessionID,通过get传参的方式将sessionID传到要实现session共享的页面,读取sessionID,从而从session中获取数据。 8、对缓存技术的了解 9、表单中get和post提交方式的区别? get是显式的,数据从url中可以看到,传输的数据量小,安全性低;post是隐式的,传送的数据量较大,安全性较高 10、优化mysql数据库的方法 1,数据表中的数据类型的优化如选择合适的字段,选择效率快速的字段 2,索引优化 3、SQL语句的优化 (1)优化查询过程中的数据访问如使用limit、使用返回列不用* (2)优化长难句的查询语句变复杂为简单、切分查询、分解关联查询 (3)优化特定类型的查询语句如优化count()、优化关联查询、优化子查询、优化Groupby、优化li'mit 4、存储引擎的优化 (1)尽量使用InnoDB存储引擎,因为它支持事务、外键、使用独立表空间、使用的是行级锁、 5、数据表结构的设计优化 (1)分区操作如通过特定的策略对数据进行物理拆分、对用户透明的、partitionby (2)分库分表如水平拆分(以行级进行拆分)、垂直拆分(列及拆分) 6、数据架构的优化 (1)主从复制 (2)读写分离 (3)双主热备 (4)负载均衡通过LVS的三种模式实现的、Mycat数据库中间件实现的 11、语句include和require的区别是什么? require是无条件包含,也就是如果一个流程里加入require,无论条件成立与否都会先执行require,当文件不存在或者无法打开的时候,会提示错误,并且会终止程序执行 include有返回值,而require没有(可能因为如此require的速度比include快),如果被包含的文件不存在的化,那么会提示一个错误,但是程序会继续执行下去 12、redis和memcacahe、mongoDB的区别? 都是非关系型数据库,性能都非常高,但是mongoDB和memcache、redis是不同的两种类型。后两者主要用于数据的缓存,前者主要用在查询和储存大数据方面,是最接近数据库的文档型的非关系数据库。 从数据存储位置上来分,memcache的数据存在内存中,而redis既可以存储在内存中,也可以存储的到磁盘中,达到持久化存储的功能,memcache一旦断电,数据全部丢失,redis可以利用快照和AOF把数据存到磁盘中,当恢复时又从磁盘中读取到内存中,当物理内存使用完毕后,可以把数据写入到磁盘中。 从存储数据的类型上来分,memcache和redis存储的方式都是键值对,只不过redis值的类型比较丰富,有string(字符串),hash(哈希),list(列表),set(集合)zset(有序集合),而memcache主要存储的是字符串。 13、PHP的基本变量类型 四种标量类型:boolean(布尔型)、integer(整型)、float(浮点型,也称作double)、string(字符串) 两种复合类型:array(数组)、object(对象) 最后是两种特殊类型:resource(资源)、NULL(NULL) 14、静态化如何实现的?伪静态如何实现? 1、静态化指的是页面静态化,也即生成实实在在的静态文件,也即不需要查询数据库就可以直接从文件中获取数据,指的是真静态。实现方式主要有两种: 一种是我们在添加信息入库的时候就生成的静态文件,也称为模板替换技术。 一种是用户在访问我们的页面时先判断是否有对应的缓存文件存在,如果存在就读缓存,不存在就读数据库,同时生成缓存文件。 2、伪静态不是真正意义上的静态化,之所以使用伪静态,主要是为了SEO推广,搜索引擎对动态的文件获取难度大,不利于网站的推广。实习原理是基于Apache或Nginx的rewrite机智主要有两种方式: 一种是直接在配置虚拟机的位置配置伪静态,这个每次修改完成后需要重启web服务器。 另一种采用分布式的,可以在网站的根目录上创建.htaccess的文件,在里面配置相应的重写规则来实现伪静态,这种每次重写时不需要重启web服务器,且结构上比较清晰。 16、如何处理负载,高并发 17、Mysql的读写分离 读写分离的实现原理就是在执行SQL语句的时候,判断到底是读操作还是写操作,把读的操作转向到读服务器上(从服务器,一般是多台),写的操作转到写的服务器上(主服务器,一般是一台,视数据量来看)。 18、说一下单引号双引号? 单引号内部的变量不会执行,双引号会执行 单引号解析速度比双引号快。 单引号只能解析部分特殊字符,双引号可以解析所有特殊字符。 19、PHP7的新特性?重点 NULL合并运算符:由于日常使用中存在大量同时使用三元表达式和isset()的情况,NULL合并运算符使得变量存在且值不为NULL,它就会返回自身的值,否则返回它的第二个操作数。 use加强:从同一namespace导入的类、函数和常量现在可以通过单个use语句一次性导入了 匿名类:现在支持通过newclass来实例化一个匿名类 20、PHP数组排序 sort()-以升序对数组排序 rsort()-以降序对数组排序 asort()-根据值,以升序对关联数组进行排序 ksort()-根据键,以升序对关联数组进行排序 arsort()-根据值,以降序对关联数组进行排序 krsort()-根据键,以降序对关联数组进行排序 21、PHP支持多继承吗? 不支持。PHP中只允许单继承,父类可以被一个子类用关键字“extends”继承。 22、PHP如何实现多继承吗? 可以使用interface或trait实现。 23、优化MYSQL数据库的方法 (1)选择最有效率的表名顺序 (2)WHERE子句中的连接顺序 (3)SELECT子句中避免使用‘*’ (4)用Where子句替换HAVING子句 (5)通过内部函数提高SQL效率 (6)避免在索引列上使用计算。 (7)提高GROUPBY语句的效率,可以通过将不需要的记录在GROUPBY之前过滤掉。 (1).选取最适用的字段属性,应该尽量把字段设置为NOTNULL (2).使用连接(JOIN)来代替子查询(Sub-Queries) (3).使用联合(UNION)来代替手动创建的临时表 (4).尽量少使用LIKE关键字和通配符 (5).使用事务和外键 25、MySQL主从备份的原理? mysql支持单向、异步复制,复制过程中一个服务器充当主服务器,而一个或多个其它服务器充当从服务器。 26、error_reporting()的作用? 设置PHP的报错级别并返回当前级别。 代码实现123 $lifeTime=24*3600;//保存一天 session_set_cookie_params($lifeTime); session_start(); 28、常见的PHP安全性攻击 SQL注入:用户利用在表单字段输入SQL语句的方式来影响正常的SQL执行。防止: 使用mysql_real_escape_string()过滤数据 手动检查每一数据是否为正确的数据类型 使用预处理语句并绑定变量 参数化SQL:是指在设计与数据库链接并访问数据时,在需要填入数值或数据的地方,使用参数(Parameter)来给值,用@或?来表示参数。 XSS攻击:跨站点脚本攻击,由用户输入一些数据到你的网站,其中包括客户端脚本(通常JavaScript)。如果你没有过滤就输出数据到另一个web页面,这个脚本将被执行。防止:为了防止XSS攻击,使用PHP的htmlentities()函数过滤再输出到浏览器。 CSRF:跨站点请求伪造,是指一个页面发出的请求,看起来就像是网站的信任用户,但是是伪造的防止:一般来说,确保用户来自你的表单,并且匹配每一个你发送出去的表单。有两点一定要记住: 对用户会话采用适当的安全措施,例如:给每一个会话更新id和用户使用SSL。 生成另一个一次性的令牌并将其嵌入表单,保存在会话中(一个会话变量),在提交时检查它。如laravel中的_token 代码注入:代码注入是利用计算机漏洞通过处理无效数据造成的。问题出在,当你不小心执行任意代码,通常通过文件包含。写得很糟糕的代码可以允许一个远程文件包含并执行。如许多PHP函数,如require可以包含URL或文件名。防止代码注入 过滤用户输入 在php.ini中设置禁用allow_url_fopen和allow_url_include。这将禁用require/include/fopen的远程文件 -------------------------------------------------------------------------------------------------------- 1、__FILE__表示什么意思? 文件的完整路径和文件名。如果用在包含文件中,则返回包含文件名。自PHP4.0.2起,__FILE__总是包含一个绝对路径,而在此之前的版本有时会包含一个相对路径。 2、如何获取客户端的IP地址? 1$_SERVER[‘REMOTE_ADDR’] 3、写出使用header函数跳转页面的语句 1Header(‘location:index.php’); 4、$str是一段html文本,使用正则表达式去除其中的所有js脚本 $pattern=‘/ Preg_replace($pattern,’’,$str); 5、mvc是什么相互间有什么关系 答:mvc是一种开发模式,主要分为三部分:m(model),也就是模型,负责数据的操作;v(view),也就是视图,负责前后台的显示;c(controller),也就是控制器,负责业务逻辑 客户端请求项目的控制器,如果执行过程中需要用到数据,控制器就会到模型中获取数据,再将获取到的数据通过视图显示出来 6、oop是什么 答:oop是面向对象编程,面向对象编程是一种计算机编程架构,OOP的一条基本原则是计算机程序是由单个能够起到子程序作用的单元或对象组合而成。 2、继承性:就是子类自动继承其父级类中的属性和方法,并可以添加新的属性和方法或者对部分属性和方法进行重写。继承增加了代码的可重用性。PHP只支持单继承,也就是说一个子类只能有一个父类。 3、多态性:子类继承了来自父级类中的属性和方法,并对其中部分方法进行重写。于是多个子类中虽然都具有同一个方法,但是这些子类实例化的对象调用这些相同的方法后却可以获得完全不同的结果,这种技术就是多态性。多态性增强了软件的灵活性。 1、易维护 采用面向对象思想设计的结构,可读性高,由于继承的存在,即使改变需求,那么维护也只是在局部模块,所以维护起来是非常方便和较低成本的。 2、质量高 在设计时,可重用现有的,在以前的项目的领域中已被测试过的类使系统满足业务需求并具有较高的质量。 3、效率高 在软件开发时,根据设计的需要对现实世界的事物进行抽象,产生类。使用这样的方法解决问题,接近于日常生活和自然的思考方式,势必提高软件开发的效率和质量。 4、易扩展 由于继承、封装、多态的特性,自然设计出高内聚、低耦合的系统结构,使得系统更灵活、更容易扩展,而且成本较低。 7、smarty是什么,有什么作用 答:smarty是用php写出来的模板引擎,也是目前业界最著名的php模板引擎之一 它分离了逻辑代码和外在的显示,提供了一种易于管理和使用的方法,用来将混杂的php逻辑代码与html代码进行分离,我们公司使用的是TP框架,已经封装好了smarty模板,所以没有单独使用过。 8.TP的特性有哪些 1.多表查询非常方便,在model中几句代码就可以完成对多表的关联操作 2.融合了smarty模板,使前后台分离 3.支持多种缓存技术,尤其对memcache技术支持非常好 4.命名规范,模型,视图,控制器严格遵循命名规则,通过命名一一对应 5.支持多种url模式 6.内置ajax返回方法,包括xml,json,html等 7.支持应用扩展,类库扩展,驱动扩展等 9.请介绍一下laravel框架 答:laravel框架的设计思想比较先进,非常适合应用各种开发模式,作为一个框架,它为你准备好了一切,composer是php的未来,没有composer,php肯定要走向没落 laravel框架最大的特点和优秀之处就是集合了php比较新的特点,以及各种各样的设计模式,Ioc模式,依赖注入等 10.请简述一下数据库的优化 答:数据库的优化可以从四个方面来优化: 1.从结构层:web服务器采用负载均衡服务器,mysql服务器采用主从复制,读写分离 2.从储存层:采用合适的存储引擎,采用三范式 3.从设计层:采用分区分表,索引,表的字段采用合适的字段属性,适当的采用逆范式,开启mysql缓存 4.sql语句层:结果一样的情况下,采用效率高,速度快节省资源的sql语句执行 11.怎么保证促销商品不会超卖 答:这个问题是我们当时开发时遇到的一个难点,超卖的原因主要是下的订单的数目和我们要促销的商品的数目不一致导致的,每次总是订单的数比我们的促销商品的数目要多,当时我们的小组讨论了好久,给出了好几个方案来实现: 第一种方案:在每次下订单前我们判断促销商品的数量够不够,不够不允许下订单,更改库存量时加上一个条件,只更改商品库存大于0的商品的库存,当时我们使用ab进行压力测试,当并发超过500,访问量超过2000时,还是会出现超卖现象。所以被我们否定了。 第二种方案:使用mysql的事务加排他锁来解决,首先我们选择数据库的存储引擎为innoDB,使用的是排他锁实现的,刚开始的时候我们测试了下共享锁,发现还是会出现超卖的现象。有个问题是,当我们进行高并发测试时,对数据库的性能影响很大,导致数据库的压力很大,最终也被我们否定了。 第三种方案:使用文件锁实现。当用户抢到一件促销商品后先触发文件锁,防止其他用户进入,该用户抢到促销品后再解开文件锁,放其他用户进行操作。这样可以解决超卖的问题,但是会导致文件得I/O开销很大。 最后我们使用了redis的队列来实现。将要促销的商品数量以队列的方式存入redis中,每当用户抢到一件促销商品则从队列中删除一个数据,确保商品不会超卖。这个操作起来很方便,而且效率极高,最终我们采取这种方式来实现 12.商城秒杀的实现 答:抢购、秒杀是如今很常见的一个应用场景,主要需要解决的问题有两个: 1高并发对数据库产生的压力 2竞争状态下如何解决库存的正确减少("超卖"问题) 对于第一个问题,已经很容易想到用缓存来处理抢购,避免直接操作数据库,例如使用Redis。第二个问题,我们可以使用redis队列来完成,把要秒杀的商品放入到队列中,因为pop操作是原子的,即使有很多用户同时到达,也是依次执行,文件锁和事务在高并发下性能下降很快,当然还要考虑其他方面的东西,比如抢购页面做成静态的,通过ajax调用接口,其中也可能会出现一个用户抢多次的情况,这时候需要再加上一个排队队列和抢购结果队列及库存队列。高并发情况下,将用户进入排队队列,用一个线程循环处理从排队队列取出一个用户,判断用户是否已在抢购结果队列,如果在,则已抢购,否则未抢购,库存减1,写数据库,将用户入结果队列。 22.购物车的原理 答:购物车相当于现实中超市的购物车,不同的是一个是实体车,一个是虚拟车而已。用户可以在购物网站的不同页面之间跳转,以选购自己喜爱的商品,点击购买时,该商品就自动保存到你的购物车中,重复选购后,最后将选中的所有商品放在购物车中统一到付款台结账,这也是尽量让客户体验到现实生活中购物的感觉。服务器通过追踪每个用户的行动,以保证在结账时每件商品都物有其主。 主要涉及以下几点: 1、把商品添加到购物车,即订购 2、删除购物车中已定购的商品 3、修改购物车中某一本图书的订购数量 4、清空购物车 5、显示购物车中商品清单及数量、价格 实现购物车的关键在于服务器识别每一个用户并维持与他们的联系。但是HTTP协议是一种“无状态(Stateless)”的协议,因而服务器不能记住是谁在购买商品,当把商品加入购物车时,服务器也不知道购物车里原先有些什么,使得用户在不同页面间跳转时购物车无法“随身携带”,这都给购物车的实现造成了一定的困难。 目前购物车的实现主要是通过cookie、session或结合数据库的方式。下面分析一下它们的机制及作用 $data=['a','b','c'];foreach($dataas$k=>$v){$v=&$data[$k];}print_r($data);
";if(filetype($dir.'/'.$file)=='dir'){loopDir($dir.'/'.$file);}}}}loopDir($dir);10请简单叙述CGIfastCGIh和PHP-FPM的区别CGI代表为了联系PHP和websevae的一个桥梁fastCGI是CGI的改良版PHP-FPM进程管理器