ホームページ > バックエンド開発 > PHPチュートリアル > PHPを介してページ内の指定されたコンテンツクラスを取得する方法

PHPを介してページ内の指定されたコンテンツクラスを取得する方法

jacklove
リリース: 2023-03-31 11:28:02
オリジナル
3862 人が閲覧しました

関数:

1. コンテンツ内の URL、電子メール、画像を取得します。

2. コンテンツ内の URL、電子メール、画像を置き換えます。

url:url">xxx

メール:admin@admin.com

image: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;;
}
?>
ログイン後にコピー

この記事では、その入手方法について説明しますthrough php ページ内の指定されたコンテンツ クラス その他の関連コンテンツについては、PHP 中国語 Web サイトに注目してください。

関連する推奨事項:

php 関連の構文スキルの紹介

php を使用して URL に基づいてサムネイルを自動的に生成する方法

phpのoutput_bufferingキャッシュを利用する方法のご紹介

以上がPHPを介してページ内の指定されたコンテンツクラスを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート