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、工作
大数据学习之路大数据课程大纲奉上,供你参考