php基础面试题

–转载自https://www.cnblogs.com/zypphp/p/8185150.html–飞翔的超级大鸟
1. 变量如何定义?如何检查变量是否定义?如何删除一个变量?判断一个变量是否为空的函数?
isset()
unset()
empty()

  1. 什么是可变变量?
    一个变量的变量名可以动态的设置和使用。
    a=hello, a = ′ h e l l o ′ , a=world, a = ′ w o r l d ′ , {$a}=hello world

  2. 变量赋值方式有哪几种?
    1)直接赋值
    2)变量间赋值
    3)引用赋值

  3. 引用和拷贝有什么区别?
    拷贝是将原来的变量内容复制下来,拷贝后的变量与原来的变量使用各自的内存,互不干扰。
    引用相当于是变量的别名,其实就是用不同的名字访问同一个变量内容。当改变其中一个变量的值时,另一个也跟着发生变化。

  4. php中变量有哪些基本数据类型?
    php支持8种原始数据类型。
    包括:
    四种标量类型(布尔型boolean,整型interger,浮点型float/double , 字符串string)
    两种复合类型(数组array , 对象object)
    两种特殊类型(资源resource,NULL)

  5. 其它类型转换为boolean类型时,哪些被认为是false?
    布尔值false,整型值0, 浮点型值0.0, 空白字符串, 字符串’0’, 空数组,特殊数据类型NULL, 没有设定的变量。

empty()函数在哪些情况下返回true?
布尔值false,
整型值0,
浮点型值0.0,
空白字符串,
字符串’0’,
array()空数组,
特殊数据类型NULL,
没有任何属性的对象,
没有赋值的变量。

  1. 如果定义了一个变量 a, a , 但 是 没 有 赋 初 始 值 那 么 a==0吗?
    a==false a == f a l s e 吗 ? a==”吗?
    a==NULL a == N U L L 吗 ? a===NULL吗? 答:echo=>什么都没有 , var_dump=>NULL
    empty( b)==trueecho=>1,vardump=>bool(true) b ) == t r u e 吗 ? — — — — — — — — — — — — e c h o => 1 , v a r d u m p => b o o l ( t r u e ) 此 时 如 果 输 出 a++是多少?——————— echo=>什么都没有 , var_dump=>NULL
    如果输出++$a又是多少?————————— echo=>1 , var_dump=>int(1)

  2. 字符串怎么转成整数,有几种方法?怎么实现?
    强制类型转换: (整型)字符串变量名;
    直接转换:settype(字符串变量,整型);
    intval(字符串变量);

  3. 标量数据和数组的最大区别是什么?
    一个标量只能存放一个数据,而数组可以存放多个数据。

  4. 常量如何定义? 如何检测一个常量是否被定义?常量的值只能是哪些数据类型?
    define()//定义常量 , defined()//检查常量是否定义
    常量的值只能是标量类型的数据。

  5. 常量分为系统内置常量和自定义常量。请说出最常见的几个系统内置常量?
    FILE , LINE , PHP_OS , PHP_VERSION

  6. 如果定义了两个相同的常量,前者和后者哪个起作用?
    前者起作用,因为常量一旦定义就不能被重新定义或者取消定义。

  7. 常量和变量有哪些区别?
    1)常量前没有$符号;
    2)常量只能通过define()定义,而不能通过赋值语句定义;
    3)常量可以在任何地方定义和访问,而变量有全局和局部之分;
    4)常量一旦定义就不能被重新定义或者取消定义,而变量而通过赋值方式重新定义;
    5)常量的值只能是标量数据,而变量的数据库类型有8种原始数据类型。

  8. PHP中常用的几个预定义的全局数组变量是哪些?
    有9大预定义的内置数组变量:
    POST, P O S T , _GET, REQUEST, R E Q U E S T , _SESSION, COOKIE, C O O K I E , _FILES, SERVER, S E R V E R , _ENV, $GLOBALS

  9. 在实际开发中,常量最常用于哪些地方?
    1)连接数据库的信息定义成常量,如数据库服务器的用户名、密码、数据库名、主机名;
    2)将站点的部分路径定义成常量,如web绝对路径,smarty的安装路径,model、view或者controller的文件夹路径;
    3)网站的公共信息,如网站名称,网站关键词等信息。

  10. 函数的优越性有哪些?
    提高程序的可维护性
    提高软件的可靠性
    提高程序的可重用性
    提高程序的开发效率

  11. 如何定义一个函数?函数名区分大小写吗?
    1)使用 function 关键字;
    2)函数命名规则和变量一样,以字母或者下划线开头,而不能以数字开头;
    3)函数名不区分大小写;
    4)函数名不可以使用已经声明过的或者系统自建的函数名称。

  12. 什么是变量的能见度 或者 说是变量作用域?
    就是变量在程序中的可作用范围。根据变量的能见度,变量分为局部变量和全局变量。

  13. 什么是局部变量和全局变量?函数内是否可以直接调用全局变量?
    局部变量是函数内部定义的变量,其作用域是所在的函数。如果函数外还有一个跟局部变量名字一样的变量,
    程序会认为它们两个是完全不同的两个变量。当退出函数的时候,其中的局部变量就同时被清除。

全局变量是定义在所有函数以外的变量,其作用域是整个php文件,但是在用户自定义的函数内部是无法使用的。
如果一定要在用户自定义的函数内部使用全局变量,那么就需要使用global关键字声明。
也就是说如果在函数内的变量前加上golbal来修饰,那么函数内部就可以访问到这个全局变量,
不仅可以利用这个全局变量进行运算而且可以对这个全局变量进行重新赋值。
全局变量还可以使用 $GLOBALS[‘var’] 来调用。

  1. global关键词如何使用?预定义的全局变量数组$GLOBALS如何使用?

  2. 什么是静态变量?
    如果一个函数内定义的变量前使用关键字static来声明,那么该变量就是静态变量。
    一般函数内的变量在函数调用结束后,其存储的数据将被清除,所占的内存空间也被释放。而使用静态变量时,
    该变量会在函数第一次被调用时被初始化,初始化后该变量也不会被清除,当再次调用该函数时,这个静态变量
    不再被初始化,而能保存上次函数执行完后的值。可以说静态变量在所有对该函数的调用之间共享。

  3. php中函数传递参数的方式有哪些?两者有什么区别?
    按值传递和按地址传递(或按引用传递)
    (1)按值传递: 待传递的变量,与传递给函数之后的变量是存储在不同的空间中。所以函数体内对
    该变量值做的修改,不影响原本的变量值。
    (2)按地址传递: 使用 & 符号,表明该参数是以地址的方式传递值。并不会将主程序中的指定数值或目标变量传递给函数,
    而是把该数值或变量的内存储存区块地址导入函数之中,所以函数体内的该变量和主程序中的该变量在内存
    中是同一个。函数体做的修改,直接影响到函数体外部的该变量的值。

  4. 什么是递归函数?如何进行递归调用?
    递归函数其实就是调用自身的函数,但是必须满足以下两个条件:
    1)在每一次调用自身时,必须是更接近于最终结果;
    2)必须有一个确定的递归终止条件,不会造成死循环。
    举例说明:
    在实际工作中往往会在遍历文件夹的时候使用。
    如果有个例子是希望获取到目录windows下所有的文件,那么先遍历windows目录,如果发现其中还有文件夹,那么就会调用自身,继续往下寻找,依次类推,
    直到遍历到再也没有文件夹为止,这也就是意味着遍历出来了所有的文件。

  5. 判断一个函数是否存在?
    function_exists( string $function_name ) 如果存在,返回true, 不存在则返回 false。

  6. func()和@func()之间有什么区别?
    第二个函数调用失败不会报错,第一个会报错

  7. include()和require()函数的用法和区别是什么?include_once()和require_once()呢?
    include和require出现错误后的错误级别不一样
    include_once()和require_once()在加载之前要判断是否已经导入

  8. 说出前置++和后置++的区别?
    前置++是先将变量增加1,然后在将值赋值给原来的变量;
    后置++是先返回变量的当前值,然后再将变量的当前值增加1.

  9. 字符串运算符“.”与算术运算符“+”有什么区别?
    当“a”“b”之间使用.时认为是连字符。如果两者间是+的时候php会认为是一次运算。
    1)如果+号两边的字符串是数字组成的,那么会将字符串自动转为整型;
    2)如果+号两边是纯粹的字母,那么会输出0;
    3)如果+号两边的字符串是以数字开头的,那么会截取字符串开头的数字,然后进行运算。

  10. 什么是三目(或三元)运算符?
    根据一个表达式的结果在另两个表达式中选择一个。
    例如: ($a==true) ? ‘good’:’bad’;

  11. 控制流程语句有哪些?
    1:三种程序结构 顺序结构、分支结构、循环结构
    2:分支: if/esle/esleif/ switch/case/default
    3: switch 需要注意的:
    case子句中的常量可以是整型、字符串型常量、 或者常量表达式,不允许是变量。
    同一个switch子句中,case的值不能相同,否则只能取到首次出现case中的值。
    4: 循环 for while do…while
    do…while 后面必须加入分号结尾。
    while 和 do…while 的区别
    5:break 和 continue 的区别。
    break可以终止循环。
    continue没有break强大,只能终止本次循环而进入到下一次循环中。

  12. 数组的概念是什么?数组根据索引分为哪两种,如何区分?数组的赋值方式有哪两种?
    数组是一个可以存储一组或一系列数值的变量(复合型变量)
    索引数组(索引值为数字,以0开始)和关联数组(以字符串作为索引值)

数组的赋值方式有哪两种?
数组的声明方式主要有两种。
1.通过array()函数声明数组;
可以通过key=>value的方式分别定义索引和值,也可以不定义数组的索引下标,只给出数组的元素值。
2.直接为数组元素赋值,不需要调用array()函数。例如:
arr[0]=1; a r r [ 0 ] = 1 ; arr[1] = 2;
特别注意:
数组的下标如果是等价于整数的字符串值(但不能以0开头),则会被当作整数对待。
例如: array[3] a r r a y [ 3 ] 与 array[‘3’] 引用的是相同的一个元素,而 $array[‘03’] 引用的则就是另外的一个元素了。

32.数组如何遍历?
①for循环
②foreach循环 ,这是最常用的遍历方式。用法如下:foreach( arras a r r a s key=>$value){}
③list each 和while 配合起来循环

  1. foeach数组的时候指针是如何指向的?list()/each()/while()循环数组的时候指针如何指向的呢?
    当foreach开始执行的时候,数组内部的指针会自动指向第一个单元。因为foreach所操作的是指定数组的拷贝,而不是该数组本身。
    而each()一个数组后,数组指针将停留在数组中的下一个单元或者碰到数组结尾时停留在最后一个单元。如果要再次使用each()遍历数组,必须要使用reset().
    reset()将数组的内部指针倒回到第一个单元并返回第一个数组单元的值。

  2. 如何计算数组长度(或者说计算数组中所有元素的个数)?字符串怎么取长度?
    count() – 计算数组中的元素个数。
    可以使用count(数组名)或者count(数组名,1),如果有第二个参数,并且是数字1,则表示递归统计数组元素的个数。
    如果第二个参数是数字0,则等同于只有一个参数的count()函数。
    sizeof() – count() 的别名
    字符串:strlen()、mb_strlen();

  3. 数组中相关的常用函数有哪些?
    1) count –(sizeof别名)— 计算数组中的单元数目或对象中的属性个数
    例如:int count ( mixed var[,int v a r [ , i n t mode ] ) var v a r 通 常 都 是 数 组 类 型 , 任 何 其 它 类 型 都 只 有 一 个 单 元 。 mode 默认值为0. 1为开启递归地对数组计数
    2) in_array ( mixed needle,array n e e d l e , a r r a y haystack [, bool strict])needlestrictTRUEinarray()needlehaystack3arraymerge(array s t r i c t ] ) — 检 查 数 组 中 是 否 存 在 某 个 值 。 如 果 n e e d l e 是 字 符 串 , 则 比 较 是 区 分 大 小 写 的 。 如 果 第 三 个 参 数 s t r i c t 的 值 为 T R U E 则 i n a r r a y ( ) 函 数 还 会 检 查 n e e d l e 的 类 型 是 否 和 h a y s t a c k 中 的 相 同 。 3 ) a r r a y m e r g e ( a r r a y array1 [, array array2[,array a r r a y 2 [ , a r r a y … ]] ) 将一个或多个数组的单元合并起来,一个数组中的值附加在前一个数组的后面。返回作为结果的数组。
    特别注意:如果输入的数组中有相同的字符串键名,则该键名后面的值将覆盖前一个值。然而,如果数组包含数字键名,后面的值将不会覆盖原来的值,而是附加到后面。
    如果只给了一个数组并且该数组是数字索引的,则键名会以连续方式重新索引

4) 数组与字符串之间的转换
(1)explode ( string separator,string s e p a r a t o r , s t r i n g string [, int limit])使(2)implode(string l i m i t ] ) 使 用 一 个 分 隔 字 符 来 分 隔 一 个 字 符 串 。 ( 2 ) i m p l o d e ( s t r i n g glue , array $arr ) 使用一个连接符将数组中的每个单元连接为一个字符串。
join 为 implode 的别名

5) sort(array & array[,int a r r a y [ , i n t sort_flags ]) — 对数组按照值排序,当本函数结束时数组单元将被从最低到最高重新安排。

  1. 数组合并函数array_merge()和数组加法运算 arr+ a r r + arr2 的区别是什么?
    array_merge()->使用array_merge(),如果是关联数组合并,如果数组的键名相同,那么后面的值将覆盖前者;如果是数字索引数组合并,则不覆盖,而是
    后者附加到前者后面。
    “+”->使用数组加法运算,与array_merge()不同,加法运算不管是关联数组还是数字索引数组,都是将相同键名的的值舍弃,
    也就是只保留首次出现该键名的元素,后来的具有相同键名的元素都不会被加进来。

  2. 字符串定义的时候单引号和双引号有什么区别?

  3. echo(),print(),print_r()的区别?
    (1)echo 是语法,Output one or more strings,没有返回值;
    (2)print 是函数,不能输出数组和对象,Output a string,print有返回值;
    (3)print_r 是函数,可以输出数组。print_r是个比较有意思的函数,可以输出stirng、int、float、
    array、object等,输出array时会用结构表示,print_r输出成功时返回true;而且print_r可以通过print_r($str,true)来,使print_r不输出而返回print_r处理后的值。此外,对于echo和print,基本以使用echo居多,因为其效率比print要高。

  4. 按照功能分类说说都有哪些字符串处理函数?这些函数的作用是什么?
    A. 字符串输出函数
    (1)echo a, a , b, c;(2)print( c … … ; 是 一 个 语 言 结 构 , 而 不 是 一 个 真 正 的 函 数 。 ( 2 ) p r i n t ( a) 本函数输出字符串。若成功则返回 1,失败返回 0
    (3)print_r( a)(4)vardump( a ) ( 4 ) v a r d u m p ( a); 能输出类型、长度、值
    B. 去除字符串首尾空格的函数: trim ltrim rtrim(别名:chop) 使用第二个参数,还可以去除指定的字符。
    C. 转义字符串函数:addslashes()
    D. 获取字符串长度的函数:strlen()
    E. 截取字符串长度的的函数:substr()
    F. 检索字符串函数: strstr() , strpos()
    G. 替换字符串函数:str_replace()

  5. 请给出以下问题的正确答案?
    1). arr=array(james,tom,symfony); a r r = a r r a y ( ′ j a m e s ′ , ′ t o m ′ , ′ s y m f o n y ′ ) ; 请 将 arr数组的值用’,’分割并合并成字符串输出?
    echo implode(‘,’,$arr);

2). str=jack,james,tom,symfony; s t r = ‘ j a c k , j a m e s , t o m , s y m f o n y ′ ; 请 将 str用’,’分割,并把分割后的值放到 arr a r r 数 组 中 ? arr = explode(‘,’,$str);

3). arr=array(3,7,2,1,d,abc); a r r = a r r a y ( 3 , 7 , 2 , 1 , ′ d ′ , ′ a b c ′ ) ; 请 将 arr按照从大到小的顺序排序,并保持其键值不变?
arsort( arr);printr( a r r ) ; p r i n t r ( arr);

4). mail=gaofei@163.com;(163.com)echostrstr( m a i l = “ g a o f e i @ 163. c o m ” ; 请 将 此 邮 箱 的 域 ( 163. c o m ) 取 出 来 并 打 印 , 看 最 多 能 写 出 几 种 方 法 ? e c h o s t r s t r ( mail,’163’);
echo substr( mail,7); m a i l , 7 ) ; arr = explode("@", mail);echo m a i l ) ; e c h o arr[1];

5). 如果有一个字符串,该字符串是“123,234,345,”。请问如何切割掉这个字符串最后一个逗号?

6). 获取随机数的函数有哪几个?mt_rand() 和 rand()哪个执行速度快?

41.页面字符出现乱码,怎么解决?
1.首先考虑当前文件是不是设置了字符集。查看是不是meta标签中写了charset,如果是php页面还可以看看是不是
在header()函数中指定了charset;
例如:

header(“content-type:text/html;charset=utf-8”);

2.如果设置了字符集(也就是charset),那么判断当前文件保存的编码格式是否跟页面设置的字符集保持一致,
两者必须保持统一;

3.如果涉及到从数据库提取数据,那么判断数据库查询时的字符集是否跟当前页面设置的字符集一致,两者必须统一,
例如:mysql_query(“set names utf8”)。

  1. 正则表达式是什么?php中有哪些常用的跟正则相关的函数?请写出一个email的正则,中国手机号码和座机号码的正则表达式?
    正则表达式是用于描述字符排列模式的一种语法规则。正则表达式也叫做模式表达式。
    网站开发中正则表达式最常用于表单提交信息前的客户端验证。
    比如验证用户名是否输入正确,密码输入是否符合要求,email、手机号码等信息的输入是否合法。
    在php中正则表达式主要用于字符串的分割、匹配、查找和替换操作。

preg系列函数可以处理。具体有以下几个:

string preg_quote ( string str [, string delimiter] )
转义正则表达式字符 正则表达式的特殊字符包括:. \ + * ? [ ^ ] $ ( ) { } = ! < > | :。
preg_replace – 执行正则表达式的搜索和替换
mixed preg_replace ( mixed pattern, mixed replacement, mixed subject [, int limit] )
preg_replace_callback – 用回调函数执行正则表达式的搜索和替换
mixed preg_replace_callback ( mixed pattern, callback callback, mixed subject [, int limit] )
preg_split – 用正则表达式分割字符串
array preg_split ( string pattern, string subject [, int limit [, int flags]] )

  1. 如果想过滤掉某个字符串中所有的html标记使用哪个函数?

  2. preg_replace()和 str_ireplace()两个函数在使用上有什么不同?preg_split()和split()函数如何使用?

  3. 获取当前时间戳的函数主要有哪些?用PHP打印出今天的时间,格式是2010-12-10 22:21:21?
    用PHP打印出前一天的时间格式是2010-12-10 22:21:21?如何把2010-12-25 10:30:25变成unix时间戳?

echo date (“Y-m-d H:i:s” ,strtotime(‘-1,days’));

date(‘Y-m-d H:i:s’,time());

unixtime=strtotime(20099210:30:25);//unixechodate(YmdH:i:s, u n i x t i m e = s t r t o t i m e ( “ 2009 − 9 − 2 10 : 30 : 25 ” ) ; / / 变 成 u n i x 时 间 戳 e c h o d a t e ( “ Y − m − d H : i : s ” , unix_time);//格式化为正常时间格式

  1. 在url中用get传值的时候,若中文出现乱码,应该用哪个函数对中文进行编码?
    用户在网站表单提交数据的时候,为了防止脚本攻击(比如用户输入),php端接收数据的时候,应该如何处理?
    使用urlencode()对中文进行编码,使用urldecode()来解码。
    使用htmlspecialchars($_POST[‘title’])来过滤表单传参就可以避免脚本攻击。

  2. 连接数据库操作的步骤是什么?每一步的返回值是什么数据类型?尤其是mysql_query()返回什么数据类型?

  3. 说说mysql_fetch_row() 和mysql_fetch_assoc()和mysql_fetch_array之间有什么区别?
    第一个是返回结果集中的一行作为索引数组,第二个是返回关联数组,而第三个既可以返回索引数组也可以返回关联数组,取决于它的第二个参数 MYSQL_BOTH MYSQL_NUM MYSQL_ASSOC 默认为MYSQL_BOTH
    sql=selectfromtable1; s q l = ” s e l e c t ∗ f r o m t a b l e 1 ” ; result = mysql_query( sql);mysqlfetcharray( s q l ) ; m y s q l f e t c h a r r a y ( result, MYSQL_NUM);

  4. 请说出目前学过的返回是资源的函数?
    答: mysql_connect();
    mysql_query();只有这执行select的时候成功,才返回资源,失败返回FALSE
    fopen();

  5. 打开、关闭文件分别是什么函数? 文件读写是什么函数?删除文件是哪个函数?
    判断一个文件是否存在是哪个函数?新建目录是哪个函数?

  6. 文件上传需要注意哪些细节?怎么把文件保存到指定目录?怎么避免上传文件重名问题?
    1.首现要在php.ini中开启文件上传;
    2.在php.ini中有一个允许上传的最大值,默认是2MB。必要的时候可以更改;
    3.上传表单一定要记住在form标签中写上enctype=”multipart/form-data”;

  7. 提交方式 method 必须是 post;
  8. 设定 type=”file” 的表单控件;
    6.要注意上传文件的大小MAX_FILE_SIZE、文件类型是否符合要求,上传后存放的路径是否存在。

可以通过上传的文件名获取到文件后缀,然后使用时间戳+文件后缀的方式为文件重新命名,这样就避免了重名。
可以自己设置上传文件的保存目录,与文件名拼凑形成一个文件路径,使用move_uploaded_file(),就可以完成
将文件保存到指定目录。

  1. $_FILES是几维数组?第一维和第二维的索引下标分别是什么?批量上传文件的时候需要注意什么?
    二维数组。第一维是上传控件的name,二维下标分别为name/type/tmp_name/size/error.

  2. header()函数主要的功能有哪些?使用过程中注意什么?
    答:

  3. 文件下载的时候如果使用header()函数?
    答:header(“content-type: application/octet-stream;charset=UTF-8”); //在这里加utf-8和在上面定义有什么区别?、??
    header(“accept-ranges: bytes”);
    header(“accept-length: “.filesize( filedir. f i l e d i r . filename));
    header(“content-disposition: attachment; filename=”. filedir. f i l e d i r . filename);

  4. 什么是ajax?ajax的原理是什么?ajax的核心技术是什么?ajax的优缺点是什么?
    ajax是asynchronous javascript and xml的缩写,是javascript、xml、css、DOM等多个技术的组合。’$’是jQuery的别名.

页面中用户的请求通过ajax引擎异步地与服务器进行通信,服务器将请求的结果返回给这个ajax引擎,
最后由这个ajax引擎来决定将返回的数据显示到页面中的指定位置。Ajax最终实现了在一个页面的指定位置可以加载另一个页面所有的输出内容。
这样就实现了一个静态页面也能获取到数据库中的返回数据信息了。所以ajax技术实现了一个静态网页在不刷新整个页面的情况下与服务器通信,
减少了用户等待时间,同时也从而降低了网络流量,增强了客户体验的友好程度。

Ajax的优点是:
1. 减轻了服务器端负担,将一部分以前由服务器负担的工作转移到客户端执行,利用客户端闲置的资源进行处理;
2. 在只局部刷新的情况下更新页面,增加了页面反应速度,使用户体验更友好。
Ajax的缺点是不利于seo推广优化,因为搜索引擎无法直接访问到ajax请求的内容。
ajax的核心技术是XMLHttpRequest,它是javascript中的一个对象。

  1. jquery是什么?jquery简化ajax后的方法有哪些?
    jQuery是Javascript的一种框架。
    .get(), . g e t ( ) , .post(), .ajax() . a j a x ( ) 。 是jQuery对象的别名。

代码如下:
.post(异步访问的url地址 , {‘参数名’ : 参数值} , function(msg){ .post(异步访问的url地址 , {‘参数名’ : 参数值} , function(msg){ (“#result”).html(msg);
});

.get(异步访问的url地址 , {‘参数名’ : 参数值} , function(msg){ .get(异步访问的url地址 , {‘参数名’ : 参数值} , function(msg){ (“#result”).html(msg);
});

.ajax({  
type: “post”,  
url: loadUrl,  
cache:false,  
data: “参数名=” + 参数值,  
success: function(msg) {
.ajax({  type: “post”,  url: loadUrl,  cache:false,  data: “参数名=” + 参数值,  success: function(msg) {
(“#result”).html(msg);
}
});

  1. 什么是会话控制?
    简单地说会话控制就是跟踪和识别用户信息的机制。会话控制的思想就是能够在网站中跟踪一个变量,通过这个变量,
    系统能识别出相应的用户信息,根据这个用户信息可以得知用户权限,从而展示给用户适合于其相应权限的页面内容。
    目前最主要的会话跟踪方式有cookie,session。

  2. 会话跟踪的基本步骤
    1).访问与当前请求相关的会话对象
    2).查找与会话相关的信息
    3).存储会话信息
    4).废弃会话数据

  3. 使用cookie的注意事项有哪些?
    1) setcookie()之前不可以有任何页面输出,就是空格,空白行也不可以;
    2) setcookie()后,在当前页面调用$_COOKIE[‘cookiename’]不会有输出,必须刷新或到下一个页面才可以看到cookie值;
    3) 不同的浏览器对cookie处理不同,客户端可以禁用cookie,浏览器也可以闲置cookie的数量,一个浏览器能创建的cookie数量最多300个,并且每个不可以超过4kb,
    每个web站点能设置的cookie总数不能超过20个。
    4) cookie是保存在客户端的,用户禁用了cookie,那么setcookie就不会起作用了。所以不可以过度依赖cookie。

  4. 使用session的时候,通过什么来表示当前用户,从而与其他用户进行区分?
    sessionid,通过session_id()函数可以取得当前的session_id。

  5. session和cookie的使用步骤分别是什么?什么是sesssion和cookie的生命周期?session和cookie的区别是什么?
    cookie是保存在客户端机器的,对于未设置过期时间的cookie,cookie值会保存在机器的内存中,只要关闭浏览器则
    cookie自动消失。如果设置了cookie的过期时间,那么浏览器会把cookie以文本文件的形式保存到硬盘中,
    当再次打开浏览器时cookie值依然有效。

session是把用户需要存储的信息保存在服务器端。每个用户的session信息就像是键值对一样存储在服务器端,
其中的键就是sessionid,而值就是用户需要存储信息。服务器就是通过sessionid来区分存储的session信息是
哪个用户的。

两者最大的区别就是session存储在服务器端,而cookie是在客户端。session安全性更高,而cookie安全性弱。

session在web开发中具有非常重要的份量。它可以将用户正确登录后的信息记录到服务器的内存中,当用户以此身份
访问网站的管理后台时,无需再次登录即可得到身份确认。而没有正确登录的用户则不分配session空间,即便输入了
管理后台的访问地址也不能看到页面内容。通过session确定了用户对页面的操作权限。

使用session的步骤:
1. 启动session:
使用session_start()函数来启动。
2. 注册会话:
直接给 SESSION3.使session使4.1.使unsetsession2.使 S E S S I O N 数 组 添 加 元 素 即 可 。 3. 使 用 会 话 : 判 断 s e s s i o n 是 否 为 空 或 者 是 否 已 经 注 册 , 如 果 已 经 存 在 则 像 普 通 数 组 使 用 即 可 。 4. 删 除 会 话 : 1. 可 以 使 用 u n s e t 删 除 单 个 s e s s i o n ; 2. 使 用 _SESSION=array()的方式,一次注销所有的会话变量;
3.使用session_destroy()函数来彻底销毁session。

cookie怎么使用?
1. 记录用户访问的部分信息
2. 在页面间传递变量
3. 将所查看的internet页存储在cookies临时文件夹中,可以提高以后的浏览速度。

创建cookie:
setcookie(string cookiename , string value , int expire);
读取cookie:
通过超级全局数组$_COOKIE来读取浏览器端的cookie的值。
删除cookie:有两种方法
1.手工删除方法:
右击浏览器属性,可以看到删除cookies,执行操作即可将所有cookie文件删除。
2.setcookie()方法:
跟设置cookie的方法一样,不过此时将cookie的值设置为空,有效时间为0或小于当前时间戳。

  1. 如何设置一个cookie的名字为username,值为jack,并且让此cookie一周后失效?
    一个浏览器最多可以产生多少个cookie,每个cookie文件最大不能超过多少?
    setcookie(‘username’,’jack’,time()+7*24*3600);
    最多可以产生20个cookie,每个最多不超过4K

  2. 设置或读取session之前,需要做什么?
    可以直接在php.ini中开启session.auto_start = 1或者在页面头部用session_start();
    开启session,session_start()前面不能有任何输出,包括空行。

  3. 在实际开发中,session在哪些场合使用?
    session用来存储用户登录信息和用在跨页面传值。
    1)常用在用户登录成功后,将用户登录信息赋值给session;
    2)用在验证码图片生成,当随机码生成后赋值给session。

  4. 注销session会话的形式有几种?
    unset()
    $_SESSION=array();
    session_destroy();

你可能感兴趣的:(php)