Rumah  >  Artikel  >  Tutorial CMS  >  Bagaimana untuk membangunkan ciri yang mengemas kini pemalam WordPress secara automatik

Bagaimana untuk membangunkan ciri yang mengemas kini pemalam WordPress secara automatik

WBOY
WBOYasal
2023-09-05 10:40:511565semak imbas

Bagaimana untuk membangunkan ciri yang mengemas kini pemalam WordPress secara automatik

Cara membangunkan ciri yang secara automatik mengemas kini pemalam WordPress

WordPress ialah sistem pengurusan kandungan sumber terbuka (CMS) yang sangat popular dengan kaya Pasaran pemalam untuk melanjutkan fungsinya. Untuk memastikan pemalam sentiasa terkini dan selamat, pembangun perlu melaksanakan kemas kini automatik. Dalam artikel ini, kami akan membimbing anda tentang cara membangunkan pemalam WordPress yang mengemas kini automatik dan memberikan contoh kod untuk membantu anda bermula dengan cepat.

Persediaan

Sebelum memulakan pembangunan, anda perlu menyediakan langkah utama berikut:

  1. Buat direktori pemalam: folder dalam direktori pemalam WordPress untuk menyimpan fail pemalam anda.
  2. Dapatkan repositori jauh pemalam: Anda perlu menyimpan versi terkini pemalam di suatu tempat dan dapatkan pautan URLnya. Anda boleh menggunakan alat kawalan versi (seperti Git) untuk mengurus kod pemalam, dan kemudian gunakan repositori pemalam ke pelayan web.
  3. Buat fail konfigurasi: Untuk melaksanakan kemas kini automatik, anda memerlukan fail konfigurasi yang mengandungi maklumat pemalam dan nombor versi. Anda boleh menyimpan fail konfigurasi pada pelayan anda sendiri dan mendapatkan URLnya.

Tulis kod pemalam

Seterusnya, kami akan menulis kod pemalam untuk melaksanakan fungsi kemas kini automatik.

Pertama, buat fail pemalam utama dalam direktori pemalam, seperti plugin-name.php. Dalam fail ini, anda perlu menentukan kelas untuk mengurus proses kemas kini automatik pemalam. Berikut ialah contoh kelas pemalam yang mudah: plugin-name.php。在该文件中,您需要定义一个类来管理插件的自动更新过程。以下是一个简单的插件类示例:

<?php
class Plugin_Name {
    private $plugin_file;
    private $plugin_slug;
    private $version;

    public function __construct($plugin_file, $plugin_slug, $version) {
        $this->plugin_file = $plugin_file;
        $this->plugin_slug = $plugin_slug;
        $this->version = $version;

        add_action('init', array($this, 'check_for_update'));
        add_filter('pre_set_site_transient_update_plugins', array($this, 'set_update_transient'));
    }

    public function check_for_update() {
        $config_url = 'https://example.com/plugin-config.json'; // 替换为您的配置文件URL

        $config = wp_remote_get($config_url);
        if (!is_wp_error($config)) {
            $config = json_decode(wp_remote_retrieve_body($config), true);

            if (isset($config['version']) && version_compare($this->version, $config['version'], '<')) {
                $download_url = $config['download_url'];
                $package = wp_remote_get($download_url);

                if (!is_wp_error($package)) {
                    $package_file = $this->plugin_file;

                    WP_Filesystem();
                    global $wp_filesystem;
                    $wp_filesystem->put_contents($package_file, wp_remote_retrieve_body($package));

                    // 更新插件版本号
                    $plugin_data = get_plugin_data($this->plugin_file);
                    $plugin_data['Version'] = $config['version'];
                    $plugin_data['RequiresWP'] = $config['requires_wp'];
                    $plugin_data['RequiresPHP'] = $config['requires_php'];
                    $plugin_data['TestedWP'] = $config['tested_wp'];

                    $all_plugins = get_plugins();
                    $all_plugins[$this->plugin_slug] = array_merge($all_plugins[$this->plugin_slug], $plugin_data);
                    update_option('active_plugins', array_keys($all_plugins));

                    delete_transient('update_plugins'); // 清除插件更新缓存
                }
            }
        }
    }

    public function set_update_transient($transient) {
        if (empty($transient->checked)) {
            return $transient;
        }

        $config_url = 'https://example.com/plugin-config.json'; // 替换为您的配置文件URL

        $config = wp_remote_get($config_url);
        if (!is_wp_error($config)) {
            $config = json_decode(wp_remote_retrieve_body($config), true);

            if (isset($config['version']) && version_compare($this->version, $config['version'], '<')) {
                $transient->response[$this->plugin_slug] = array(
                    'new_version' => $config['version'],
                    'package' => $config['download_url'],
                    'slug' => $this->plugin_slug
                );
            }
        }

        return $transient;
    }
}

// 实例化插件类
new Plugin_Name(__FILE__, 'plugin-folder/plugin-name.php', '1.0.0');
?>

在上面的代码示例中,我们在构造函数中将插件文件名__FILE__、插件slug和插件版本号传递给插件类。然后,我们使用add_actionadd_filtercheck_for_update方法和set_update_transient方法绑定到相应的WordPress钩子上,以实现自动检查和更新的功能。

check_for_update方法首先从远程配置文件中获取插件的最新版本号和下载链接。然后,通过wp_remote_get函数来下载最新版本的插件包。接下来,我们使用WP_Filesystem类和global $wp_filesystem来更新插件文件,并更新插件的版本信息。最后,我们使用delete_transient函数来清除插件的更新缓存,以便在下次检查时得到最新版本的插件。

set_update_transient方法在WordPress检查插件更新时被调用,并用来设置插件的更新信息。首先,从远程配置文件中获取插件的最新版本号和下载链接。然后,将更新信息存储在$transient

{
    "version": "1.0.1",
    "requires_wp": "5.2",
    "requires_php": "7.2",
    "tested_wp": "5.4",
    "download_url": "https://example.com/plugin-package.zip"
}

Dalam contoh kod di atas, kami menghantar nama fail pemalam __FILE__, slug pemalam dan pemalam- dalam nombor versi dalam pembina kepada kelas pemalam. Kemudian, kami menggunakan add_action dan add_filter untuk mengikat kaedah check_for_update dan kaedah set_update_transient pada cangkuk WordPress yang sepadan, To mencapai fungsi semakan dan pengemaskinian automatik.

Kaedah check_for_update mula-mula mendapatkan nombor versi terkini dan pautan muat turun pemalam daripada fail konfigurasi jauh. Kemudian, muat turun versi terkini pakej pemalam melalui fungsi wp_remote_get. Seterusnya, kami menggunakan kelas WP_Filesystem dan global $wp_filesystem untuk mengemas kini fail pemalam dan mengemas kini maklumat versi pemalam. Akhir sekali, kami menggunakan fungsi delete_transient untuk mengosongkan cache kemas kini pemalam supaya kami mendapat versi terbaharu pemalam pada kali seterusnya kami menyemak.

Kaedah set_update_transient dipanggil apabila WordPress menyemak kemas kini pemalam dan digunakan untuk menetapkan maklumat kemas kini pemalam. Mula-mula, dapatkan nombor versi terkini dan pautan muat turun pemalam daripada fail konfigurasi jauh. Kemudian, simpan maklumat kemas kini dalam pembolehubah $transient supaya WordPress boleh menemui kemas kini pada pemalam.

Di atas ialah contoh pelaksanaan pemalam WordPress kemas kini automatik asas. Bergantung pada keperluan anda, anda boleh mengoptimumkan lagi kod dan menambah ciri seperti pengendalian ralat dan pengelogan.

Mengkonfigurasi fail repositori dan konfigurasi jauh

Akhir sekali, anda perlu mengkonfigurasi fail repositori dan konfigurasi jauh pemalam. Anda boleh menggunakan alat kawalan versi seperti Git untuk mengurus kod pemalam dan menggunakan repositori pemalam ke pelayan web. Kemudian, buat fail konfigurasi dalam format JSON yang mengandungi maklumat pemalam dan nombor versi. Simpan fail konfigurasi pada pelayan anda dan rujuk URLnya dalam kod pemalam.

Berikut ialah contoh fail konfigurasi:

rrreee

Dalam fail konfigurasi, anda boleh menentukan nombor versi terkini pemalam, keperluan versi minimum untuk WordPress, dan keperluan versi minimum untuk PHP dan pautan muat turun untuk pakej pemalam.

Kesimpulan

Dengan mengikuti langkah dan contoh kod di atas, anda boleh membangunkan pemalam WordPress yang mengemas kini automatik dengan mudah. Ciri kemas kini automatik membantu anda memastikan pemalam anda sentiasa terkini dan selamat, memberikan pengalaman pengguna yang lebih baik. #🎜🎜##🎜🎜# Semasa pembangunan, sila pastikan anda menggunakan piawaian pembangunan WordPress terkini dan amalan terbaik. Selain itu, ingat untuk menyandarkan fail pemalam anda sebelum mengemas kini sekiranya berlaku apa-apa yang tidak dijangka. #🎜🎜##🎜🎜# Saya doakan anda berjaya dalam pembangunan! #🎜🎜#

Atas ialah kandungan terperinci Bagaimana untuk membangunkan ciri yang mengemas kini pemalam WordPress secara automatik. 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

Artikel berkaitan

Lihat lagi