1. はじめに:
Empire CMS は強力なカスタム フィールド処理機能を提供し、ユーザーによる Imperial CMS の二次開発を大幅に容易にします。
Empire CMSでは、フィールドの追加・変更時に「バックグラウンドでの情報処理機能の追加」、「バックグラウンドでの情報処理機能の変更」、「フロントデスクでの情報処理機能の追加」、「変更」を設定することができます。フィールドコンテンツの格納形式に特殊な要件がある機種でよく使用される、フィールドコンテンツを処理するための関数を設定します。今回は処理関数の生成形式について簡単に説明します。フィールド処理関数の具体的な設定位置を次の図に示します:
2. 基本的な設定手順:
1. 処理関数を記述します。
2. e/class/userfun.php ファイルの内容に関数をコピーします;
3. フィールド設定処理関数名を変更します。
3. フィールド処理関数の形式:
コードは次のとおりです:
function user_FieldFun($mid,$f,$isadd,$isq,$value,$ cs){
return $value;
}
パラメータの説明:
user_FieldFun: 関数名
$mid: システム モデル ID
$f: フィールド名
$isadd: 値が 0 の場合は情報の追加、値が 1 の場合は情報の変更
$isq: 値が 0 の場合はバックグラウンド処理、値が 1 の場合は情報の変更1の場合はフォアグラウンド処理です
$value: フィールドの元の内容
$cs: フィールド追加パラメータ、フィールド処理関数で設定されたパラメータの内容
バックエンド フィールド関数の設定: user_AddTitle
#コードは次のとおりです:
function user_AddTitle($mid,$f,$isadd,$isq,$value,$cs){
$value='[EmpireCMS]'.$value;return $value;
}
例 2: タイトル コンテンツは、writer フィールドと befrom フィールドの組み合わせによって設定されます。
タイトル フィールドには、HTML コードが表示されます:
(注: タイトルは必須項目であるため、初期値を指定する必要があります。内容が空であることを示すプロンプトが表示されます)
#コードは次のとおりです:
$value=$_POST['writer' ].$_POST['befrom'];
return $value;}
例 3: 画像をアップロードしてサムネイルを自動生成
背景フィールド関数の設定: user_TranImgAuto##170,120
画像のアップロード フィールドには HTML コードが表示されます:
(注: 変数名には、関数の「$filetf」変数に対応する「フィールド名」imgrs が使用されます)
コードは次のようになります:
function user_TranImgAuto($mid,$f,$isadd,$isq,$value,$cs){
global $empire,$dbtbpre,$public_r,$emod_r,$class_r,$tranpicturetype,$musername;
$filetf=$f.'imgrs';//变量名
if(!$_FILES[$filetf]['name'])
{
return '';
}
$classid=(int)$_POST['classid'];
$id=(int)$_POST['id'];
$filepass=(int)$_POST['filepass'] ;
$filetype=GetFiletype($_FILES[$filetf]['name']);
$pr=$empire->fetch1("select qaddtran,qaddtransize,qaddtranimgtype from {$dbtbpre}enewspublic 制限 1 ");
if(!$pr['qaddtran'])
{
printerror("CloseQTranPic","",1);
}
if(!strstr($pr ['qaddtranimgtype'],"|".$filetype."|"))
{
printerror("NotQTranFiletype","",1);
}
if($_FILES[$ filetf]['size']>$pr['qaddtransize']*1024)
{
printerror("TooBigQTranFile","",1);
}
if(!strstr( $tranpicturetype,','.$filetype.','))
{
printerror("NotQTranFiletype","",1);
}
$tfr=DoTranFile($_FILES[$ filetf]['tmp_name'],$_FILES[$filetf]['name'],$_FILES[$filetf]['type'],$_FILES[$filetf]['size'],$classid);
if($tfr['tran'])
{
$csr=explode(',',$cs);
$maxwidth=$csr[0];
$maxheight=$ csr[1];
$yname=$tfr['yname'];
$name=$tfr['name'];
include_once(ECMS_PATH.'e/class/gd.php') ;
// 生成缩图
$filer=ResizeImage($yname,$name,$maxwidth,$maxheight,$public_r['spickill']);
DelFiletext($yname);
if($filer['file'])
{
//写量据库
$type=1;
$filetime=date("Y-m-d H:i:s");
$filesize=@filesize($filer['file']);
$filename=GetFilename(str_replace(ECMS_PATH,'',$filer['file']));
$adduser='[メンバー] ]'.$musername;
$infoid=$isadd==1?0:$id;
$empire->query("{$dbtbpre}enewsfile に挿入(filename,filesize,adduser,path, filetime,classid,no,type,id,cjid,fpath)values('$filename','$filesize','$adduser','$tfr[filepath]','$filetime','$classid',' [".$f."]".addslashes(RepPostStr($_POST[title]))."','$type','$infoid','$filepass','$public_r[fpath]');" );
if($isadd==0)
{
$tbname=$emod_r[$mid]['tbname'];
if(strstr($emod_r[$mid][' tbdataf'],','.$f.','))
{
$ir=$empire->fetch1("select stb from {$dbtbpre}ecms_".$tbname." ここで id ='$id'");
$ifr=$empire->fetch1("{$dbtbpre}ecms_".$tbname."_data_".$ir[stb] から ".$f." を選択します。 " where id='$id'");
$ifval=$ifr[$f];
}
else
{
$ir=$empire->fetch1(" select ".$f." from {$dbtbpre}ecms_".$tbname." where id='$id'");
$ifval=$ir[$f];
}
if ($ifval)
{
DelYQTranFile($classid,$id,$ifval,$f);
}
}
$value=str_replace($tfr['filename'], $filename,$tfr['url']);
}
}
else
{
$value='';
}
return $value;
}
以上がImperial CMS機能の復号化のフィールド処理機能の詳細説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。