大家好,首先,我不会php,但是有个php的问题希望大家能帮我解决下,万分感谢我从一个php程序中调出一个字符串$longurl这个$longurl echo 的结果是
www.csdn.net/123456<a href=http://www.csdn.net/123456>点击此处</a>如何截取www.csdn.net/123456 这一段呢我在网上找的结果是$aa = $longurl;
preg_match("/http[^\"]*/",$aa,$bb);
echo $bb[0];但是下一段程序 我用的百度短网址api想缩短程序是$urlbd = '$bb[0]';
$result = getBaiduShortUrl($urlbd);
if ($result) {
echo '成功:'.$result;
} else {
die('失败');
}function getBaiduShortUrl($urlbd) {
$data = array(
'url' => $urlbd,
);
$baidu_url = 'http://dwz.cn/create.php';
$ret = postData($baidu_url, $data);
if ($ret) {
$ret = json_decode($ret, true);
if ($ret['status'] !== 0) {
return false;
} else {
return $ret['tinyurl'];
}
} else {
return false;
}
}
function postData($urlbd, $data) {
        $options = array(
            CURLOPT_RETURNTRANSFER  =>  true,
            CURLOPT_HEADER          =>  false,
            CURLOPT_FOLLOWLOCATION  =>  true,
            CURLOPT_ENCODING        =>  'gzip,deflate,sdch',
            CURLOPT_USERAGENT       =>  'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/535.1 (KHTML, like Gecko) Ubuntu/11.10 Chromium/14.0.835.202 Chrome/14.0.835.202 Safari/535.1',
            CURLOPT_AUTOREFERER     =>  true,
            CURLOPT_CONNECTTIMEOUT  =>  120,
            CURLOPT_TIMEOUT         =>  120,
            CURLOPT_MAXREDIRS       =>  10,
            CURLOPT_REFERER => 'http://www.baidu.com/',
            CURLOPT_POSTFIELDS =>  $data,
        );          $ch = curl_init($urlbd);
        curl_setopt_array($ch, $options);
        $content = curl_exec($ch);
        $err = curl_errno($ch);
        $errmsg = curl_error($ch);
        $header = curl_getinfo($ch);
        curl_close($ch);
        
        return $content;
}
 缩短的地址怎么也不对 请大家帮我看下好吗 

解决方案 »

  1.   

    你那个正则取不到你想要的那段吧 还有 $urlbd = '$bb[0]'; 你这样子定义 $urlbd的值就是$bb[0]这一个字符串
    要用双引号才会解析里面的变量 换成下面的
    preg_match("/<a href=http:\/\/([^\"]+)[^<>]*>.*<\/a>/i", $aa, $bb);
    $urlbd = $bb[1];
      

  2.   

    刚csdn 又怂了.如何截取www.csdn.net/123456 这一段呢你是要从 www.csdn.net/123456<a href=http://www.csdn.net/123456>点击此处</a> 
    提取www.csdn.net/123456 ?如果是的话那可不是什么缩短网址. 方法有很多,我不清楚你还有没有其他的网址情况出现,暂时这么写吧
    $str='www.csdn.net/123456<a href=http://www.csdn.net/123456>点击此处</a>';
    preg_match('/^([a-z\d\.\/]+)<a/i',$str,$match);
    $urlStr=$match[1];
    echo $urlStr;
    结果
    www.csdn.net/123456
      

  3.   

    运行你的代码没有问题 
    看下你的php.ini 中的 display_errors = On 是不是这样
      

  4.   

    代码是有问题的 运行结果:
    真实网址为:
    http://www.baidu.com/123456.html
    立即访问>> 
    http://www.baidu.com/654321.html
    立即访问>>
    http://www.baidu.com/654321.html查看源代码:最后面有个这个<a href=成功:http://dwz.cn/XlYQhttp://dwz.cn/XlYQ这个短地址再还原不是http://www.baidu.com/654321.html
    而是:http://www.baidu.com/654321.html%3Cbr/%3E%3Cb%3E%3Ca%20href=就是说缩短的网址不光是http://www.baidu.com/654321.html 还带了点别的愁人呐
      

  5.   


    ...
    http://www.baidu.com/654321.html%3Cbr/%3E%3Cb%3E%3Ca%20href=
    通过解码后就是 http://www.baidu.com/654321.html
      

  6.   

    http://www.baidu.com/654321.html  缩短之后的结果是  http://dwz.cn/XoPs而http://dwz.cn/XlYQ这个短地址还原之后的结果显示是http://www.baidu.com/654321.html其实超链接打开的是http://www.baidu.com/654321.html%3Cbr/%3E%3Cb%3E%3Ca%20href=
    我让这个超链接愁死了
      

  7.   

    www.csdn.net/123456<a href=http://www.csdn.net/123456>点击此处</a>
    若需要截取的字符都是$s1<a ....这样的话,有必要用正则吗?
    用$strArray = explode("<a", $str);分隔,这样不行吗?
      

  8.   

    楼上的哥,我不懂php,希望能给出完整点的 嘿嘿 
      

  9.   

    我的意思是:
    我从一个php程序中调出一个字符串$longurl这个$longurl echo 的结果是
    www.csdn.net/123456<a href=http://www.csdn.net/123456>点击此处</a>

    这个中的 $longurl 字符串是不是都是 {url地址<a>...</a>}这样的规律啊!是的话就可以用php的字符串分隔函数去分隔它,然后返回一个数组:
    $strArray = explode("<a", $longurl);
    print_r($strArray);你在看看结果是咋样吧
      

  10.   

    $strArray = explode("<a", $longurl);
    print_r($strArray);修改之后url中带有<br>我改成$strArray = explode("<br", $longurl);
    print_r($strArray);之后再调用就好了!!!都是神人