这里提供一种临时处理的思路:既然新浪判断了Referer,我们伪造就是了
最后用API方式调用,例如:api.php?url=新浪外链地址
远程图片
<?php/** * @description: curl_get 获取远程图片 * @param 图片url * @return: 获取到的图片文件流 */ function curl_get($url){ $ch = curl_init($url); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($ch, CURLOPT_RETURNTRANSFER, true); curl_setopt($ch, CURLOPT_USERAGENT, 'Mozilla/5.0 (Linux; U; Android 4.4.1; zh-cn; R815T Build/JOP40D) AppleWebKit/533.1 (KHTML, like Gecko)Version/4.0 M *** Browser/4.5 Mobile Safari/533.1'); curl_setopt($ch, CURLOPT_TIMEOUT, 10); $content = curl_exec($ch); curl_close($ch); return ($content);}/** * @description: 对传入的URL做安全化处理 * @param 图片URL * @return: 如果不安全 则退出;反之返回原url */ function waf($url){ if (is_array($url)) { return false; } $blacklist = array('file', 'dict', 'gopher', 'php', '///', './'); foreach ($blacklist as $key) { if (stripos($url, $key) !== false) return false; } if (stripos(parse_url($url, PHP_URL_HOST), "sinaimg.cn") == false) { return false; } return $url;} @$url = $_GET['url']; /**判断REFERER 防止他人盗取. */ if (isset($_SERVER['HTTP_REFERER'])) { if (stripos($_SERVER['HTTP_REFERER'], $_SERVER['HTTP_HOST']) === false) { die("Error"); }}if ($url = waf($url)) { header("Content-Type: image/jpeg;text/html; charset=utf-8"); echo curl_get($url);} else { die("ERroR");}
转载于蓝优博客 https://umqun.com/Code/16.html
微信域名安全检测API PHP源码 感谢蓝优提供源码 这是一个很简单操作,利用跳转检测是否和域名一致。调用:域名/api.php?url= <?php /** --------...
1.主要原理用到了php的post和if函数 if($_POST["password"] == right_pwd) 2.我们需要输入一次后某时间段不失效就用到了cookies, setcook...
<?php // 实例1 /** * @start time */ function proStartTime() { global $startTime; $mtime1...
效果是这样滴~ <meta http-equiv="refresh" content="1;url='<?php echo $url;?>';"> content是跳转时间...
本文是介绍:Emlog如何实现主分类以及子分类显示该分类全部分类和分类高亮 我们知道要查询子分类很简单,只需要写一下sql查询一下哪个分类的pid是主分类ID 但是此方法到了子分类就会不显示或者出错,...
laysns资源网系统今日文章时间加红 只需要写一个判断,那如果今日未发文则显示昨日时间加红怎么实现呢? 首先laysns资源网系统新版增加了一个 $todayPublishNum 函...