Rumah >pembangunan bahagian belakang >tutorial php >Bagaimana untuk melaksanakan sambungan PHP ke API Baidu Wenxin Yiyan untuk mendapatkan kenyataan rawak dan memaparkannya dalam halaman

Bagaimana untuk melaksanakan sambungan PHP ke API Baidu Wenxin Yiyan untuk mendapatkan kenyataan rawak dan memaparkannya dalam halaman

WBOY
WBOYasal
2023-08-25 21:36:311019semak imbas

Bagaimana untuk melaksanakan sambungan PHP ke API Baidu Wenxin Yiyan untuk mendapatkan kenyataan rawak dan memaparkannya dalam halaman

Cara menyambungkan PHP ke Baidu Wenxin Yiyan API untuk mendapatkan pernyataan rawak dan memaparkannya dalam halaman

  1. Pengenalan
    Baidu Wenxin Yiyan ialah antara muka API yang menyediakan pernyataan rawak Kami boleh menggunakan PHP untuk menyambung ke API dan Dapatkan pernyataan rawak dan paparkannya dalam halaman. Artikel ini akan memperkenalkan cara menggunakan PHP untuk menyambung ke API Baidu Wenxin Yiyan, dan menggabungkannya dengan contoh kod untuk mencapai paparan halaman pernyataan rawak.
  2. Dapatkan kunci API
    Pertama, kita perlu mendaftar akaun pembangun di tapak web rasmi Baidu Wenxinyiyan dan mendapatkan kunci API. Selepas pendaftaran selesai, log masuk ke akaun, cari kunci API di pusat peribadi, dan salin kunci untuk kegunaan seterusnya.
  3. Sambung ke API
    Kami menggunakan fungsi curl PHP untuk menyambung ke API Baidu Wenxin Yiyan Berikut ialah contoh kod untuk menyambung ke API:
<?php
$api_url = 'https://api.bingstudio.cn/wenxin/yiyan';
$api_key = 'your_api_key'; // 替换成你的API密钥

$curl = curl_init();

curl_setopt_array($curl, array(
  CURLOPT_URL => $api_url,
  CURLOPT_RETURNTRANSFER => true,
  CURLOPT_TIMEOUT => 30,
  CURLOPT_HTTPHEADER => array(
    'X-Api-Key: ' . $api_key
  )
));

$response = curl_exec($curl);
$error = curl_error($curl);

curl_close($curl);

if ($error) {
  echo 'API连接错误: ' . $error;
  exit;
}

$data = json_decode($response, true);

if ($data['code'] !== 0) {
  echo 'API返回错误: ' . $data['msg'];
  exit;
}

$quote = $data['data']['content'];
$author = $data['data']['author'];

echo '随机语句:' . $quote;
echo '作者:' . $author;
?>
  1. Paparan penomboran
    Seterusnya, kami perlu melaksanakan fungsi paparan penomboran. daripada pernyataan rawak. Kami boleh menggunakan kelas paging PHP untuk mengendalikan logik paging Berikut ialah contoh kod:
<?php
class Pager {
    private $total;            // 总记录数
    private $pageSize;         // 每页显示的记录数
    private $pageNum;          // 当前页码
    private $totalPages;       // 总页数
    private $start;            // 当前页在数据库中的起始位置
    private $conn;             // 数据库连接对象

    // 构造方法,初始化分页类对象
    function __construct($total, $pageSize, $conn) {
        $this->total = $total;
        $this->pageSize = $pageSize;
        $this->totalPages = ceil($this->total / $this->pageSize);
        $this->conn = $conn;
        $this->getPageNum();
        $this->getStart();
    }

    // 获取当前页码
    function getPageNum() {
        $pageParam = isset($_GET['page']) ? intval($_GET['page']) : 1;
        if ($pageParam < 1) {
            $this->pageNum = 1;
        } elseif ($pageParam > $this->totalPages) {
            $this->pageNum = $this->totalPages;
        } else {
            $this->pageNum = $pageParam;
        }
    }

    // 获取当前页的起始位置
    function getStart() {
        $this->start = ($this->pageNum - 1) * $this->pageSize;
    }

    // 获取分页数据
    function getPagerData($sql) {
        $sql = $sql . " LIMIT $this->start, $this->pageSize";
        $result = $this->conn->query($sql);
        return $result;
    }

    // 生成分页链接
    function generateLinks($url) {
        $links = '';
        if ($this->pageNum > 1) {
            $prev = $this->pageNum - 1;
            $links .= "<a href='$url?page=$prev'>上一页</a>";
        }

        if ($this->pageNum < $this->totalPages) {
            $next = $this->pageNum + 1;
            $links .= "<a href='$url?page=$next'>下一页</a>";
        }

        return $links;
    }
}

// 使用示例
$servername = 'localhost';
$username = 'your_username';
$password = 'your_password';
$dbname = 'your_database';

// 创建数据库连接
$conn = new mysqli($servername, $username, $password, $dbname);

// 检查连接是否成功
if ($conn->connect_error) {
    die('数据库连接失败: ' . $conn->connect_error);
}

// 查询总记录数
$totalRows = $conn->query('SELECT count(*) as count FROM table')->fetch_assoc()['count'];

// 每页显示5条记录
$pageSize = 5;

// 创建分页对象
$pager = new Pager($totalRows, $pageSize, $conn);

// 查询当前页的数据
$sql = 'SELECT * FROM table';
$result = $pager->getPagerData($sql);

// 显示分页数据
if ($result->num_rows > 0) {
    while ($row = $result->fetch_assoc()) {
        echo $row['content'] . '<br>';
    }
} else {
    echo '没有数据';
}

// 生成分页链接并显示
$url = $_SERVER['PHP_SELF'];
echo $pager->generateLinks($url);

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

Contoh kod di atas akan memperoleh data paging daripada pangkalan data, dan anda boleh mengubah suainya mengikut keperluan sebenar. Pada masa yang sama, anda boleh menentukan gaya penomboran dan borang pautan secara bebas untuk disesuaikan dengan reka bentuk web anda.

  1. Kesimpulan
    Dengan menyambung ke Baidu Wenxin Yiyan API, kami boleh mendapatkan ayat rawak dengan mudah dan memaparkannya dalam penomboran. Saya harap artikel ini akan membantu anda memahami cara menggunakan PHP untuk menyambung ke API dan melaksanakan paparan paging. Melalui pengenalan contoh dan idea kod, saya percaya anda boleh menggunakannya secara fleksibel dalam projek sebenar.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan sambungan PHP ke API Baidu Wenxin Yiyan untuk mendapatkan kenyataan rawak dan memaparkannya dalam halaman. 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