当前位置:  编程技术>php
本页文章导读:
    ▪php IP转换整形(ip2long)的详解       如何将四个字段以点分开的IP网络址协议地址转换成整数呢?PHP里有这么一个函数ip2long.比如 代码如下:<?phpecho ip2long("10.2.1.3");?>我们将得到167903491这是如何计算的,目前我知道有两个算.........
    ▪php全局变量和类配合使用深刻理解       情况1: father.php如下定义: 代码如下: <?php $jack = 1000; ?> children.php 如下定义: <?php require("father.php"); $jack=123; echo $jack."/n"; ?> php children.php 运行输出为123. 如果将$jack=123注释掉,运行.........
    ▪php数组声明、遍历、数组全局变量使用小结       php教程:数组声明,遍历,数组全局变量 代码如下: <? /* * 一、数组的概述 * 1.数组的本质:管理和操作一组变量,成批处理 * 2.数组时复合类型(可以存储多个) * 3.数组中可以存储任意长度.........

[1]php IP转换整形(ip2long)的详解
    来源: 互联网  发布时间: 2013-11-30

如何将四个字段以点分开的IP网络址协议地址转换成整数呢?PHP里有这么一个函数ip2long.比如

代码如下:

<?php
echo ip2long("10.2.1.3");
?>

我们将得到
167903491

这是如何计算的,目前我知道有两个算法。其一
代码如下:

<?php
function ip2int($ip){
   //我们先把ip分为四段,$ip1,$ip2,$ip3,$ip4
   list($ip1,$ip2,$ip3,$ip4)=explode(".",$ip);
   //然后第一段乘以256的三次方,第二段乘以256的平方,第三段乘以256
   //这即是我们得到的值
    return$ip1*pow(256,3)+$ip2*pow(256,2)+$ip3*256+$ip4;
}
?>

其二,用位运算
代码如下:

<?php
function ip2int($ip){
   list($ip1,$ip2,$ip3,$ip4)=explode(".",$ip);
    return($ip1<<24)|($ip2<<16)|($ip3<<8)|($ip4);
}
?>

我们会发现,有些ip转化成整数后,是负的,这是因为得到的结果是有符号整型,最大值是2147483647.要把它转化为无符号的,可以用
sprintf("%u",ip2long($ip);

就能转换为正整数。而且得到的结果用long2ip也可以正常转换回原来的ip地址。也可以用ip2long来验证一个ip是否是有效的,如

代码如下:

<?php
function chk_ip($ip){
   if(ip2long($ip)=="-1") {
      return false;
    }
    returntrue;
}
//应用
var_export(chk_ip("10.111.149.42"));
var_export(chk_ip("10.111.256.42"));
?>

将输出true和false

把ip数据保存在数据库(MySQL)中时候,我们习惯用ip2long函数生成整型,然后存放在一个int(11)类型的字段中,但是,在不同的系统平台上,ip2long函数得到的值是不同的,因此可能造成在从数据库中读出数据,用long2ip得到ip的时候产生错误,说一下我们碰到的情况:
我们用一个int(11)类型(范围-2147483648 -2147483647)来保存把一个ip地址用ip2long处理得到的结果,例如ip是'202.105.77.179′,那么在32位机器上得到的结果是:-899068493,而在64位机器上却得到3395898803.然后把它写入数据库,由于超过int(11)的范围,因此64位机器上的结果被保存为int(11)的最大值:2147483647.于是在从数据库中取出的时候,便得到了错误的结果,会得到”127.255.255.255″这个ip地址.
解决的办法很多,比如可以用mysql的函数:INET_ATON和INET_NTOA来处理ip地址;或者把保存ip地址的字段改为bigint类型,这样在64位机器上虽然保存的是3395898803,使用long2ip函数仍能得到正确的结果.


    
[2]php全局变量和类配合使用深刻理解
    来源: 互联网  发布时间: 2013-11-30
情况1:
father.php如下定义:
代码如下:

<?php
$jack = 1000;
?>
children.php 如下定义:
<?php
require("father.php");
$jack=123;
echo $jack."/n";
?>

php children.php
运行输出为123.
如果将$jack=123注释掉,运行为1000,如果将$jack=123放到require("father.php");之前,运行结果为1000.
比较好理解:php解释执行,解释到哪,执行到哪。。像$jack这种属于全局变量,如第一种情况的初始用它的时候是1000,是在require
的时候运行得到的,结果又被改成了123,所以运行结果输出123.
情况2:
children.php代码改为如下:
代码如下:

<?php
require("father.php");
function testJack(){
if(!isset($jack)){
echo '$jack is null'."/n";
}
}//testJack
testJack();
?>

php children.php
运行结果为:$jack is null.也就是说在testJack()中引用的$jack是一个局部变量。
如果使用global关键字,声明这个$jack是一个全局变量,代码改为如下:
代码如下:

<?php
require("father.php");
function testJack(){
global $jack;
if(!isset($jack)){
echo '$jack is null'."/n";
}else{
echo '$jack is not null'."/n";
}
}//testJack
testJack();
?>

则运行结果为$jack is not null!
情况3:
children.php代码如下:
代码如下:

<?php
require("father.php");
class JackTest{
public function testJack(){
if(!isset($jack)){
echo '$jack is null'."/n";
}else{
echo '$jack is not null'."/n";
}
}//testJack
}
$jackTest = new JackTest();
$jackTest->testJack();
?>

运行结果输出:$jack is null
这是因为class中的这个函数的$jack这是一个局部变量啊。
如果在function testJack开头加 global $jack;那么就输出$jack is not null了。
比较容易理解。
情况4:
把文件名当做参数动态加载,代码如下:
代码如下:

<?php
$casefile = $_SERVER['argv'][1];
echo $casefile."/n";
require($casefile);
echo $jack."/n";
?>

运行php children.php father.php
结果如下:
father.php
1000
也就是说我们动态加载程序运行成功了。。
情况5:
要把动态加载和类的定义结合起来:
目录关系式这样的:
|- c.php
|- Bfold - b.php
|- Afold - a.class.php (里面的函数引用了../Bfold/b.php )
也就是说 在c.php 中new 了class a.class ,而a.class.php 的一个函数中require 了Bfold 文件夹下的b.php ,这个require(../Bfold/b.php )报错,Warning: ……
因为你让服务器当前执行的是c.php 文件,所以php 解析的时候是把路径相对于c.php 而言的,你试试把(../Bfold/b.php )改成(Bfold/b.php )看看,应该就不会报错了。
下面是程序例子,说明在函数内部使用require_once (A.php ).
对require_once 的理解:
假设B.php 中引用了require_once(A.php); 这条语句。。
那么其实是相当于调用了A.php 这个匿名的lambda 函数去执行。如下图:
C.php 在一个函数调用中 require 了 B.php------》
B.php 在普通语句中 require 了 A.php--------》
A.php
现在我们调用 php B.php ;因为 B.php 在普通语句中使用了 require 调用了 A.php ,那么 A.php 会把它的相对 A 来说是全局变量的变量,注册到 B.php 的环境中。因为 B.php 是根开始调用文件,他的运行环境就是全局环境。所以A.php 文件中的变量在 B.php 可以被正常使用。

现在我们调用 php C.php ;那么 C 是在函数使用 require 调用了 B.php 的,然后 B 又调用了 A ,感觉在这个调用的过程中,相对 B 和 A 根运行环境是 C 的调用函数的环境 ,但 C 的调用函数如果要使用 B 和 A 中的变量,就没有办法了。

如果用 global $a, 去引用,那么由于 $a 在这种情况下不属于全局变量,引用不到。
如果用 $a 去引用,那么由于 $a 会被当成局部变量也引用不到的。

    
[3]php数组声明、遍历、数组全局变量使用小结
    来源: 互联网  发布时间: 2013-11-30
php教程:数组声明,遍历,数组全局变量

代码如下:

<?
/*
* 一、数组的概述
* 1.数组的本质:管理和操作一组变量,成批处理
* 2.数组时复合类型(可以存储多个)
* 3.数组中可以存储任意长度的数据,也可以存储任意类型的数据
* 4.数组可以完成其他语言数据结构的功能(链表,队列,栈,集合类)
*
*
*
* 二、数组的分类
* 数组中有多个单元,(单元称为元素)
* 每个元素(下标[键]和值)
* 单访问元素的时候,都是通过下标(键)来访问元素
* 1.一维数组,二维数组,三维数组。。。多维数组
* (数组的数组,就是在数组中存有其他的数组)
* 2.PHP中有两种数组
* 索引数组:就是下标是顺序整数的索引
* 关联数组:就是下标是字符串作为索引
*
* 下标(整数,字符串)只有这两种
*
*
* 三、数组多种声明方式
*
* 1.直接为数组元素赋值声明
* 如果索引下标不给出,就会从0开始顺序索引
* 如果给出索引下标,下一个就会从最大的开始增1
* 如果后面出现前面的下标,如果是赋值就是为前面的元素重新赋值
* 混合声明时,索引和关联不互相影响(不影响索引下标的声明)
*
* 2.使用array()函数声明
* 默认是索引数组
* 如果为关联数组和索引数组指定下标,使用 键=>值
* 多个成员之间使用" , "分割
* 3.使用其他的函数声明
*
*
*
*
*/
//索引数组
$user[0]=1;//用户序号
$user[1]="zhangsan";//用户名
$user[2]=10;//年龄
$user[3]="nan";//性别
echo '<pre>';
print_r($user);
echo '</pre>';
//关联数组
$user["id"]=1;
$user["name"]="zhangsan";
$user["age"]=10;
$user["sex"];
$user["age"]=90;//赋值
echo $user["name"];//输出
//使用array()声明数组
$user=array(1,"zhangsan",10,"nan");
//使用array()声明关联数组
$user=array("id"=>1,"name"=>"zhangsan","age"=>10,"sex"=>"nan");
//声明多维数组(多条记录),来保存一个表中的多条用户信息记录
$user=array(
//用$user[0]调用这一行,比如调用这条记录中的姓名,$user[0][1]
array(1,"zhangsan",10,"nan"),
//用$user[1]调用这一行,比如调用这条记录中的姓名,$user[1][1]
array(2,"lisi",20,"nv")
);
//数组保存多个表,每个表有多条记录
$info=array(
"user"=>array(
array(1,"zhangsan",10,"nan"),
array(2,"lisi",20,"nv")
),
"score"=>array(
array(1,90,80,70),
array(2,60,40,70)
)

);
echo $info["score"][1][1];//输出60,
?>
数组超级全局变量
<?php
/* 预定义数组:
* 自动全局变量---超全局数组
*
* 1.包含了来自WEB服务器,客户端,运行环境和用户输入的数据
* 2.这些数组比较特别
* 3.全局范围内自动生效,都可以直接使用这些数组
* 4.用户不能自定义这些数组,但这些数组的操作方式和自己定义的数组操作的方式一样
* 5.在函数中直接可以使用这些数组
*
* $_GET //经由URL请求提交至脚本的变量
* $_POST //经由HTTP POST 方法提交到脚本的变量
* $_REQUEST //经由GET , POST和COOKIE机制提交 到脚本的变量
* $_FILES //经由http post方法文件上传而提交至脚本的变量
* $_COOKIE
* $_SESSION
* $_ENV //执行环境提交至脚本的变量
* $_SERVER //变量由WEB服务器设定的,或直接和当前脚本的执行环境相关联
* $GLOBALS //只要是当前脚本有效的变量都在这里,数组的键名为全局脚本的名称
*
*
*/
//超全局数组在函数内部可以直接调用
$arr=array(10,20);//一般数组
$_GET=array(50,90);//超全局数组
function demo(){
global $arr;//调用全局变量要先包含
print_r($arr);
print_r($_GET);//直接调用超全局数组不用包含
}



?>
<!-- **********页面传值get请求*************** -->
<?php
//直接把传的值当变量用,当php.ini配置文件中register_global=on时有用。
echo $username."<br>";
echo $email."<br>";
echo $page."<br>";
//最稳定的取值方法
echo $_GET["username"]."<br>";
echo $_GET["email"]."<br>";
echo $_GET["page"]."<br>";
?>
<a href="/blog_article/demo/username/zhangsan/amp;email/aaa@bbb.com/amp;page/45.html">this is a $_GET test</a>
<!-- ***********页面传值post请求**************** -->
<form action="/blog_article/demo.html" method="post">
username:<input type="text" name="uname" /> <br/>
password:<input type="password" name="pass" /> <br/>
<input type="submit" value="login" /> <br />
</form>
<?php
print_r($_GET);//不能接收到
print_r($_POST);//这样才能接收到
?>
<?php
//$_ENV的使用
echo'<pre>';
print_r($_ENV);
echo'</pre>';
//显示当前环境
// 也可以单个遍历
?>
<?php
//利用$GLOBALS超全局数组在函数内部调用全局变量
$a=100;
$b=200;
$c=300;
function demo()
{
//直接调用全局变量
echo $GLOBALS["a"]."<br>";
echo $GLOABLS["b"]."<br>";
echo $GLOABLS["c"]."<br>";

}
?>

数组遍历
<?php
/* 数组的遍历
*
* 1.使用for语句循环遍历数组
* 1.其他语言(只有这一种方式)
* 2.PHP中这种方式不是首选的方式
* 3.数组必须是索引数组,而且下标必须是连续的。
* (索引数组下标可以不连续,数组还有关联数组,这两种不能遍历)
*
* 2.使用foreach语句循环遍历数组
* foreacho(数组变量 as 变量值){
* //循环体
* }
* 1.循环次数由数组的元素个数决定
* 2.每一次循环都会将数组中的元素分别赋值给后面变量
*
* foreach(数组变量 as 下标变量=> 值变量){
* }
*
*
* 3.while() list() each() 组合循环遍历数组
*
* each()函数:
* 1.需要一个数组作为参数
* 2.返回来的也是一个数组
* 3.返回来的数组是0,1,key,value四个下标(固定的)
* 0和key下标是当前参数数组元素的键
* 1和value下标是当前参数数组元素的值
* 4.默认当前元素就是第一个元素
* 5.每执行一次后就会将当前元素向后移动
* 6.如果到最后的元素再执行这个函数,则返回false
* list()函数:
* 1. list()=array();需要将一个数组赋值给这个函数
* 2.数组中的元素个数,要和list()函数中的参数个数相同
* 3.数组中的每个元素值会赋值list()函数中的每个参数,list()将每个参数转为变量
* 4.list()只能接受索引数组
* 5.按索引的下标顺序来给参数赋值
*
*
*
*/
//for语句遍历数组
$user=array(1,"zhangsan",40,"nan");
for($i=0;$i<4;$i++)
{
echo"$user[{$i}]=".$user[$i]."<br>";
}

//使用foreach
$user=array(1,"zhangsan",40,"nan");
foreach($user as $val)//$val是自定义变量
{
echo $val."<br>";//输出与下标无关
}
foreach($user as $key=>$val)//$val $key 都是自定义变量
{
echo $key."=====>".$val."<br>";
}

//foreach遍历多维数组
$info=array(
"user"=>array(
//$user[0]
array(1, "zansan", 10, "nan"),
//$user[1][1]
array(2, "lisi", 20, "nv"), //$user[1]
//$user[2]
array(3, "wangwu", 30, "nan")
),
"score"=>array(
array(1, 100, 90, 80),
array(2, 99, 88, 11),
array(3, 10, 50, 88)
),
"connect"=>array(
array(1, '110', 'aaa@bbb.com'),
array(2, '120', 'bbb@ccc.com'),
array(3, '119', 'ccc@ddd.com')
)
);
foreach($info as $tableName=>$table)
{
echo '<table align="center" width="500" border="1">';
echo '<caption><h1>'.$tableName.'</h1></caption>';
foreach($table as $row)
{
echo '<tr>';
foreach($row as $col)
{
echo '<td>'.$col.'</td>';
}
echo '</tr>';
}
echo '</table>';
}

//each()的使用
$user=array("id"=>1,"name"=>"zhangsan","age"=>10,"sex"=>"nan");
$a=each($user);//Array ( [1] => 1 [value] => 1 [0] => id [key] => id ) 默认是第一个元素的值
print_r($a);
$b=each($user);
print_r($b);//Array ( [1] => zhangsan [value] => zhangsan [0] => name [key] => name ) 每执行一次,向后遍历一个

$c=each($user);
print_r($c);//Array ( [1] => 10 [value] => 10 [0] => age [key] => age )
$d=each($user);
print_r($d);//Array ( [1] => nan [value] => nan [0] => sex [key] => sex )
$e=each($user);
var_dump($e);//bool(false) 当没有元素时,返回的值
//each()配合while遍历
$user=array("id"=>1,"name"=>"zhangsan","age"=>10,"sex"=>"nan");
while($arr=each($user))
{
//echo $arr[0]."====>".$arr[1]."<br>";//通过0,1 来显示 键(下标) 和 值
echo $arr["key"]."===>".$arr["value"]."<br>";//通过key,value 来显示 键 值
}

//list()函数的使用
list($name,$age,$sex)=array("zhangsan",10,"nnnnn");
echo $name."<br>";
echo $age."<br>";
echo $sex."<br>";
//另一种使用方法
list(,,$sex)=array("zhangsan",10,"nnnnn");
echo $sex."<br>";//只把性别转换为变量
//ip判断
$ip="192.168.1.128";
list(,,,$d)=explode(".",$ip);//explode表示用 . 来分隔,并返回一个数组
echo $d;//取出128
//list()只能接收索引数组的例子
$user=array("id"=>1,"name"=>"zhangsan","age"=>10,"sex"=>"nan");
list($key,$value)=each($user);//Array( [1]=>1 [0]=>id) 按照索引下标的顺序给list中的参数赋值,所以先是 0键 然后是 1值
echo $key."--->".$value;
//while list() each() 组合使用
$user=array("id"=>1,"name"=>"zhangsan","age"=>10,"sex"=>"nan");
while(list($key,$value)=each($user))
{
echo $key."--->".$value."<br>";
}

//多次循环只显示一次的解决方法
//使用数组的内部指针控制函数
//next(数组);数组指针移动到下一个
//prev(数组);数组指针移动到上一个
//reset(数组);数组指针移动到第一个(复位)
//end(数组);数组指针移动到最后一个
//current(数组);获取当前元素的值,当前元素时指数组指针指向的元素。
//key(数组);获取当前元素的键值(下标)
$user=array("id"=>1,"name"=>"zhangsan","age"=>10,"sex"=>"nan");
while(list($key,$value)=each($user))
{
echo $key."--->".$value."<br>";
}
//在这里将数组指针移动到第一个以下循环就能输出
//reset($user)
while(list($key,$value)=each($user))//因为each()到最后一个返回false,所以循环直接跳出
{
echo $key."--->".$value."<br>";
}
while(list($key,$value)=each($user))//因为each()到最后一个返回false,所以循环直接跳出
{
echo $key."--->".$value."<br>";
}

echo current($user)."=====>".key($user);
?>

    
最新技术文章:
▪PHP函数microtime()时间戳的定义与用法
▪PHP单一入口之apache配置内容
▪PHP数组排序方法总结(收藏)
▪php数组排序方法大全(脚本学堂整理奉献)
▪php数组排序的几个函数(附实例)
▪php二维数组排序(实例)
▪php根据键值对二维数组排序的小例子
▪php验证码(附截图)
▪php数组长度的获取方法(三个实例)
▪php获取数组长度的方法举例
▪判断php数组维度(php数组长度)的方法
▪php获取图片的exif信息的示例代码
▪PHP 数组key长度对性能的影响实例分析
▪php函数指定默认值的方法示例
▪php提交表单到当前页面、提交表单后页面重定...
▪php四舍五入的三种实现方法
▪php获得数组长度(元素个数)的方法
▪php日期函数的简单示例代码
▪php数学函数的简单示例代码
▪php字符串函数的简单示例代码
▪php文件下载代码(多浏览器兼容、支持中文文...
▪php实现文件下载、支持中文文件名的示例代码...
▪php文件下载(防止中文文件名乱码)的示例代码
▪解决PHP文件下载时中文文件名乱码的问题
▪php数组去重(一维、二维数组去重)的简单示例
▪php小数点后取两位的三种实现方法
▪php Redis 队列服务的简单示例
▪PHP导出excel时数字变为科学计数的解决方法
▪PHP数组根据值获取Key的简单示例
▪php数组去重的函数代码示例
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3