ホームページ >CMS チュートリアル >エンパイアCMS >Sharing Empire CMS7.0は閲覧・訪問したメンバー全員を記録する手法を実現

Sharing Empire CMS7.0は閲覧・訪問したメンバー全員を記録する手法を実現

silencement
silencement転載
2019-11-29 14:25:142350ブラウズ

Sharing Empire CMS7.0は閲覧・訪問したメンバー全員を記録する手法を実現

この記事では、ニュース システム データ テーブルを例として、閲覧および訪問したすべてのメンバーをデータベースに記録する Imperial CMS7.0 の方法について説明します。具体的な手順は次のとおりです:

1. ニュース システム データ テーブルのフィールド管理に「visituserid」フィールドを追加し、フィールド タイプは「CHAR」です。

2. 統計が必要なページの 93f0f5c25f18dab9d176bd4f6de5d30e9c3bca370b5104690d9ef395f2c5f8d1 に次のコードを追加します:

コードは次のとおりです:

<script src="[!--news.url--]/ly/jquery.js" type="text/javascript"></script>
<script>
//信息ID
var id = [!--id--];
//登陆用户
var userid = <?=$lguserid=intval(getcvar(&#39;mluserid&#39;))?>;
$(function(){
if(userid)
{
$.post(
&#39;/ly/recorduser/index.php&#39;,
{userid:userid,id:id},
"html"
);
}
})
</script>

推奨学習《 Empire cms チュートリアル

3. データ コードの追加

圧縮パッケージをダウンロードし、フォルダーを解凍してルート ディレクトリに置きます。このサイトからダウンロードできます

ファイル パス ルート ディレクトリ/ly/recorduser/index.php
index.php ファイル コード:

コードは次のとおりです:

<?php
require(&#39;../../e/class/connect.php&#39;); //引入数据库配置文件和公共函数文件
require(&#39;../../e/class/db_sql.php&#39;); //引入数据库操作文件
include(&#39;../../e/class/functions.php&#39;);
$link=db_connect(); //连接MYSQL
$empire=new mysqlquery(); //声明数据库操作类
if(!$_POST[&#39;userid&#39;])
{
exit;
}
/*
userid
visituserid
/
表名称:
栏目ID
信息ID
表名称@@@栏目ID@@@信息ID::::::
/
*/
//查询是否已有userid
if($user=$empire->fetch1("select * from {$dbtbpre}ecms_news where id = {$_POST[&#39;id&#39;]}"))
{
//格式化字符串
$visituserid="{$_POST[&#39;userid&#39;]}";
//信息分隔符
$dot=&#39;&#39;;
//判断是否已有记录数
if(strstr($user[&#39;visituserid&#39;],$visituserid))
{
//已有记录返回空
die;
}
if($user[&#39;visituserid&#39;]!=&#39;&#39;)
{
$dot=&#39;,&#39;;
}

//大于1000调记录数去掉最后的一条信息
if($user[&#39;visituserid&#39;] && substr_count($user[&#39;visituserid&#39;],$dot)>=999)
{
//去除最后一条记录数
$arr=explode(&#39;,&#39;,$user[&#39;visituserid&#39;]);
$arrvisituserid=&#39;&#39;;
$dot1=$dot;
for($i=0;$i<count($arr);$i++)
{
if($i!=(count($arr)-1))
{
if($i==(count($arr)-2))
{
$dot1=&#39;&#39;;
}
$arrvisituserid.=$arr[$i].$dot1;
}
}
$visituserid.=$dot.$arrvisituserid;
}
else
{
$visituserid.=$dot.$user[&#39;visituserid&#39;];
}
//不存在的记录数、更新表
$empire->query("update {$dbtbpre}ecms_news set `visituserid` = &#39;{$visituserid}&#39; where id = {$_POST[&#39;id&#39;]}");
}
//没有记录数插入一条
else
{
$visituserid="{$_POST[&#39;userid&#39;]}";
$sql=$empire->query(" INSERT INTO `{$dbtbpre}ecms_news` `visituserid` VALUES &#39;{$visituserid}&#39; ");
}
?>

4. ユーザーの読み取りリストを呼び出します

呼び出す必要がある場所に次のコードを追加します:

コードは次のとおりです:

<div class="ct_fw"><li>已阅人:</li>
<!--判断visituserid是否为空-->
<?php
if($navinfor[visituserid])
{
?>
<!--visituserid不为空时显示开始-->
<?php
$record=$empire->fetch1("select * from {$dbtbpre}ecms_news where id = $navinfor[id]");
if($record)
{
$info=explode(",",$record[&#39;visituserid&#39;]);
$visituserid=&#39;&#39;;
foreach($info as $v)
{
$arr=explode($v);
$sql=$empire->fetch1("select * from {$dbtbpre}enewsmember where userid = $v ");
$visituserid.="<li><a href=&#39;/e/space/?userid=$v&#39; title=&#39;点击访问{$sql[username]}的空间&#39; target=&#39;_blank&#39;>
{$sql[username]}</a></li>";
//print_r($arr);
//die;
}
}
?>
<?=$visituserid?>
<!--visituserid不为空时显示结束-->
<?php
}
else
{
?>
<!--visituserid为空时显示开始-->
<!--visituserid为空时显示结束-->
<?php
}
?>
</div>

以上です。

以上がSharing Empire CMS7.0は閲覧・訪問したメンバー全員を記録する手法を実現の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はwww.word666.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。