PHP获得跳转的真实地址实例

取得Response Headers,之后慢慢分析就行了。

给出具体实现方法:

 代码如下 复制代码

$header = get_headers($url, 1);
if (strpos($header[0], ’301′) || strpos($header[0], ’302′)) {
if (is_array($header['Location'])) {
return $header['Location'][count($header['Location'])-1];
} else {
return $header['Location'];
}
} else {
return $url;
}

实例二

 代码如下 复制代码

<?php
//
echo get_redirect_url('http://www.111cN.nEt');
//输出结果为:http://code.google.com/android/
function get_redirect_url($url){
    $redirect_url = null;

    $url_parts = @parse_url($url);
    if (!$url_parts) return false;
    if (!isset($url_parts['host'])) return false; //can't process relative URLs
    if (!isset($url_parts['path'])) $url_parts['path'] = '/';

    $sock = fsockopen($url_parts['host'], (isset($url_parts['port']) ? (int)$url_parts['port'] : 80), $errno, $errstr, 30);
    if (!$sock) return false;

    $request = "HEAD " . $url_parts['path'] . (isset($url_parts['query']) ? '?'.$url_parts['query'] : '') . " HTTP/1.1rn";
    $request .= 'Host: ' . $url_parts['host'] . "rn";
    $request .= "Connection: Closernrn";
    fwrite($sock, $request);
    $response = '';
    while(!feof($sock)) $response .= fread($sock, 8192);
    fclose($sock);

    if (preg_match('/^Location: (.+?)$/m', $response, $matches)){
        if ( substr($matches[1], 0, 1) == "/" )
            return $url_parts['scheme'] . "://" . $url_parts['host'] . trim($matches[1]);
        else
            return trim($matches[1]);

    } else {
        return false;
    }

}

时间: 2024-09-20 07:59:31

PHP获得跳转的真实地址实例的相关文章

PHP使用CURL获取302跳转后的地址实例

  这篇文章主要介绍了PHP使用CURL获取302跳转后的地址实例,需要的朋友可以参考下 直接上代码: 代码如下: /*返回一个302地址*/ function curl_post_302($url, $vars) { $ch = curl_init(); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_POST, 1); curl

PHP使用CURL获取302跳转后的地址实例_php实例

直接上代码: 复制代码 代码如下:       /*返回一个302地址*/     function  curl_post_302($url, $vars) {           $ch = curl_init();          curl_setopt($ch,  CURLOPT_RETURNTRANSFER, 1);          curl_setopt($ch, CURLOPT_URL,  $url);          curl_setopt($ch, CURLOPT_POST

url-php 如何获取短链接跳转后的真实地址?

问题描述 php 如何获取短链接跳转后的真实地址? 最后在做一个项目,需要获取[手机淘宝分享]的短链接 跳转后的最终URL,需要从这个URL中拿到商品的ID. 在网上也淘了不少办法,但不成功. 短链接:http://b.mashort.cn/h.OhrnJ?cv=AADRopTu&sm=eeb5d6 希望有位能帮我解答一下.谢谢 解决方案 http://my.oschina.net/baiduapi/blog/299228 解决方案二: $url='http://b.mashort.cn/h.O

php获取本机真实IP地址实例代码_php技巧

本文实例为大家分享了php获取本机真实IP地址实例代码,供大家参考. 主要是获取操作系统为win2000/xp.win7的本机IP真实地址,和获取操作系统为linux类型的本机IP真实地址,具体内容如下 function getLocalIP() { $preg = "/\A((([0-9]?[0-9])|(1[0-9]{2})|(2[0-4][0-9])|(25[0-5]))\.){3}(([0-9]?[0-9])|(1[0-9]{2})|(2[0-4][0-9])|(25[0-5]))\Z/

获取软件下载的真实地址!再谈获取Response.redirect重定向的URL_应用技巧

http://www.im286.com/viewthread.php?tid=1550010&extra=page%3D1 其实这个问题落伍谈了n次了其中care4也说了两次所以如果你有问题最好先搜索一下 说不定问题早有人解决了http://www.im286.com/viewthread. ... ;highlight=%2Bcare4http://www.im286.com/viewthread. ... ;highlight=%2Bcare4care4的代码有一个小缺点 就是需要组件.第

ASP,隐藏图片的真实地址

一般情况下,网站的图片代码是这样的.<img src="./attachments/test.jpg" /> 右键点击图片,选择属性就可以看到图片的真实地址.这样就让其它网站有机可乘,盗链您网站的图片.我们可以利用一个小技巧来防止这种情况. 新建一个showimg.asp(或showimg.php)文件(本文是用asp语法,其实php除语法不同外,基本思路都是相同的),它所要做的是从request中取file的值.如下: <%    Dim filename    f

ASP二进制流方法隐藏图片文件真实地址

二进制 功能描述:上传图片文件到指定目录后,在本文件根据URL传入的文件名加上文件所在目录根据文件完整路径.再将该文件二进制数据流写入服务页面,从而达到隐藏图片真实地址防止外部引用图片的效果. 以下是引用片段:<%@LANGUAGE="VBSCRIPT" CODEPAGE="936"%> <% Option Explicit Const SysUrl="http://www.80Boby.com/uImg/" Function

如何查找视频真实地址

现在网上的影院非常丰富,但是许多新片都只提供在线观看而不允许用户下载,而由于种种原因,网速又得不到保障,看起来断断续续地,非常影响心情.经过我的一番探索,终于找出几种可以查找得到在线视频文件的真实地址的方法. 一.查看源文件法 一些网站把视频文件直接内嵌在网页式播放器中,虽然没有"点击下载"地链接,但只要你查看一下网页的源文件,其真实地址就一览无余了,具体方法,打开网页后,点击IE菜单的"查看-源文件",系统即用记事本打开了该网页的源文件,按Ctrl-F,查找&qu

ASP编程隐藏图片的真实地址

一般情况下,网站的图片代码是这样的. <img src="./attachments/test.jpg" /> 右键点击图片,选择属性就可以看到图片的真实地址.这样就让其它网站有机可乘,盗链您网站的图片.我们可以利用一个小技巧来防止这种情况. 新建一个showimg.asp(或showimg.php)文件(本文是用asp语法,其实php除语法不同外,基本思路都是相同的),它所要做的是从request中取file的值.如下: <% Dim filename filena