这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 综合技术 » 基础知识 » 扣丁学堂PHP视频教程之session实现机制和PHP正则表达式详解

共4条 1/1 1 跳转至

扣丁学堂PHP视频教程之session实现机制和PHP正则表达式详解

助工
2020-10-26 10:49:32     打赏

  近年来,I随着国内T行业发展迅猛,无论是高薪行业的标签,还是互联网就业的保障,都吸引着越来越多的人加入到行业中来。而纵观IT行业中的众多编程语言,PHP在服务器脚本语言市场的占有率上一直遥遥领先。今天扣丁学堂小编给大家整理了一下关于PHP视频教程中的session实现机制和PHP正则表达式详解吧。

  一、默认机制,用磁盘文件来实现PHP会话。php.ini配置:session.save_handler=files


  1、session_start()


  A、session_start()是session机制的开始,它有一定概率开启垃圾回收,因为session是存放在文件中,


  PHP自身的垃圾回收是无效的,SESSION的回收是要删文件的,这个概率是根据php.ini的配置决定的,


  但是有的系统是session.gc_probability=0,这也就是说概率是0,而是通过cron脚本来实现垃圾回收。


  session.gc_probability=1


  session.gc_divisor=1000


  session.gc_maxlifetime=1440//过期时间默认24分钟


  //概率是session.gc_probability/session.gc_divisor结果1/1000,


  //不建议设置过小,因为session的垃圾回收,是需要检查每个文件是否过期的。


  session.save_path=//好像不同的系统默认不一样,有一种设置是“N;/path”


  //这是随机分级存储,这个样的话,垃圾回收将不起作用,需要自己写脚本


  B、session会判断当前是否有$_COOKIE[session_name()];session_name()返回保存session_id的COOKIE键值,


  这个值可以从php.ini找到


  session.name=PHPSESSID//默认值PHPSESSID


  C、如果不存在会生成一个session_id,然后把生成的session_id作为COOKIE的值传递到客户端.


  相当于执行了下面COOKIE操作,注意的是,这一步执行了setcookie()操作,COOKIE是在header头中发送的,


  这之前是不能有输出的,PHP有另外一个函数session_regenerate_id()如果使用这个函数,这之前也是不能有输出的。


  setcookie(session_name(),


  session_id(),


  session.cookie_lifetime,//默认0


  session.cookie_path,//默认’/’当前程序跟目录下都有效


  session.cookie_domain,//默认为空


  )


  D、如果存在那么session_id=$_COOKIE[session_name];


  然后去session.savepath指定的文件夹里去找名字为’SESS’.session_id()的文件.


  读取文件的内容反序列化,然后放到$_SESSION中


  2、为$_SESSION赋值


  比如新添加一个值$_SESSION[‘test’]=’blah';那么这个$_SESSION只会维护在内存中,当脚本执行结束的时候,


  用把$_SESSION的值写入到session_id指定的文件夹中,然后关闭相关资源.这个阶段有可能执行更改session_id的操作,


  比如销毁一个旧的的session_id,生成一个全新的session_id.一半用在自定义session操作,角色的转换上,


  比如Drupal.Drupal的匿名用户有一个SESSION的,当它登录后需要换用新的session_id


  if(isset($_COOKIE[session_name()])){


  setcookie(session_name(),”,time()42000,’/’);//旧sessioncookie过期


  }


  session_regenerate_id();//这一步会生成新的session_id


  //session_id()返回的是新的值


  二、PHP正则表达式的基础总结


  开头的^和结尾的$让PHP从字符串开头检查到结尾。假使没有$,程序仍会匹配到Email的末尾。


  开头的^和结尾的$让PHP从字符串开头检查到结尾。假使没有$,程序仍会匹配到Email的末尾。


  [和]被用来限制许可输入类型。例如a-z允许所有的小写字母,A-Z允许所有的大写字母,0-9所有数字,等等,以及更多其他类型。


  {和}被用来限制期望的字符数。例如{2,4}表示字符串的每一节可以有2-4字符长度,像是.com.cn或.info。在这里,"."并不算一个字符,因为{2,4}之前定义的许可输入类型只有大小写字母,故此段只匹配大小写字母


  (和)被用来合并小节,并定义字符串中必须存在的字符。(a|b|c)能够匹配a或b或c。


  (.)将匹配所有字符,而[.]只匹配"."本身。


  要使用一些符号本身,必须在前增加一个\。这些字符有:()[].*?+^|$


  /定界符


  ^字符串头


  $字符串尾


  [a-z]所有小写字母


  [A-Z]所有大写字母


  [0-9]所有数字


  ?零或一个紧接前的字符


  零或多个紧接前的字符


  一或多个紧接前的字符


  {4}4个紧接前的字符


  {4,8}4-8个紧接前的字符


  .任意字符


  (red|green|blue)Red或green或blue(红或绿或蓝)


  s空格


  特殊字符(需要在前加\)


  ()[].*?+^|$


  规则匹配preg_match


  利用preg_match(),我们可以完成字符串的规则匹配。如果找到一个匹配,preg_match()函数返回1,否则返回0。还有一个可选的第三参数可以让你把匹配的部分存在一个数组中。在验证数据时这个功能可以变得非常有用。


  $string="football";


  if(preg_match('/foo/',$string)){


  //匹配正确


  }


  规则替换preg_replace


  preg_replace允许你替换字符串中匹配到你定义的正则表达式。


  $val="/123456789/abcd";


  $pp=preg_replace("/[(\/*)+(.)(*\/)+]+/",'fuck',$val);


  print_r($pp);


  结果是:fuck123456789fuckabcd


  规则分割preg_split


  preg_split可以将整段字符串按匹配到的正则表达式分割成1、2或更多字符的多段。比如获取标签,无论是用空格还是逗号分隔的:


  $tags=preg_split('/[,]/','my,tags,unevenly,spaced');


  print_r($tags);


  结果是:Array([0]=>my[1]=>tags[2]=>unevenly[3]=>spaced)


  以上就是关于扣丁学堂PHP视频教程中的session实现机制和PHP正则表达式的详细介绍,希望对大家有帮助,最后想要了解更多关于PHP开发发展前景趋势,请关注扣丁学堂官网、微信等平台,扣丁学堂IT职业在线学习教育平台为您提供权威的PHP培训视频教程系统,通过千锋扣丁学堂金牌讲师在线录制的一套PHP视频教程课程,让你快速掌握PHP从入门到精通开发实战技能。扣丁学堂PHP技术交流群:374332265。



工程师
2020-10-28 22:34:56     打赏
2楼

分享搞的不错


高工
2020-10-29 21:54:42     打赏
3楼

学到了


工程师
2020-11-01 22:45:41     打赏
4楼

十分不错的分享


共4条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]