Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Gunakan PHP dan coreseek untuk melaksanakan fungsi carian pengetahuan perubatan yang tepat

Gunakan PHP dan coreseek untuk melaksanakan fungsi carian pengetahuan perubatan yang tepat

PHPz
PHPzasal
2023-08-07 15:34:42700semak imbas

Gunakan PHP dan coreseek untuk melaksanakan fungsi carian pengetahuan perubatan yang tepat

Gunakan PHP dan coreseek untuk melaksanakan fungsi carian pengetahuan perubatan yang tepat

Abstrak: Artikel ini memperkenalkan cara menggunakan PHP dan enjin carian coreseek untuk melaksanakan fungsi carian pengetahuan perubatan yang tepat. Dengan membina antara muka pengurusan dan antara muka carian, dan mengkonfigurasi coreseek, pembangun boleh dengan mudah melaksanakan sistem carian pengetahuan perubatan yang cekap dan fleksibel.

Kata kunci: PHP, coreseek, carian ilmu perubatan, enjin carian

Pengenalan: Dengan perkembangan pesat Internet, permintaan orang ramai terhadap pengetahuan perubatan juga semakin tinggi. Untuk memenuhi keperluan pengguna, kami berharap dapat membangunkan sistem carian pengetahuan perubatan yang cekap dan fleksibel. Di antara banyak enjin carian, coreseek ialah pilihan yang sangat popular. Artikel ini akan memperkenalkan cara menggunakan PHP dan coreseek untuk melaksanakan fungsi carian pengetahuan perubatan yang tepat.

Bahagian Pertama: Membina Antaramuka Pengurusan

Pertama, kita perlu membina antara muka pengurusan supaya pentadbir boleh menambah, mengedit dan memadam data pengetahuan perubatan dengan mudah. Kami boleh menggunakan PHP untuk membangunkan antara muka pengurusan yang mudah, termasuk fungsi berikut:

  1. Tambah pengetahuan perubatan: Pentadbir boleh menambah tajuk, kandungan dan maklumat lain pengetahuan perubatan pada antara muka pengurusan.
  2. Edit pengetahuan perubatan: Pentadbir boleh mengedit pengetahuan perubatan sedia ada pada antara muka pengurusan.
  3. Padamkan pengetahuan perubatan: Pentadbir boleh memadamkan pengetahuan perubatan sedia ada pada antara muka pengurusan.

Berikut ialah contoh kod PHP mudah untuk melaksanakan fungsi di atas:

<?php
// 连接数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "medical_knowledge";

$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("连接失败:" . $conn->connect_error);
}

// 添加医疗知识
if (isset($_POST['add'])) {
    $title = $_POST['title'];
    $content = $_POST['content'];
    
    $sql = "INSERT INTO knowledge (title, content) VALUES ('$title', '$content')";
    if ($conn->query($sql) === TRUE) {
        echo "添加成功!";
    } else {
        echo "添加失败:" . $conn->error;
    }
}

// 编辑医疗知识
if (isset($_POST['edit'])) {
    $id = $_POST['id'];
    $title = $_POST['title'];
    $content = $_POST['content'];
    
    $sql = "UPDATE knowledge SET title='$title', content='$content' WHERE id=$id";
    if ($conn->query($sql) === TRUE) {
        echo "编辑成功!";
    } else {
        echo "编辑失败:" . $conn->error;
    }
}

// 删除医疗知识
if (isset($_GET['delete'])) {
    $id = $_GET['delete'];
    
    $sql = "DELETE FROM knowledge WHERE id=$id";
    if ($conn->query($sql) === TRUE) {
        echo "删除成功!";
    } else {
        echo "删除失败:" . $conn->error;
    }
}

// 查询医疗知识
$sql = "SELECT * FROM knowledge";
$result = $conn->query($sql);
?>

<!-- 管理界面 HTML -->
<!DOCTYPE html>
<html>
<head>
    <title>医疗知识管理</title>
</head>
<body>
    <h1>医疗知识管理</h1>

    <!-- 添加医疗知识表单 -->
    <h2>添加医疗知识</h2>
    <form action="" method="POST">
        标题:<input type="text" name="title"><br>
        内容:<textarea name="content"></textarea><br>
        <input type="submit" name="add" value="添加">
    </form>

    <!-- 编辑医疗知识表单 -->
    <h2>编辑医疗知识</h2>
    <form action="" method="POST">
        <?php while($row = $result->fetch_assoc()): ?>
        ID:<input type="text" name="id" value="<?php echo $row['id']; ?>"><br>
        标题:<input type="text" name="title" value="<?php echo $row['title']; ?>"><br>
        内容:<textarea name="content"><?php echo $row['content']; ?></textarea><br>
        <input type="submit" name="edit" value="编辑">
        <a href="?delete=<?php echo $row['id']; ?>">删除</a><br>
        <?php endwhile; ?>
    </form>
</body>
</html>

<?php
// 关闭数据库连接
$conn->close();
?>

Bahagian 2: Membina antara muka carian

Selepas pentadbir menyediakan pengetahuan perubatan, kami perlu membangunkan antara muka carian supaya pengguna boleh Kata Kunci untuk mencari pengetahuan perubatan yang berkaitan. Kami juga boleh menggunakan PHP untuk membangunkan antara muka carian mudah, termasuk fungsi berikut:

  1. Cari pengetahuan perubatan: Pengguna boleh memasukkan kata kunci pada antara muka carian dan mencari dengan mengklik butang carian.
  2. Memaparkan hasil carian: Hasil carian akan dipaparkan pada antara muka carian dalam bentuk senarai, termasuk tajuk dan kandungan yang sepadan.

Berikut ialah contoh kod PHP mudah untuk melaksanakan fungsi di atas:

<?php
// 连接数据库
$servername = "localhost";
$username = "username";
$password = "password";
$dbname = "medical_knowledge";

$conn = new mysqli($servername, $username, $password, $dbname);
if ($conn->connect_error) {
    die("连接失败:" . $conn->connect_error);
}

// 搜索医疗知识
if (isset($_GET['search'])) {
    $keyword = $_GET['keyword'];
    
    // 调用coreseek搜索引擎
    $searchCmd = "/usr/local/coreseek/bin/search -i index -c /usr/local/coreseek/etc/csft.conf -q "$keyword" -n 0,20";
    exec($searchCmd, $output);
    
    // 显示搜索结果
    echo "<h2>搜索结果</h2>";
    foreach ($output as $result) {
        $resultArray = explode("    ", $result);
        $title = $resultArray[0];
        $content = $resultArray[1];
        
        echo "<h3>$title</h3>";
        echo "<p>$content</p>";
    }
}
?>

<!-- 搜索界面 HTML -->
<!DOCTYPE html>
<html>
<head>
    <title>医疗知识搜索</title>
</head>
<body>
    <h1>医疗知识搜索</h1>

    <!-- 搜索表单 -->
    <form action="" method="GET">
        <input type="text" name="keyword">
        <input type="submit" name="search" value="搜索">
    </form>
</body>
</html>

<?php
// 关闭数据库连接
$conn->close();
?>

Bahagian 3: Mengkonfigurasi coreseek

Untuk coreseek dan PHP berfungsi dengan betul, kita perlu melakukan beberapa konfigurasi terlebih dahulu. Mula-mula, kita perlu mencipta fail konfigurasi coreseek /usr/local/coreseek/etc/csft.conf dan menambah kandungan berikut dalam fail:

source medical_knowledge
{
    type                    = mysql
    sql_host                = localhost
    sql_user                = username
    sql_pass                = password
    sql_db                  = medical_knowledge
    sql_port                = 3306

    sql_query               = SELECT id, title, content FROM knowledge
    sql_attr_uint           = id
    sql_attr_str2ordinal    = title
    sql_attr_str2ordinal    = content
}

index index
{
    source                  = medical_knowledge
    path                    = /usr/local/coreseek/var/data/medical_knowledge
    min_word_len            = 1
    min_prefix_len          = 1
    enable_star             = 1
}

searchd
{
    listen                  = 9312
    log                     = /usr/local/coreseek/var/log/searchd.log
    query_log               = /usr/local/coreseek/var/log/query.log
    read_timeout            = 5
    max_children            = 30
    pid_file                = /usr/local/coreseek/var/log/searchd.pid
    seamless_rotate         = 0
    preopen_indexes         = 0
    unlink_old              = 1
}

Kemudian, kita perlu mencipta indeks untuk coreseek untuk melakukan carian yang sepadan. Buka terminal dan jalankan arahan berikut:

$ /usr/local/coreseek/bin/indexer -c /usr/local/coreseek/etc/csft.conf --all

Akhir sekali, kita perlu memulakan perkhidmatan carian coreseek. Jalankan arahan berikut dalam terminal:

$ /usr/local/coreseek/bin/searchd -c /usr/local/coreseek/etc/csft.conf

Kesimpulan: Melalui langkah di atas, kami berjaya melaksanakan fungsi carian pengetahuan perubatan yang tepat menggunakan PHP dan coreseek. Pentadbir boleh menambah, mengedit dan memadam pengetahuan perubatan melalui antara muka pengurusan, dan pengguna boleh mencari pengetahuan perubatan yang berkaitan melalui antara muka carian. Dengan mengkonfigurasi perkhidmatan pengindeksan dan carian coreseek, kami melaksanakan sistem carian pengetahuan perubatan yang cekap dan fleksibel.

Atas ialah kandungan terperinci Gunakan PHP dan coreseek untuk melaksanakan fungsi carian pengetahuan perubatan yang tepat. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn