Home  >  Article  >  Backend Development  >  php gets the specified content class in the page

php gets the specified content class in the page

黄舟
黄舟Original
2017-02-18 09:33:371170browse

Function:

1. Get the url, email, and image in the content.

2. Replace the url, email, and image in the content.

url:<a href="url">xxx</a>
email:admin@admin.com
image:<img src="image">



##Grep.class. php

<?php
/** grep class
*   Date:   2013-06-15
*   Author: fdipzone
*   Ver:    1.0
*
*   Func:
*
*   set:        设置内容
*   get:        返回指定的内容
*   replace:    返回替换后的内容
*   get_pattern 根据type返回pattern
*/
class Grep{ // class start
    private $_pattern = array(
                            &#39;url&#39; => &#39;/<a.*?href="((http(s)?:\/\/).*?)".*?/si&#39;,
                            &#39;email&#39; => &#39;/([\w\-\.]+@[\w\-\.]+(\.\w+))/&#39;,
                            &#39;image&#39; => &#39;/<img.*?src=\"(http:\/\/.+\.(jpg|jpeg|gif|bmp|png))\">/i&#39;
                        );
    private $_content = &#39;&#39;; // 源内容
    /* 設置搜尋的內容
    *  @param String $content
    */
    public function set($content=&#39;&#39;){
        $this->_content = $content;
    }
    /* 获取指定内容
    *  @param String $type
    *  @param int    $unique 0:all 1:unique
    *  @return Array
    */
    public function get($type=&#39;&#39;, $unique=0){
        $type = strtolower($type);
        if($this->_content==&#39;&#39; || !in_array($type, array_keys($this->_pattern))){
            return array();
        }
        $pattern = $this->get_pattern($type); // 获取pattern
        preg_match_all($pattern, $this->_content, $matches);
        return isset($matches[1])? ( $unique==0? $matches[1] : array_unique($matches[1]) ) : array();
    }
    /* 获取替换后的内容
    *  @param String $type
    *  @param String $callback
    *  @return String
    */
    public function replace($type=&#39;&#39;, $callback=&#39;&#39;){
        $type = strtolower($type);
        if($this->_content==&#39;&#39; || !in_array($type, array_keys($this->_pattern)) || $callback==&#39;&#39;){
            return $this->_content;
        }
        $pattern = $this->get_pattern($type);
        return preg_replace_callback($pattern, $callback, $this->_content);
    }
    /* 根据type获取pattern
    *  @param String $type
    *  @return String
    */
    private function get_pattern($type){
        return $this->_pattern[$type];
    }
} // class end
?>

Demo


##

<?php
header(&#39;content-type:text/htm;charset=utf8&#39;);

require(&#39;Grep.class.php&#39;);

$content = file_get_contents(&#39;http://www.test.com/&#39;);

$obj = new Grep();
$obj->set($content);

$url = $obj->get(&#39;url&#39;, 0);
$email = $obj->get(&#39;email&#39;, 1);
$image = $obj->get(&#39;image&#39;, 1);

print_r($url);
print_r($email);
print_r($image);

$url_new = $obj->replace(&#39;url&#39;, &#39;replace_url&#39;);
echo $url_new;

function replace_url($matches){
    return isset($matches[1])? &#39;[url]&#39;.$matches[1].&#39;[/url]&#39; : &#39;&#39;;
}
?>


The above is how PHP obtains the content of the specified content type in the page. For more related content, please pay attention to the PHP Chinese website (www.php.cn)!


Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn