php 基础知识点(1)

2018-03-28  本文已影响0人  青青玉立

1. setcookie("a","value");print $_COOKIE['a']; 语句输出的结果是什么

        Notice: Undefined index: a in

2. 字符串”\r”,”\n”,”\t”,”\x20”分别代表什么

“\r”代表的含义是:

在Linux、unix 中表示返回到当行的最开始位置,

在Mac OS 中表示换行且返回到下一行的最开始位置,相当于Windows 里的 \n 的效果

“\n”代表的含义是:

在Windows 中表示换行且回到下一行的最开始位置。相当于Mac OS 里的 \r 的效果

在Linux、unix 中只表示换行,但不会回到下一行的开始位置。

“\t”所代表的含义是:

键盘上的“TAB”键,跳格(移至下一列)

“\x20”所代表的含义是:是32在ASCII表中16进制的表示

3. 以下语句输出的结果是什么

$a = 3;

echo "$a",'$a',"\\\$a","${a}","$a"."$a","$a"+"$a";

得到的结果是: 3$a\$a3336

注意:(用花括号界定变量名,适用于PHP所有版本)

$a = 'flower';

echo "She received some $as"; // 无效 $as变量

echo "She received some ${a}s"; // 有效

echo "She received some {$a}s"; // 有效;推荐的使用方法

4 php中将当前页面重定向到另一个页面怎么写?

header();

5 什么是魔术引号(magic_quotes_gpc)?

魔术引号(Magic Quotes)是一个自动将进入 PHP 脚本的数据进行转义的过程。提示:最好在编码时不要转义而在运行时根据需要而转义

类似addslashes() 对输入的字符创中的字符进行转义处理

6 在类的方法中,如何调用其父类的同名方法?

    parent::方法名

7 php中如何取得get,post参数,和上传的文件

$_GET,$_POST,$_FILES

8 如何取得客户端的ip(要求取得一个int)

    ip2long($_SERVER['REMOTE_ADDR']);

    *:$_SERVER['REMOTE_ADDR'] 获取字符串ip

      ip2long 将 IPV4 的字符串互联网协议转换成长整型数字

9 include和require的区别

require:出现错误后直接终止退出,程序不再执行

include:包含一个不存在的文件,会提示警告程序会继续执行

10 extends的作用是什么

类的继承

11 @test()和&test()的区别

@test()的作用是屏蔽test()方法中警告的作用

&test()引用test()方法

12 array+array与array_merge()的区别

二者之间的区别是:

1 键名为数字时,array_merge()不会覆盖掉原来的值,但+合并数组则会把最先出现的值作为最终结果返回,而把后面的数组拥有相同键名的那些值“抛弃”掉(不是覆盖)

2 键名为字符时,+仍然把最先出现的值作为最终结果返回,而把后面的数组拥有相同键名的那些值“抛弃”掉,

但array_merge()此时会覆盖掉前面相同键名的值

13 请列举最少3个php对象的魔术方法和说明它们的用途

构造方法: __construct()

析构方法__destruct()

__get() 控制私有的受保护的未定义的成员属性的访问

__set() 对私有的受保护的未定义的成员属性进行赋值控制

__isset() 对私有的受保护的未定义成员属性进行isset和empty的判断控制

14 什么是fpm?

FastCGI Process Manager:FastCGI进程管理器

15 描述一下php开发中常见的几种攻击以及解决方案

SQL注入:

解决这个问题的办法是,将 PHP 的内置 mysql_real_escape_string() 函数用作任何用户输入的包装器。这个函数对字符串中的字符进行转义,使字符串不可能传递撇号等特殊字符并让 MySQL 根据特殊字符进行操作。

跨站点脚本攻击(XSS):

strip_tags() 函数,这个函数可以清除任何包围在 HTML 标记中的内容

或者使用htmlspecialchars() 函数、htmlentities()函数输出HTML实体

echo intval(0.58*100) 输出的结果是57,试分析这是为什么?

原因就是浮点数精度的问题。

简单的十进制分数如同 0.1 或 0.7 不能在不丢失一点点精度的情况下转换为内部二进制的格式。这就会造成混乱的结果:例如,floor((0.1+0.7)*10) 通常会返回 7 而不是预期中的 8,因为该结果内部的表示其实是类似 7.9999999999…。这和一个事实有关,那就是不可能精确的用有限位数表达某些十进制分数。例如,十进制的 1/3 变成了 0.3333333…。所以永远不要相信浮点数结果精确到了最后一位,也永远不要比较两个浮点数是否相等。如果确实需要更高的精度,应该使用任意精度数学函数或者 gmp 函数

写出mysql中,插入数据,读出数据,更新数据的语句

INSERT INTO 表名 VALUES (””,””);

SELECT * FROM 表名;。

UPDATE 表名 SET 字段名1=’a’,字段名2=’b’ WHERE 字段名3=’c’;

写入数据时,聚簇索引所在的列的内容是随机的,会引起什么性能问题?

聚簇索引情况下,写入数据时,插入速度严重依赖插入顺序,按照主键的顺序插入是加载数据到InnoDB表中速度最快的方式。但如果不是按照主键顺序加载数据,那么在加载完成后最好使用OPTIMIZE TABLE命令重新组织一下表。

基于聚簇索引的表在插入新行,或者主键被更新导致需要移动行的时候,可能面临“页分裂”的问题。当行的主键值要求必须将这一行插入到某个已满的页中时,存储引擎会将该页分裂成两个页面来容纳该行,这就是一次分裂操作。页分裂会导致表占用更多的磁盘空间。

聚簇索引可能导致全表扫描变慢,尤其是行比较稀疏,或者由于页分裂导致数据存储不连续的时候

如何查看当前linux服务器的磁盘io状态?

iostat -x -k

top //cpu项

vmstat

如何查看linux服务器的cpu负载

top(top程序提供了一个动态的、实时的、直观的运行中的系统。它能显示系统的主要信息,并且把由内核管理的任务列表显示出来。top命令监控CPU利用率,进程状态和内存利用率。顶部区域包含了整个系统状态的信息,从左到右,从上到下,依次是:当前时间,正常运行时间,负载均衡,进程总数和概况,CPU状态,内存占用情况,swap占用情况。)

如何查看一个进程当前打开的文件?

查看所有进程的文件打开数

lsof |wc -l

查看某个进程打开的文件数

lsof -p pid |wc -l

什么是管道命令?

这个管道命令“|”仅能处理经由前面一个命令传来的正确信息,也就是standard output的信息,对于stdandard error并没有直接处理能力。在每个管道后面接的第一个数据必定是“命令”,而且这个命令必须要能够接受standard input的数据才行,这样的命令才可以是“管道命令”,例如Less、more、head、tail等都是可以接收standard input的管道命令

safe_mode 为了解决共享服务器安全问题而设置,PHP5.3将不再有安全模式

调用gc_enable() 和 gc_disable()函数来打开和关闭垃圾回收机制

error_reporting — 设置应该报告何种 PHP 错误

variables_order 设置描述PHP解析变量顺序  默认设定为EGPCS(Environment,GET,POST,Cookie,Server)

serialize 序列化 反序列化

 所有php里面的值都可以使用函数serialize()来返回一个包含字节流的字符串来表示。unserialize()函数能够重新把字符串变回php原来的值。 序列化一个对象将会保存对象的所有变量,但是不会保存对象的方法,只会保存类的名字

 类名可以是任何非 PHP 保留字的合法标签。一个合法类名以字母或下划线开头,后面跟着若干字母,数字或下划线

表达式 1 == [['1']] 的结果是 false

header 参数解释

 If-Modified-Since  作用: 把浏览器端缓存页面的最后修改时间发送到服务器去,服务器会把这个时间与服务器上实际文件的最后修改时间进行对比。如果时间一致,那么返回304,客户端就直接使用本地缓存文件。如果时间不一致,就会返回200和新的文件内容。客户端接到之后,会丢弃旧文件,把新文件缓存起来,并显示在浏览器中

If-None-Match 作用: If-None-Match和ETag一起工作,工作原理是在HTTP Response中添加ETag信息。 当用户再次请求该资源时,将在HTTP Request 中加入If-None-Match信息(ETag的值)。如果服务器验证资源的ETag没有改变(该资源没有更新),将返回一个304状态告诉客户端使用本地缓存文件。否则将返回200状态和新的资源和Etag.  使用这样的机制将提高网站的性能

Accept  作用: 浏览器端可以接受的媒体类型

 Connection: keep-alive  当一个网页打开完成后,客户端和服务器之间用于传输HTTP数据的TCP连接不会关闭,如果客户端再次访问这个服务器上的网页,会继续使用这一条已经建立的连接

  例如:  Connection: close  代表一个Request完成后,客户端和服务器之间用于传输HTTP数据的TCP连接会关闭, 当客户端再次发送Request,需要重新建立TCP连接

GBK编码下一个字符占2个字节,一个utf8数字占1个字节 一个utf8英文字母占1个字节

 pack函数创建的二进制文件

上一篇 下一篇

猜你喜欢

热点阅读