织梦搜索实现标题完全精准搜索方法

织梦搜索实现标题完全精准搜索,就是搜索文档标题必须一模一样才有搜索结果

实现教程

1、在 /plus/ 新建一个 so.php 文件

<?phprequire_once(dirname(__FILE__) . "/../include/common.inc.php");require_once DEDEINC . "/arc.partview.class.php";if ($title == '')
{
    ShowMsg('关键字不能为空!', '-1');
    exit();
}
$row = $dsql->GetOne("SELECT id FROM `dede_archives` WHERE title = '$title' ");if (is_array($row))
{
    $chRow    = $dsql->GetOne("SELECT c.addtable FROM dede_archives AS a LEFT JOIN dede_channeltype AS c ON a.channel=c.id where a.id='{$row['id']}'");
    $addtable = trim($chRow['addtable']);
    $result   = $dsql->GetOne("SELECT arc.*,addf.* FROM `dede_archives` arc LEFT JOIN `{$addtable}` addf ON arc.id=addf.aid WHERE arc.arcrank>-1 AND arc.id = '{$row['id']}'");
    $pv       = new PartView();
    foreach ($result as $k => $v)
    {
        $pv->Fields[$k] = $v;
    }
    $pv->SetTemplet($cfg_basedir . $cfg_templets_dir . "/" . $cfg_df_style . "/so.htm");
    $pv->Display();
}else{
    ShowMsg('没有相关记录!', '-1');
}exit();

2、你的模板文件夹里添加1个 so.htm 模板文件

例如 /templets/default/so.htm

<div>

    <p>标题:{dede:field.title /}</p>

    <p>缩略图:{dede:field.litpic /}</p>

    <p>品牌:{dede:field.pinpai /}</p>

    <p>货号:{dede:field.huohao /}</p>

    <p>价格:{dede:field.jiage /}</p>

    <p>内容:{dede:field.body /}</p>

</div>

可调用所有字段包括自定义字段

3、前台模板搜索框代码

<form  method=”post” action=”{dede:global.cfg_cmspath/}/plus/so.php” >

    <div id=”search_box”>

        <p>标题精准搜索:<input type=”text” name=”title” value=”” /></p>

        <input type=”submit” name=”submit” value=”开始搜索”  />

    </div>

</form>

注意:name=”title”   不是 name=”q”