<?php
//打印一个三角形
for($i=0;$i<=3;$i++)
{
for($j=0;$j<=3-$i;$j++){
echo ‘ ’;
}
for($k=0;$k<=2*$i;$k++)
{
echo “*”;
}
echo ‘<br>’;
}
?>
<?php
//杨辉三角
for($i=0;$i<6;$i++)
{
//第一个和最后一个都为1
$a[$i][0]=1;
$a[$i][$i]=1;
}
for($i=2;$i<6;$i++){
for($j=1;$j<$i;$j++)
{
$a[$i][$j]=$a[$i-1][$i-1]+$a[$i-1][$j];
}
}
for($i=0;$i<6;$i++)
{
for($j=0;$j<=$i;$j++){
echo $a[$i][$j].’ ’;
}
echo ‘<br/>’;
}
?>
<?php
//合并多个数组
function t(){
$c=func_num_args()-1;//返回传递给函数的参数个数
$a=func_get_args();//返回一个数组,包括函数的参数列表
for($i=0;$i<=$c;$i++){
if(is_array($a[$i])){
for($j=0;$j<count($a[$i]);$j++){
$r[]=$a[$i][$j];
}
}else{
die(‘Not a array’);
}
}
return $r;
}
print_r(t(range(1,4),range(1,4),range(1,4)));
?>
<?php
//求牛
function cow($num,$y)
{
for($j=1;$j<$y;$j++)
{
if($j>=4 && $j<15)
{
$num++;
cow($num,$y-$j);
}
if($j==20)
$num–;
}
return $num;
}
echo cow(2,2);
?>
<?php
//顺序查找(数组里查找某个元素)
function seq_sch($array,$n,$k)//在某个位置之前查找某元素(不包括指定位置)
{
$array[$n]=$k;
for($i=0;$i<$n;$i++)
{
if($array[$i]==$k)
break;
}
if($i<$n)
return $i;
else
return -1;
}
$array=array(‘a’,'b’,'c’);
echo seq_sch($array,2,’b');
?>
<?php
function show($i)
{
if($i==1)
return 1;
else
return $i*show($i-1);
}
echo “<br>”;
echo show(3);
?>
<?php
//裴波那挈数列
function b($n)
{
if($n<2)
return $n;
else
return b($n-1)+show($n-2);
}
echo b(2);
?>
本文链接
const AUTH_SECRET = '07e7606b379e0f6c21170a96521a0917';
//生成签名
/**
* hash_hmac — Generate a keyed hash value using the HMAC method
*/
public function generateAuthSignature($uid, $time, $expire = null)
{
$scramble = 'uid='.$uid.'&time='.$time.'&expire='.$expire;
return hash_hmac('sha256', $scramble, self::AUTH_SECRET);
}
//签名认证:@param 用户id,生成时间,失效时间,签名
public function authWithSignature($uid, $time, $expire, $s)
{
if(!ctype_digit($uid)){
return false;
}
//过期时间小于当前时间 : 失效
if($expire < TIMESTAMP){
return false;
}
if($this->generateAuthSignature($uid, $time, $expire) === $s){
app::$uid = $uid;
$this->switchUser($uid);
return true;
}
return false;
}
本文链接
之前为了做 《plog.cn 1-6位 超期待删 短域名 筛查工具》,特地在 plog.cn 服务器上部署了一个 whois 查询小工具。PS:使用方法 http://plog.cn/whois/yourdomain.com
为了实现这个 whois 小工具,查了足足有两个小时的资料,网上有很多种 whois查询 的php实现,大致实现的思路无不例外以下几种:
1.通过http调用 xinnet或者是万网的 whois查询接口查询,而后将结果输出到页面,博客 http://blog.163.com/mengqing_dao/blog/static/133520513201162634227882/ 所描述的方法,就是这种最简单的,通过间接调用新网 whois查询接口的实现方法
2.直接通过读取 whois服务器,实现域名的查询。文章 http://dev.meettea.com/show-78-1.html 阐述的方法,就是根据被查询域名的后缀名,访问不同的 whois服务器,查询结果
对应的 域名后缀 -> whois 服务器 的映射关系大致如下:
对于这种方法,虽然实现起来很简单,但是对于在Godaddy.com平台或者是国内的厦门易名网注册的 域名来说,只能查到一个大概,而无法查到具体真正的 domain 的信息,如下:
在godday注册的域名的whois信息
在厦门易名网注册的域名的whois信息
所以,无论上面两种方法,都不能比较完善的实现 whois 的查询功能。
这时候 Jay感觉到,仅仅是 whois 这件小事,也需要用牛刀,我们需要一个完善 whois查询组件。
此时的 Jay立刻打开 google.com,搜索 php whois,果不其然!
在 百度中,搜了半天,出来的都是一些外门奇方,google一搜,就立马出现一套完整的 whois client 的 php 实现,项目名称就叫《phpWhois》,项目主页:http://www.phpwhois.org/ ,于是立马 download 下来,根据文档中的 demo,很快就把 whois 的查询功能实现了。
下面是调用 phpWhois 组件,实现 whois信息查询的核心代码部分:
<pre><?phpinclude('whois_inc/whois.main.php');
$whois =newWhois();
$result = $whois->Lookup($domain);
$output = implode("\n", $result['rawdata']);
echo $output;?></pre>
在这里<pre></pre>标签的作用是定义预格式化的文本,就是将 whois 查询到的 raw text 按原来的文本排版格式直接输出。
DomainName: lxfq.cnROID:20130114s10001s62921725-cn
DomainStatus: ok
Registrant ID:000046dbRegistrant:黎军RegistrantContactEmail:2673732891@qq.com
SponsoringRegistrar:北京网尊科技有限公司NameServer: ns1.vtopchina.cn
NameServer: ns2.vtopchina.cn
RegistrationDate:2013-01-1404:02:16ExpirationDate:2014-01-1404:02:16
DNSSEC:unsigned
总结:
whois虽然仅仅只是一种最简单的基于 tcp 的查询协议,但是很多工作,即便我们实现起来也非常简单,如果有现成的 php组件可以用的话,就应该尽量避免自己重复发明一个轮子。倒不是说不可以,只是重新实现一种协议,即便是最简单的那种,也会遇到很多的例外。
就像 phpWhois 组件,争对godaddy类似这种的例外情况,就处理的非常好。
所以,专业的事情,还是让专业的开源组件去实现吧!
本文链接