首页 开发编程 正文

php数据匹配怎么做

//获取页面代码$rs=file_get_contents($url);//emotion.pclady.com.cn/skills/0903/376476.html"target=_blank>...

php数据匹配怎么做,php信息申请代码?

//采集首页地址

$url="http://emotion.pclady.com.cn/skills/";

//获取页面代码

$rs=file_get_contents($url);

//设置匹配正则

//$fp=fopen("text.txt","a");

//$fw=fwrite($fp,$rs);

//fclose($fp);

/*<I class=titles><A

href="http://emotion.pclady.com.cn/skills/0903/376476.html"

target=_blank>留住你身边的好男人</A></I>*/

$preg='/<i\s+class=\"titles\"><a\s+href=\"[^>]+\">(.*)<\/a><\/i>/i';

//进行正则搜索

preg_match_all($preg,$rs,$title);

//计算标题数量

$count=count($title[0]);

echo $count."<br>";

//通过标题数量进行内容采集

for ($i=0;$i<$count;$i++){

//设置内容页地址

$pr='/<a\s+href=\"[^>]+\">/isU';

preg_match_all($pr,$title[0][$i],$jurl);

$substr=substr($jurl[0][0],9);

$curl=substr($substr,0,-18);

//获取内容页代码

$c=file_get_contents($curl);

//设置内容页匹配正则

$pc='/<a\s+href=\"[^>]+\">/i';

//进行正则匹配搜索

preg_match($pc,$c,$content);

//输出标题

echo $title[0][$i]."<br>";

echo $title[1][$i]."<br>";

$concount=count($content[0]);

echo $concount."<br>";

echo $content[0][0];

for ($j=0;$j<$concount;$j++){

}

}

有哪些好玩的网站可以分享?

窥探别人的记忆、舔狗日记,在线玩游戏……分享10个不容错过的奇怪网站,总有一个让你一眼爱上!

考虑到大家记不住这么多网站,所以我把下文推荐的所有网站的站点,都收集到一个导航栏里:

除了本文的网站,上面还有超级多的各类网站:

获取导航栏看这里:打开微信,搜索微信公众号【PPT狂想曲】,私信【网站导航栏】,就可以啦1.OSU戳泡泡

网址:http://osugame.online/

一款可以在线玩的音乐节奏游戏。

点击谱面,选择难易程度,就可以玩啦!按键默认是鼠标左右键和Z、X键,可以在设置中修改。

操作简单,右上角的常见问题,也能为你提供帮助哦!

站内提供不少风格、语言的谱面,目前还不支持用户从本地上传,不过开发者已经开始研究这个功能了!

今天刚玩,有点小辣鸡:

2.诺基亚短信图片生成

网址:https://zzkia.noddl.me/

一个生成诺基亚短信表情包的网站。

操作非常简单,输入内容,点击生成就可以了!

支持保存图片:

3.时间胶囊——给未来

网址:http://p.timepill.net/

一个帮你记录此刻、分享给未来的网站。

你可以写给未来的自己、朋友或家人,相信这也是一段美好的回忆!

填上自己的名字,邮箱(便于网站提醒你),胶囊内容(不能超过500字),设置好时间胶囊的打开时间、未到期提示信息,点击添加,你就拥有了一颗自己的时间胶囊!

添加成功之后,会出现一串Key(04b3-33ae-01c6-bd5b-91d6),大家一定要保存好。

支持自己复制后保存,也可以分享给朋友。

如果你想提前打开胶囊,网站会告诉你打开时间距离现在有多少秒,还有一串提示,嘿嘿!

4.动态全球地图

网址:https://earth.nullschool.net/

一个可以看到全球风、天气、海洋和污染情况的网站。

网站里简简单单,黑色背景下只有一个变化的地球。鼠标随意拖动,就能看到360度无死角的地球全貌。可以更直观地浏览地球上的风、天气、海洋和污染情况等,数据每3个小时更新一次!

支持浏览多种模式:空气、海洋、化学、颗粒物、空间(可见极光的地方);还能分别看到1000,850,700,500,250,70和10海拔时的地球表面的风力、温度等变化;

点击“叠加”中的温度,可以看到全球的温度分布:

还能在上面看到2013时的地球温度、洋流变化,支持放大观看细节!

会玩的可以将它录制成一段视频,放在PPT中做背景,绝对能惊艳全场!

虽然不能再发现新大陆,但是这个网站真的是让我眼前一亮!

考虑到大家记不住这么多网站,所以我把下文推荐的所有网站的站点,都收集到一个导航栏里:

除了本文的网站,上面还有超级多的各类网站:

获取导航栏看这里:打开微信,搜索微信公众号【PPT狂想曲】,私信【网站导航栏】,就可以啦5.Mikutap

由日本一个音乐人制作的网站,敲击键盘字母A-Z,就会发出不同的声音,网站上也能够出现不同的图案。

制作灵感来源于这个网站patatap,但是Mikutap的声音是来自初音未来的,所以,创造出来的声音更受欢迎一些。

你还可以借助鼠标,点击网站页面的不同位置,也能发出不同的声音哦。一不小心就玩了俩小时,同事还以为我在努力码字。

6.在线玩贪吃蛇

网址:http://slither.io/

一个在线版的贪吃蛇游戏。

随着你不断的进食,你的身体也会不断变大,游戏唯一的规则就是你的头不能碰到别人的身体部分。

而你可以使用自己身体的优势,让别人碰你,这样,它就会成为你的食物了。

7.Firefox Send

一个超好用的分享神器!

最近非常喜欢的一个网站,比百度云好用得多!平时传输文件时,微信有限制,只能100M以下,所以有些大文件传输起来就非常麻烦,但是这个网站最大可以传输1G!

8.Wallhaven

网址:Top Wallpapers wallhaven.cc

一个提供高清壁纸的网站。

虽然就提供了三个分类,一般,动漫和人物,但是里面的图片质量很高,数量也很多。

你还可以看到网站内最受欢迎的壁纸:

9.恐龙快跑

网站:chrome://dino/

这个在严格意义上不算是网站,如果你之前有过断网的情况,你可能也见过这个画面:

但你知道吗?

在这个界面敲一下空格,就可以进入一个小游戏了:

但是,也不用拔掉网线。输入网址:chrome://dino/,就可以无限畅玩恐龙快跑了。

10、舔狗日记

网址:http://tg.94275.cn/#

听名字就知道,这个网站会随机生成舔狗语录。

建议别轻易点开,因为真的很舔狗!我怕你看了扎心~

11、百度的镜面

网址:https://udiab.net/

没错,这个网站展示的就是镜子里面的百度!

唯一的用处就是可以整蛊你的朋友,趁她不注意,偷偷在她电脑上打开这个网站。期待你们在评论区晒出朋友的反应!

特别是和女朋友吵架的时候,哈哈哈你懂得!

最后,考虑到大家记不住这么多网站,所以我把下文推荐的所有网站的站点,都收集到一个导航栏里:

除了本文的网站,上面还有超级多的各类网站:

获取导航栏看这里:打开微信,搜索微信公众号【PPT狂想曲】,私信【网站导航栏】,就可以啦

最近在搜寻一些新的有趣网站,如果点赞多的话,我会回来更新哦!

欢迎关注我的头条号 @PPT狂想曲 ,浏览主页,还可以了解到更多高效神器哦~

php如何获取客户端信息?

代码入下,只做参考

class userPCInfo{

//获取客户端浏览器

public static function get_client_browser(){

$sys = $_SERVER['HTTP_USER_AGENT']; //获取用户代理字符串

if (stripos($sys, "Firefox/") > 0) {

preg_match("/Firefox\/([^;)]+)+/i", $sys, $b);

$exp[0] = "Firefox";

$exp[1] = $b[1]; //获取火狐浏览器的版本号

} elseif (stripos($sys, "Maxthon") > 0) {

preg_match("/Maxthon\/([\d\.]+)/", $sys, $aoyou);

$exp[0] = "傲游";

$exp[1] = $aoyou[1];

} elseif (stripos($sys, "MSIE") > 0) {

preg_match("/MSIE\s+([^;)]+)+/i", $sys, $ie);

$exp[0] = "IE";

$exp[1] = $ie[1]; //获取IE的版本号

} elseif (stripos($sys, "OPR") > 0) {

preg_match("/OPR\/([\d\.]+)/", $sys, $opera);

$exp[0] = "Opera";

$exp[1] = $opera[1];

} elseif(stripos($sys, "Edge") > 0) {

//win10 Edge浏览器 添加了chrome内核标记 在判断Chrome之前匹配

preg_match("/Edge\/([\d\.]+)/", $sys, $Edge);

$exp[0] = "Edge";

$exp[1] = $Edge[1];

} elseif (stripos($sys, "Chrome") > 0) {

preg_match("/Chrome\/([\d\.]+)/", $sys, $google);

$exp[0] = "Chrome";

$exp[1] = $google[1]; //获取google chrome的版本号

} elseif(stripos($sys,'rv:')>0 && stripos($sys,'Gecko')>0){

preg_match("/rv:([\d\.]+)/", $sys, $IE);

$exp[0] = "IE";

$exp[1] = $IE[1];

}else {

$exp[0] = "未知浏览器";

$exp[1] = "";

}

return $exp;

}

//获取客户端操作系统

public static function get_client_os(){

$agent = $_SERVER['HTTP_USER_AGENT'];

$os = false;

if (preg_match('/win/i', $agent) && strpos($agent, '95')){

$os = 'Windows 95';

}else if (preg_match('/win 9x/i', $agent) && strpos($agent, '4.90')){

$os = 'Windows ME';

}else if (preg_match('/win/i', $agent) && preg_match('/98/i', $agent)){

$os = 'Windows 98';

}else if (preg_match('/win/i', $agent) && preg_match('/nt 6.0/i', $agent)){

$os = 'Windows Vista';

}else if (preg_match('/win/i', $agent) && preg_match('/nt 6.1/i', $agent)){

$os = 'Windows 7';

}else if (preg_match('/win/i', $agent) && preg_match('/nt 6.2/i', $agent)){

$os = 'Windows 8';

}else if(preg_match('/win/i', $agent) && preg_match('/nt 10.0/i', $agent)){

$os = 'Windows 10';#添加win10判断

}else if (preg_match('/win/i', $agent) && preg_match('/nt 5.1/i', $agent)){

$os = 'Windows XP';

}else if (preg_match('/win/i', $agent) && preg_match('/nt 5/i', $agent)){

$os = 'Windows 2000';

}else if (preg_match('/win/i', $agent) && preg_match('/nt/i', $agent)){

$os = 'Windows NT';

}else if (preg_match('/win/i', $agent) && preg_match('/32/i', $agent)){

$os = 'Windows 32';

}else if (preg_match('/linux/i', $agent)){

$os = 'Linux';

}else if (preg_match('/unix/i', $agent)){

$os = 'Unix';

}else if (preg_match('/sun/i', $agent) && preg_match('/os/i', $agent)){

$os = 'SunOS';

}else if (preg_match('/ibm/i', $agent) && preg_match('/os/i', $agent)){

$os = 'IBM OS/2';

}else if (preg_match('/Mac/i', $agent) && preg_match('/PC/i', $agent)){

$os = 'Macintosh';

}else if (preg_match('/PowerPC/i', $agent)){

$os = 'PowerPC';

}else if (preg_match('/AIX/i', $agent)){

$os = 'AIX';

}else if (preg_match('/HPUX/i', $agent)){

$os = 'HPUX';

}else if (preg_match('/NetBSD/i', $agent)){

$os = 'NetBSD';

}else if (preg_match('/BSD/i', $agent)){

$os = 'BSD';

}else if (preg_match('/OSF1/i', $agent)){

$os = 'OSF1';

}else if (preg_match('/IRIX/i', $agent)){

$os = 'IRIX';

}else if (preg_match('/FreeBSD/i', $agent)){

$os = 'FreeBSD';

}else if (preg_match('/teleport/i', $agent)){

$os = 'teleport';

}else if (preg_match('/flashget/i', $agent)){

$os = 'flashget';

}else if (preg_match('/webzip/i', $agent)){

$os = 'webzip';

}else if (preg_match('/offline/i', $agent)){

$os = 'offline';

}else{

$os = '未知操作系统';

}

return $os;

}

//获取ip地址

public static function get_ip() {

//判断服务器是否允许$_SERVER

if (isset($_SERVER)) {

if (isset($_SERVER['HTTP_X_FORWARDED_FOR'])) {

$realip = $_SERVER['HTTP_X_FORWARDED_FOR'];

} elseif (isset($_SERVER['HTTP_CLIENT_IP'])) {

$realip = $_SERVER['HTTP_CLIENT_IP'];

} else {

$realip = $_SERVER['REMOTE_ADDR'];

}

} else {

//不允许就使用getenv获取

if (getenv("HTTP_X_FORWARDED_FOR")) {

$realip = getenv("HTTP_X_FORWARDED_FOR");

} elseif (getenv("HTTP_CLIENT_IP")) {

$realip = getenv("HTTP_CLIENT_IP");

} else {

$realip = getenv("REMOTE_ADDR");

}

}

return $realip;

}

//获取当前ip所在城市

public static function GetIpLookup($ip = ''){

if(empty($ip)){

return '请输入IP地址';

}

$test= 'http://ip.taobao.com/service/getIpInfo.php?ip='.$ip;

$res = @file_get_contents($test);

return $res;

}

}

PHP用1个函数实现post请求?

引言

前天的文章,我们说到了如何高效的下载网络资源,对于小体积的文件。可以便捷的使用 file_put_contents() 进行请求。与之配对的函数 file_get_contents() 则是读取资源。

今天我们讨论一下,有没有一种可能,使用一个函数,就可以给服务器发送post请求的数据呢?

学习时间

上一段中我们已经提示了,有一个函数可以用于读取网络资源,也就是间接的发起网络请求。默认 file_get_contents()是使用 GET 请求,如果是POST请求按道理也应该做的来。不过要怎么写呢?

file_get_contents() 函数是用来将文件的内容读入到一个字符串中的首选方法。如果操作系统支持还会使用内存映射技术来增强性能。

其参数形式如下:

string file_get_contents( string $filename[, bool $use_include_path = false[, resource $context[, int $offset = -1[, int $maxlen]]]] )

复杂的功能,我们需要组装后面的参数即可。我们需要使用流操作的上下文 context,传入该函数。

首先构造请求的参数,也就是键值对,这里需要使用 & 进行多参数连接:

$postdata = http_build_query( array( 'name' => 'joe', 'age' => '13' ) );

接着构造请求结构体:

$opts = array('http' => array( 'method' => 'POST', 'header' => 'Content-Type: application/x-www-form-urlencoded', 'content' => $postdata ) );

最重要的一步,创建基于流的上下文,使用

$context = stream_context_create($opts);

写到这里就“万事俱备只欠东风”了。我们隆重地清楚主旨函数处理这些参数:

$result = file_get_contents('http://example.com/submit.php', false, $context);

之后结果,或者错误内容,就会输出到 $result 对象。使用 false 判断,或者使用已知的接口返回数据类型,进一步处理。

深度定制

上一节的内容并没有考虑网络超时,接口授权,等等情形。本节我们说一个复杂度高一些的,要求处理一个https请求,并配置了 basic auth 的 url,并使用 post 上传数据。

首先还是裁剪请求体:

$opts = array('http' => array( 'method' => 'POST', 'header' => "Content-Type: text/xml\r\n.Authorization: Basic ".base64_encode("$https_user:$https_password")."\r\n", 'content' => $body, 'timeout' => 60 ) );

注意我们在请求上添加了 header,这是根据目标 url 的要求添加的。$body 就是上一节中的 $postdata 结构类型。

接着创建流上下文:

$context = stream_context_create($opts);

最后调用函数:

$url = 'https://'.$https_server;

$result = file_get_contents($url, false, $context, -1, 40000);

写在最后

通过上面两个细节的函数处理,大家是不是对 file_get_contents() 有了更加深入的看法,原来这家伙还可以这么用,真是开了眼界!

Happy coding :_)

我是 @程序员小助手 ,持续分享编程知识,欢迎关注。

该如何学习大数据知识?

学习大数据的步骤:

1、要明白自己为什么要学习大数据,自己学习大数据的目的是什么?找到自己学习大数据的真实需求,为后续学习过程中提供足够的动力

2、了解大数据课程都要学习什么

3、报名大数据培训班

4、坚持学习,不放弃

5、项目开发实训

6、工作

大数据学习之路

大数据课程大纲奉上,供你参考

本文转载自互联网,如有侵权,联系删除