ホームページ >バックエンド開発 >PHPチュートリアル >Google chrome 正式版 記事抄録を自動生成するコード【PHP版】
実装内容:HTMLコードを含むテキストを切り詰めますが、包含タグが閉じていなくても問題ありません。
注: これはサーバー側で使用するための PHP バージョンです。クライアント バージョンが必要な場合は、次の記事をお読みください。
BLOG などのプログラムを作成する場合、記事の前の部分を表示する必要があることがよくあります。不適切な切り詰めにより、囲んでいるタグが破壊され、文書構造全体に損傷が生じるのではないかと心配しています。私の関数を使用すると、要求が厳しくない状況でこの問題を解決できます。
この機能がサーバー側に適用されるかクライアント側に適用されるかを誰もが考慮する必要があります。この機能は実行するとマシンへの負荷が高くなる可能性があると考えられるため、セキュリティ要件が高くない場合はクライアントに配置できます。
対応するデータベース クエリも最適化されるように、この概要をデータ テーブルの別のフィールドに配置することをお勧めします。多くの時間を費やす代わりに少しのスペースを犠牲にするのは、それでも十分に得策です。
セキュリティの問題、主にコンテンツのセキュリティについてもう一度話しましょう。クライアントが通常の要約情報を変更しようとする場合、通常、BLOG の所有者がその権限を有しており、要約と原文との間の一貫性を破壊するのは彼自身の仕事です。コンテンツ以外のセキュリティはサーバー側で解決できます。したがって、この機能はクライアント側で使用することをお勧めします。
コアコード
コードをコピー コードは次のとおりです:
// PHP 4.3以降が必要
define("BRIEF_LENGTH", 800) //記事のブリーフィングの文字数
function Generate_Brief ($text ){
global $Briefing_Length;
if(strlen($text) <= BRIEF_LENGTH ) return $text;
$Foremost = substr($text, 0, BRIEF_LENGTH);
$re = "/<( /?) (P|DIV|H1|H2|H3|H4|H5|H6|アドレス|PRE|TABLE|TR|TD|TH|INPUT|SELECT|TEXTAREA|OBJECT|A|UL|OL|LI|BASE| META|LINK |HR|BR|PARAM|IMG|AREA|INPUT|SPAN)[^>]*(>?)/i";
$Single = "/BASE|META|LINK|HR|BR|PARAM |IMG| AREA|INPUT/i";
$Stack = array(); $posStack = array();
preg_match_all($re,$Foremost,$matches, PREG_SET_ORDER | PREG_OFFSET_CAPTURE);
/* [子マッチング仕様] ]:
$matches[$i][1] : 現在の「<...>」が終了部分であるかどうかを示す「/」文字
$matches[$i][2] : 要素名
$ matches[$ i][3] : 「<...>」の右 >
for($i = 0; $i < count($matches); $i++){
if ($matches [$i][1][0] == ""){
$Elem = $matches[$i][2][0]
if(preg_match($Single,$Elem) && $matches; [$i ] [3] [0]! = "") {
続行;}}
Array_push ($ Stack, StrToupper ($ は [$ i] [2] [0] に一致します); $i][2][ 1]);
if($matches[$i][3][0] =="") ブレーク
}else{
$Stack[count($Stack)- 1]; = strtoupper($matches[$i][2][0]);
if(strcasecmp($StackTop,$End)==0){
array_pop($ POSSTACK); $ は [$ i] [3] [0] == "") {
$Foremost = $Foremost. "& GT;";
$Foremost = substr($Foremost,0,$cutpos) );
$Foremost を返します
;問題が発生した場合 (上記の関数がマルチバイト文字セットを適切にサポートしていないことがわかった場合)、次のことをわざわざ試さないでください。
コードをコピーします コードは次のとおりです:
function Generate_Brief($text){
global $Briefing_Length;
if(mb_strlen($text) < = BRIEF_LENGTH ) $text を返す;
$Foremost = mb_substr($text, 0, BRIEF_LENGTH)
$re = "<(/?)(P|DIV|H1|H2|H3|H4|H5|H6|ADDRESS) |PRE|TABLE |TR|TD|TH|INPUT|SELECT|TEXTAREA|OBJECT|A|UL|OL|LI|BASE|META|LINK|HR|BR|PARAM|IMG|AREA|INPUT|SPAN)[^> ;]*( >?)";
$Single = "/BASE|META|LINK|HR|BR|PARAM|IMG|AREA|INPUT|BR/i";
$Stack = array(); $posStack = array();
mb_ereg_search_init($Foremost, $re, 'i');
while($pos = mb_ereg_search_pos()){
$match = mb_ereg_search_getregs() /* [子マッチングの式]:
$matche [1] : A "/" "" Characting WHETHER CURRENT "& LT; ... & GT;" $ Matche [2]: 要素名「続けます; {
-1]; e $ END = MB_STRTOUPPER ($ match [2])
If (STRCASECMP, $ END) == 0);
Array_pop ($ スタック);
if (
$match[ 3] ==""){
$Foremost = mb_substr($ Foremost,0,$cutpos,"UTF-8");
$Foremost を返します
;
以上、Google Chrome 正式版 [PHP 版] の記事概要を自動生成するコードを紹介しました。PHP チュートリアルに興味のある友人の参考になれば幸いです。