代码如下 | 复制代码 |
function bigendian2int($byte_word, $signed = false) { $m = intval(($sec % 3600) / 60); |
php教程常用正则表达式函数
我们这里面很多中正则表达式代码,包括有判断中文正则,数字字母正则,字符正则表达试,数字正则表达试,邮箱正则表达式,电话号码正则表达试,手机号码正则表达试,邮编正则表达试,/url正则表达试等哦。
*/
function funcchinese($str,$num1='',$num2='')//判断中文正则
{
if($num1!='' and $num2!=''){
return (preg_match("/^([x81-xfe][x40-xfe]){".$num1.",".$num2."}$/",$str))?true:false;
}else{
return (!eregi("[^x80-xff]","$str"))?true:false;
}
}
function funcstrnum($str,$num1='',$num2='') //数字字母正则
{
if($num1!='' and $num2!=''){
return (preg_match("/^[^0-9a-za-z_@!.-]{".$num1.",".$num2."}$/",$str))?true:false;
}else{
return (preg_match("/^[^0-9a-za-z_@!.-]/",$str))?true:false;
}
}
// 常用的正则表达试
function funcstr($str,$num1='',$num2='') //字符正则表达试
{
if($num1!='' and $num2!=''){
return (preg_match("/^[a-za-z]{".$num1.",".$num2."}$/",$str))?true:false;
}else{
return (preg_match("/^[a-za-z]/",$str))?true:false;
}
}
function funcnum($str,$num1='',$num2='')//数字正则表达试
{
if($num1!='' and $num2!=''){
return (preg_match("/^[0-9]{".$num1.",".$num2."}$/",$str))?true:false;
}else{
return (preg_match("/^[0-9]/",$str))?true:false;
}
}
function funccard($str)//
{
return (preg_match('/(^([d]{15}|[d]{18}|[d]{17}x)$)/',$str))?true:false;
}
function funcemail($str)//邮箱正则表达式
{
return (preg_match('/^[_.0-9a-z-a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,4}$/',$str))?true:false;
}
function funcphone($str)//电话号码正则表达试
{
return (preg_match("/^(((d{3}))|(d{3}-))?((0d{2,3})|0d{2,3}-)?[1-9]d{6,8}$/",$str))?true:false;
}
function funcmtel($str)//手机号码正则表达试
{
return (preg_match("/(?:13d{1}|15[03689])d{8}$/",$str))?true:false;
}
function funczip($str)//邮编正则表达试
{
return (preg_match("/^[0-9]d{5}$/",$str))?true:false;
}
function funcurl($str)//url正则表达试
{
return (preg_match("/^http://[a-za-z0-9]+.[a-za-z0-9]+[/=?%-&_~`@[]':+!]*([^<>""])*$/",$str))?true:false;
}
一,socket是什么
什么是socket 所谓socket通常也称作"套接字",用于描述ip地址和端口,是一个通信链的句柄。应用程序通常通过"套接字"向网络发出请求或者应答网络请求。说白了就是一种通信机制。它类似于银行,电信啊这些部分的电话客服部门。你打电话的时候,那边会分配置一个人回答你的问题,客服部门就相当于socket的服务器端了,你这边呢就相当于客户端了,在和你通话结束前,如果有人在想找和你通话的那个说话,是不可能的,因为你在和他通信,当然客服部门的电话交换机也不会重复分配。
下面我将举例子来说明一下,socket是怎么工作的。如果你是基于应用层开发的人员并不一定要理解原理,但是能知道那是更好了。网上有关于socket的php api。下下来用就行了。
二,socket服务器server.php
<?php
// 建立server端socket
$tcp = getprotobyname("tcp");
$socket = socket_create(af_inet, sock_stream, $tcp);
socket_bind($socket, '127.0.0.1', 10008); //绑定要监听的端口
socket_listen($socket); //监听端口
//初始化一个数据,和客户端通信
$buffer = "connect";
while (true) {
// 接受一个socket连接
$connection = socket_accept($socket);
if(!$connection){
echo "connect fail";
}else{
echo "socket connected ";
// 向客户端传递一个信息数据
if ($buffer != "") {
echo "send data to client ";
socket_write($connection, $buffer . " ");
echo "wrote to socket ";
} else {
echo "no data in the buffer " ;
}
// 从客户端取得信息
while ($data = @socket_read($connection, 1024, php_normal_read)) {
printf("buffer: " . $data . " ");
//取得信息给客户端一个反馈
socket_write($connection, "information received ");
}
}
socket_close($connection);
//关闭 socket
printf("closed the socket ");
}
?>
三,socket客户端client.php
<?php
// 建立客户端的socet连接
$socket = socket_create(af_inet, sock_stream, sol_tcp);
$connection = socket_connect($socket, '127.0.0.1', 10008); //连接服务器端socket
while ($buffer = @socket_read($socket, 1024, php_normal_read)) {
//服务端告诉客户端,自己的状态
if (preg_match("/not connect/",$buffer)) {
echo "don`t connect ";
break;
} else {
//服务器传来信息
echo "buffer data: " . $buffer . " ";
echo "writing to socket ";
// 将客户的信息写到通道中,传给服务器端
if (!socket_write($socket, "some data ")) {
echo "write failed ";
}
//服务器端收到信息后,给于的回应信息
while ($buffer = socket_read($socket, 1024, php_normal_read)) {
echo "sent to server: some data response from server was:" . $buffer . " ";
}
}
}
?>
四,通信机制的一个图片(不考虑等待时间结束自动关闭socket)
简单说明一下,在说明前我要说一下,为什么要用php命令来执行服务器和客户端,客户端你用fsockopen,这样就在流览器上访问了,不至少于会连接超时。为什么会这样呢,因为你创建一个socket时,它会不断的去监听客户有没有要来连接。
socket通信的建立要二个socket通道,一个是服务器端创建的,一个是客户端创建的。
1号线,服务器创建一个socket通道,并将信息放到缓存,等待客户端连接
2号线,客户端创建一个socket通道,并连接服务器端,取得服务器端的信息进行通信,将要传的信息送入通道
3号线,服务器端从客户端取得信息,并告诉客户端,信息我已经收到了。将要传的信息送入通道
4号线,客户端从服务器端取得确认信息
到此一个通信就完全建立了,数据传输完毕后,服务器端会断开socket通信,具体操作如下
1,运行socket服务器端
[root@blackghost zhangy]# /usr/local/php/bin/php -a /home/zhangy/www/test2/server.php
interactive mode enabled
这一点做了那些工作呢
a,监听了一个10008端口
[zhangy@blackghost ~]$ netstat -an |grep listen |grep 10008
tcp 0 0 127.0.0.1:10008 0.0.0.0:* listen
[zhangy@blackghost ~]$
b,将信息送到缓存里面$buffer = "connect";看上面的代码
2,运行socket客户端
[root@blackghost zhangy]# /usr/local/php/bin/php -a /home/zhangy/www/test2/client.php
interactive mode enabled
buffer data: connect
writing to socket
sent to server: some data
response from server was:information received
3,回到服务器端
[root@blackghost zhangy]# /usr/local/php/bin/php -a /home/zhangy/www/test2/server.php
interactive mode enabled
socket connected
send data to client
wrote to socket
buffer: some data
closed the socket
代码如下 | 复制代码 |
$conn=mysql教程_connect("localhost","root","123456"); $pagesize=4;//设定每一页显示的记录数 mysql_select_db("ly",$conn); $rs=mysql_query("select count(*) from lyb",$conn);//取得记录总数$rs,计算总页数用 $myrow = mysql_fetch_array($rs); $numrows=$myrow[0]; $pages=intval($numrows/$pagesize);//计算总页数 if ($numrows%$pagesize) $pages++; //设置页数 if (isset($_get['page'])){ $page=intval($_get['page']);} else{ //设置为第一页 $page=1; } //计算记录偏移量 $offset=$pagesize*($page - 1); //读取指定记录数 $rs=mysql_query("select * from lyb order by id desc limit $offset,$pagesize",$conn); if ($myrow = mysql_fetch_array($rs)) { $i=0; ?> <table border="0" width="80%"> </tr> <?php do { $i++; ?> <td width="10%"><?=$myrow["nichen"]?></td> <?php } while ($myrow = mysql_fetch_array($rs)); echo "</tr></table>"; } |
方法一
$txt=$_get['url'];
echo referfile($txt,'http://www.111cn.net/');
function referfile($url,$refer='') {
$opt=array('http'=>array('header'=>"referer:$refer"));
$context=stream_context_create($opt);
header("location:".$url);
return file_get_contents($url,false,$context);
}
<?php
$host = "pakey.net"; //你要访问的域名
$target = "/test.asp教程"; //你要访问的页面地址
$referer = "http//uuwar.com/"; //伪造来路页面
$fp = fsockopen($host, 80, $errno, $errstr, 30);
if(!$fp){
echo "$errstr($errno)<br /> ";
}else{
$out = "
get $target http/1.1
host: $host
referer: $referer
connection: close ";
fwrite($fp, $out);
while(!feof($fp)){
echo fgets($fp, 1024);
}
fclose($fp);
}
?>
其它方法
<?
$url=str_replace('/file.php/','',$_server["request_uri"]);//得出需要转换的网址。这里我就偷懒,不做安全检测了,需要的自己加上去
$downfile=str_replace(" ","%20",$url);//替换空格之类,可以根据实际情况进行替换
$downfile=str_replace("http://","",$downfile);//去掉http://
$urlarr=explode("/",$downfile);//以"/"分解出域名
$domain=$urlarr[0];//域名
$getfile=str_replace($urlarr[0],'',$downfile);//得出header中的get部分
$content = @fsockopen("$domain", 80, $errno, $errstr, 12);//连接目标主机
if (!$content){//链接不上就提示错误
die("对不起,无法连接上 $domain 。");
}
fputs($content, "get $getfile http/1.0rn");
fputs($content, "host: $domainrn");
fputs($content, "referer: $domainrn");//伪造部分
fputs($content, "user-agent: mozilla/4.0 (compatible; msie 6.0; windows nt 5.1)rnrn");
while (!feof($content)) {
$tp.=fgets($content, 128);
if (strstr($tp,"200 ok")){ //这里要说明一下。header的第一行一般是请求文件的状态。具体请参照http 1.1状态代码及其含义 hi.baidu.com/110911/blog/item/21f20d2475af812ed50742c5.html这里是正常的文件请求状态,只需直接转向就可以。其他状态的继续执行程序
header("location:$url");
die();
}
}
//302 转向,大部分的防盗链系统都是先判断referfer,对了的话再转向真实的地址。下面就是获取真实的地址。
$arr=explode("n",$tp);
$arr1=explode("location: ",$tp);//分解出location后面的真时地址
$arr2=explode("n",$arr1[1]);
header('content-type:application/force-download');//强制下载
header("location:".$arr2[0]);//转向目标地址
die();
?>