php学习01

来源:互联网 发布:域名交易网 编辑:程序博客网 时间:2024/05/29 18:46
<?php/* * 回顾 * php 魔术方法 * __set() 当在类外使用类的private 属性时,或不存在的属性时会报错,如果设置了__set()方法,那么就会调用这个方法 *    __set(成员属性名名称,要设置的成员属性的值) * __get() 当在类外获取类的private 属性时,属性时,或不存在的属性时会报错, 如果设置了__get()方法,那么就会调用这个方法 *    __get(成员属性的名称) * __call() 当调用类的不存在的方法时,会报错,若定义了改方法,那么就调用此方法 *    __call(被调用的方法名,该方法的参数) * __callStatic(被调用的方法名,该方法的参数) * __clone() 当对象克隆时调用该方法 *    __clone(),默认参数为$this,$that$this 为要克隆出的对象,$that为原对象 * __construct 构造函数 * __destruct 析构函数 * __sleep(); 当对象序列化之前被调用 * __wakeup()当反序列化之前调用 * __autoload(被包含的类名) 当调用一个类名的方法时,如果没有将该类包含进来, 则会报错,当定义了此函数时,就会调用此函数动态加载类文件   __toString()  当直接输出类的对象时会报错,如果定义的该方法,则调用此方法 *  */class A {    private $name;    private $age;    public function __construct($name,$age){        $this->name = $name;        $this->age = $age;    }    public function __set($name,$value){        $this->$name = $value;    }    public function __get($name){        if($name=='fuck')            return "fuck!";        if(isset($this->$name)){            return $this->name;        }else{            return NULL;        }    }    public function __call($name,$args){        echo $name ,"Mothod不存在";        var_dump($args);    }    public static function __callStatic($name,$value){        echo "静态方法$name不存在";    }    public function __clone() {         $this->name = "我是被克隆的";    }    public function __sleep() {       // echo "正在被序列化";        return array(name);    }    //重新生成对象时,调用    public function __wakeup() {        $this->name = "张三";        $this->age = 234;    }    public function __toString() {        return "A";    }}//$a = new A("张三",22);//echo $a->name;//$a->name = "张三";//echo $a->name;//$a->get("xue",3,"sf") ;//$a1 = clone $a;//echo $a->name,"<br/>",$a1->name;//$p_str = serialize($a);//echo $p_str;//$a2 = unserialize($p_str);//var_dump($a2);//function __autoload($classname){//       include $classname.".php";//}//echo $a2->fuck;//A::ha();/* * 1. echo 和print 的区别 *  echo 是语句,不是函数, 不用括号,可以输出多个值,没有返回值,不能输出数组和对象 只能输出简单的类型,如 int,string  *  print 是语句,不是函数,不用括号,只能输出一个值,有返回值1,不能输出数组和对象,只能输出简单的类型,如int,string * 2.print_r() 和 var_dump() *  print_r() 是函数,可以输出复合类型和简单类型,如int float ,string ,array object,当输出对象时以机构表示如 Object{},当输出 *   数组时表示为Array() *  var_dump() 是函数,输出变量的内容,类型,长度,可以输出简单类型,复合类型,常用来调试 * 3.printf 是函数,类似C语言,格式化字符串输出 * 4.sprintf 函数,类似C语言,格式化字符串后返回一个格式化后的字符串不输出 *  *///print_r(3.55);//$arr = array("xue",3);// print_r($arr);// var_dump($arr);//$nb = sprintf("%s 是个%d吊","haha",3);//echo $nb;/* * 获取文件内容方式 * 1.file_get_contents(); *  *///$txt = file_get_contents('data.txt');//echo $txt;//$file = fopen("data.txt","r");//while(!feof($file)){//    $line = fgets($file);//   // echo $line;//    //}//while(!feof($file)){//    $char = fgetc($file);//     echo $char;//}/* * strlen() he mb_strlen的区别 * 两者都是求字符串长度的函数 * 在strlen只是获得字符串所占的字节数,无法正确处理中文字符 * 当为GB2313编码时,一个汉字占2位,当为UTF-8编码时,一个汉字占3位 * mb_strlen()能够正确处理汉字,第二个参数为编码的类型,默认为UTF-8,默认为PHP内部的编码,可以用mb_internal_encoding()来查看 * mb_strlen()并不是php核心函数, 需要加载扩展库来使用,在php.in中 extension = "php_mb_string.dll" *///$str = "黛玉123f";//echo strlen($str); // 输出10//echo mb_strlen($str,'UTF-8'); //输出6//echo mb_internal_encoding();//输出 ISO-8859-1///* * php数组函数 * 数组的键名和值 * 1.is_array()判断是否是数组,是返回TRUE,不是返回false,类似 is_int(); is_float(); * 2.array explode ( string $delimiter , string $string [, int $limit ] )此函数将字符串分割为数组 * 3.string implode ( string $glue , array $pieces )将数组分割为字符串 * 4.array_values()返回数组所有的值,请给其建立数字索引 * 5.array array_keys ( array $input [, mixed $search_value = NULL [, bool $strict = false ]] ) * 6.array_key_exists() 检索指定的键名或索引是否在数组中,存在返回true,否则返回false * 7.array_flip()交换数组的键名和值,若存在相同值,则以最后一个键值为准 * 8.array_search() 在数组中搜索给定的值,若存在返回对应的键名,否则返回FALSE * 9.检索数组中是否存在某个值,存在返回true,不存在返回FALSE * 10.isset($arr['apple'] 检测指定的键名知否存在给定的数组中,存在返回true,否则返回false * 数组的内部指针 * current($arr);  返回数组中的当前单元   pos($arr);  返回数组中的当前单元   key($arr);  返回数组中当前单元的键名   prev($arr);  将数组中的内部指针倒回一位   next($arr);  将数组中的内部指针向前移动一位   end($arr);  将数组中的内部指针指向最后一个单元   reset($arr;  将数组中的内部指针指向第一个单元 * each($arr);  返回数组当前指针单元的键名和值,以新数组的形式,且当前数组的指针向前移动一步,若到达数组最后一个单元, 则停留为最后一个单元 *  键值对被返回为四个单元的数组,键名为>,key 和 value。单元 0 和 key 包含有数组单元的键名,1 和 value 包含有数据。  * list($key,$value);  不是真正的函数,是一种语言结构,获得数组当前元素的键名和值,并赋值给变量,list只能用于没有键名和索引的数组 *  * 数组和变量之间的转换 * extract() 从数组中将变量导入到当前的符号表 * 检查每个键名看是否可以作为一个合法的变量名,同时也检查和符号表中已有的变量名的冲突。  * compact() 将变量变为数组 * 数组的分段和填充 * array_slice 在数组中取出一段 *   array_slice($array,int offset,[int length,false|true]); * 若偏移量为负数,则从数组末端开始数 * 若长度为负数,则序列将终止在距离数组末端这么远的地方 * array array_splice ( array &$input , int $offset [, int $length = 0 [, mixed $replacement ]] ) *   删除数组的某段,根据offset和length,可以用replacement替换被被删除的单元,替换个数和被替换的单元的个数一致,如果为数组,则键名 *  不保留,只替换值,也可以为字符串,如果没有删除的单元,那么替换的变量将会被插入到offset的位置 *  *  分割多个数组 *  array_chunk(array,size,[true|false]) *  将一个数组分割成多个数组,每个数组的元素量为size,size小于1将报错,可能最后一个数组的元素小于size,默认为false,将丢掉原数组的索引或键名 *    重新建立从0开始的数字索引,为true时,保留原来的键名或索引 *   *  数组的填充 *  array_pad(array,length,value); *  将数组用value填充到length长度, *  若length小于等于数组的长度,则不填充 *  如果length为负数, 则向左填充 *   *  数组与栈 *  array_push(array,value,,,); *  将一个或多个值压入数组栈,返回此数组的元素个数 *  array_pop(array); *  返回一个数组的栈顶元素,如果数组为空或者不是数组,则返回NULL *  *  数组与列队 *  array_shift(array); *  将返回数组的第一个元素,数组的元素个数减一,后面的元素向前移动,数字键名从0开始重新技术,关联键名不变 *  若数组为空,或不为数组,则返回NULL *  array_unshift(array,value,,,); *  将值插入数组的开头,所有的数字索引将重新从0开始技术,关联键名不变 *  *  数组排序 *  键值排序 *  sort(array,[]); 将数组的值从小到大排序,操作成功返回true,否则返回false *  忽略键名的数组排序 *  rsort(array[],,),将数组的值从大到小排序,操作成功返回true,否则返回false *  忽略键名的数组排序 *  usort(array,funcname);调用用户定义的函数对数组排序 *  忽略键名的数值排序 *  *  asort() 保留键名的数值排序 *  arsort() 保留键名的数值排序 *  uasort() *  ========= *  键名排序 *  ksort() 用键名排序,主要用于关联数组 *  krsort() 按照键名逆序排序 *  uksort() 自定义函数排序 *  ========= *  自然排序法排序 *  natsort();自然排序 *  natcasesort()自然排序,忽略大小写 *   *  数组的计算 *  array_sum()计算数组元素的和 *  数组的合并 *  array_merge(array1,array2);则键名会以连续方式重新索引 *  array1+array2  对于相同的键名只保留第一个 *  如果你想完全保留原有数组并只想新的数组附加到后面,用 + 运算符 *  array_merge_recursive() 递归合并数组 *  如果输入的数组中有相同的字符串键名,则这些值会被合并到一个数组中去,这将递归下去,因此如果一个值本身是一个数组,本函数将按照相应的条目把它合并为另一个数组。然而,如果数组具有相同的数组键名,后一个值将不会覆盖原来的值,而是附加到后面。  *   *  数组的差集 *  array_diff(array1,array2,array3,,,);返回在array1中但不在其他数组中的元素 *  array_diff_assoc(array1,array2,array3...);返回在array1中但不在其他数组中的元素,键名也做比较,只有键名和键值都相同时才算 *   *  数组的交集 *  array_intersect(array1,array2,,,);返回数组的交集 *  array_intersect_assoc(array1,array2,,,);返回数组的交集,键名也做比较 *   *  其他的数组函数 *  range(start,max,step);创建一个start到max范围的一个数组,step为步长,默认为1 *  array_unique()除去数组中重复的值 *  array_reverse();反转数组,若第二个参数为true时则保留键名 *  array_rand(array,size);随机返回数组中的一个或多个单元的键名,若为多个则返回包含多个键名的数组 *  shuffle(array); 将数组的元素打乱,返回FALSE或TRUE *  *   *  *///var_dump  (is_array(3));$arr = explode(",","I,am,hello,3");print_r($arr);echo implode($arr);//array_values()$arr = array_values(array('name'=>'daiyutage',"age"=>20));print_r($arr);$arr = array_keys(array('name'=>"daiyutage","age"=>20));print_r($arr);var_dump(array_key_exists('name',array("name"=>"daiyu")));var_dump (array_flip((array("a"=>1,"b"=>1,"ddd"=>33))));echo in_array("daiyutage",array("name"=>"daiyutage"));$arr = array("name"=>1);echo isset($arr['name']);$foo = array("Robert" => "Bob", "Seppo" => "Sepi","name"=>3324);$bar = each($foo);print_r($bar);$bar = each($foo);print_r($bar);$info = array("name","haha");unset($a);list($a[0],$a[1])  = $info;//print_r($a);////$name = "diayutage";//extract(array(//     "name"=>"xue",//     "age"=>22,//     "school"=>"lut"//),EXTR_PREFIX_SAME,'WX');//echo $name," ","$age","  ","$school"," ",$Wx_name;//课本,1,2,3,《书读百遍,其义自现》//compact$firstname = "Peter";$lastname = "Griffin";$age = 38;$color="red";$rs = array("color","fx");//$result = compact("firstname", "lastname", "age",$rs);//print_r($result);$arr = array("a","xx"=>"b",6=>"c","d","e");//print_r(array_slice($arr,2,-1,true));//   array_splice($arr,1,-4,"xxxxx");// print_r($arr);//print_r(array_chunk($arr,2,false));//print_r(array_pad($arr,-10,33));//print_r(array_push($arr,"daiyutage","fff"));//echo array_pop($arrs);//echo array_shift($arr);array_unshift($arr,array("hasdf","sf"));$fruits = array("lemon", "sdfsf"=>"orange", "banana", "apple");rsort($fruits);function cmp($a,$b){     return $a==$b?0:$a<$b?-1:1;}//$brr = array("fsf","fs"=>3,10=>2,4=>244,3244);//ksort($brr);//print_r($brr);//print_r(array_merge($fruits,$brr));//则键名会以连续方式重新索引//$a = array(3=>"red","hello","hello");//$b = array("red","fe");//print_r(array_intersect_assoc($a,$b));//var_dump(range(0,12,9));//print_r(array_reverse($fruits));//print_r(array_rand($fruits));//(shuffle($fruits));// print_r($fruits);///* * 时区设置 * date_default_timezone_set()设置时区,时区不正确会报错抛出 E_WARNING 而不是 E_STRICT。不区分大小写 * date_defalut_timezone_get()获取时区 * 中国时区为Asia/Shanghai 或 PRC  *  *///echo date_default_timezone_get();//error_reporting(E_ALL);//date_default_timezone_set("PRC");//echo date_default_timezone_get();///* CGI,PHP_mod,FastCGI的区别 * CGI 通用网关协议 * 当客户端请求服务器时,服务器fork一个进程,执行php.cgi程序对php页面进行解析,解析完进程销毁,返回服务器, * 每次的请求过程,fork->执行->销毁,效率很低,耗费较多的系统资源 * php_mod * php解释器以模块的形式同apache服务器一起启动,使用同一个进程 * FastCGI * CGI的增强版,相当于一个中间层,使用一个进程,客户端->服务器->FastCGI->php解释实例,FastCGI用一个进程常驻内存,并创建多个CGI实例 * apache与FastCGI的通信为tcp通信,即FastCGI可以为本机,也可以为远程主机 * apache与CGI的通信为进程间通信,必须为同一主机 * 小总结:    cgi : 需要开启若干个进程;    fastcgi : 需要额外开启一个进程;    php_mod :无需开启额外进程,因为PHP解析器已集成到web服务器中,跟web服务器在同一个进程。 *  *  php_mod配置方式 *  在apache中,httpd.conf中 * 1    LoadModule php5_module "C:/php5/php5apache2_2.dll"//大约line 1272   PHPinidir "C:/php5/php.ini"3   //修改配置4   DirectoryIndex index.html index.php//追加index.php5   AddType application/x-httpd-php .php //line 408左右添加 *  CGI配置方式 *  *  *///error_reporting(E_ALL);//setcookie("haha");/* * cookie 与 session * cookie['login'] = true; * A访问 * session盒子开 * session['login'] = true; * B访问 * session盒子开 * session['login'] = true; * session 在内存中,如果不区分每一个客户端的session,那么session将无法使用 * 所以需要将每一个请求的session与其客户端关联 * 方法: * 当第一次请求服务器时,服务器生成一个session_id, * 通过http头将session_id发送给浏览器,浏览器保存在将此session_id保存在本地的cookie中 * 当再次请求服务器时,浏览器发送此cookie,服务器收到后用本地cookie中的session_id来访问此客户端的session *  * 当cookie被禁用时,如何使用session * php默认有两种session传递方式 * 1.cookie * 2.url  如.php?sid=xxx,或者post提交方式,手动通过url添加sid *   url  通过设置php.ini参数,自动添加到url *   session.use_cookie=1 *   session.use_only_cookie=0 *   session.use.trans_id=1 *   然后php会自动在url加PHPSESSION=XXXX *  * 3.文件保存sid,第一个页面把sessionid保存在文件中,第二个页面先从这个文件中取sessionid在判断是否登录 * 4.数据库保存sid,和文件原理相同 *  * 当cookie被禁用时,浏览请求时不会再发送cookie到服务器,那么服务器就会收不到cookie=PHPSESSION的,不能使用session * 使用url * 在前一个页面开启session后,用session_id()获得session_id,然后以get/post方式传递到后一个页面 * 第二个页面在用此sessio_id来设置 session_id(),然后开启session_start(),就可以使用前面穿过来的session * 注意:session_id()必须在session_start()之前调用 *  * *  */session_start();$_SESSION['login'] = "daiyutage";//$sid = session_id();echo "<a href='b1.php'>另一个页面</a>";
0 0
原创粉丝点击