Table of Contents
My Plugin Settings
Home CMS Tutorial WordPress How to add file upload functionality to WordPress plugin

How to add file upload functionality to WordPress plugin

Sep 05, 2023 am 10:04 AM
plug-in wordpress File Upload

How to add file upload functionality to WordPress plugin

How to add file upload functionality to WordPress plugin

Introduction:
WordPress is a very popular open source content management system with its flexibility and scalability Many website developers choose to use it. One of the powerful features is the ability to extend WordPress functionality through plugins. In this article, we will explain how to add file upload functionality to a WordPress plugin and provide corresponding code examples.

  1. Create a new WordPress plugin
    First, we need to create a new WordPress plugin. Create a new folder in the WordPress plugin directory (wp-content/plugins/) and name it "my-plugin" (or name it according to your needs). Create a PHP file named "my-plugin.php" in the folder and add the following code in the file:
<?php
/*
Plugin Name: My Plugin
*/

// 添加文件上传功能的代码将在此处添加
?>
Copy after login
  1. Add a file upload form to the plugin settings page
    Next, we need to add a file upload form to the plugin settings page. In the "my-plugin.php" file, add the following code:
<?php
function my_plugin_admin_menu() {
    add_options_page('My Plugin Settings', 'My Plugin', 'manage_options', 'my-plugin', 'my_plugin_settings_page');
}
add_action('admin_menu', 'my_plugin_admin_menu');

function my_plugin_settings_page() {
    ?>
    <div class="wrap">
        <h2 id="My-Plugin-Settings">My Plugin Settings</h2>
        <form method="post" enctype="multipart/form-data">
            <input type="file" name="my_file">
            <input type="submit" value="Upload">
        </form>
    </div>
    <?php
}
?>
Copy after login

In this code, we first add a new tab to WordPress using the add_options_page function Set up the page and then use the my_plugin_settings_page function to add a form to the tab page. The form contains a file selection input box and an upload button.

  1. Handling file uploads and saving files
    Next, we need to write code to handle file uploads and save files. Add the following code to the "my-plugin.php" file:
<?php
function my_plugin_save_file() {
    if (isset($_FILES['my_file'])) {
        $upload_dir = wp_upload_dir();
        $file_name = $_FILES['my_file']['name'];
        $file_temp = $_FILES['my_file']['tmp_name'];
        $file_path = $upload_dir['path'] . '/' . $file_name;

        if (move_uploaded_file($file_temp, $file_path)) {
            echo 'File uploaded successfully.';
        } else {
            echo 'Failed to upload file.';
        }
    }
}
add_action('admin_init', 'my_plugin_save_file');
?>
Copy after login

In this code, we first check whether there is a file uploaded. Then, use the wp_upload_dir function to get the path to the WordPress upload directory and the move_uploaded_file function to move the file from the temporary location into the upload directory.

  1. Display uploaded file information
    Finally, we need to display uploaded file information in the plug-in settings page. Add the following code in the "my-plugin.php" file:
<?php
function my_plugin_show_file_info() {
    $upload_dir = wp_upload_dir();
    $file_path = $upload_dir['path'] . '/' . $_FILES['my_file']['name'];

    if (file_exists($file_path)) {
        $file_size = filesize($file_path);
        $file_type = wp_check_filetype(basename($file_path), null);
        $file_url = $upload_dir['url'] . '/' . $_FILES['my_file']['name'];

        echo '<p>File URL: <a href="' . $file_url . '">' . $file_url . '</a></p>';
        echo '<p>File Type: ' . $file_type['type'] . '</p>';
        echo '<p>File Size: ' . $file_size . ' bytes</p>';
    }
}
add_action('admin_notices', 'my_plugin_show_file_info');
?>
Copy after login

In this code, we first get the path of the uploaded file, and then use the file_exists function to check whether the file exist. If the file exists, we use the wp_check_filetype function to get the file's type and display the file's URL, type, and size on the plugin settings page.

Summary:
Through this article, we learned how to add file upload functionality to WordPress plugins. We started by creating a new WordPress plugin and added a file upload form to the plugin settings page. We then wrote code to handle the file upload and save the file, and finally displayed the uploaded file information in the plugin settings page. This example can help us understand how to extend the functionality of WordPress plugins while improving our own development skills.

The above code example is just a basic demonstration. In actual development, more logic and verification may need to be added to ensure the security and reliability of the file upload function. I hope this article will be helpful for you to add file upload function when developing WordPress plug-in.

The above is the detailed content of How to add file upload functionality to WordPress plugin. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
1 months ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat Commands and How to Use Them
1 months ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

PHP vs. Flutter: The best choice for mobile development PHP vs. Flutter: The best choice for mobile development May 06, 2024 pm 10:45 PM

PHP and Flutter are popular technologies for mobile development. Flutter excels in cross-platform capabilities, performance and user interface, and is suitable for applications that require high performance, cross-platform and customized UI. PHP is suitable for server-side applications with lower performance and not cross-platform.

How to change page width in wordpress How to change page width in wordpress Apr 16, 2024 am 01:03 AM

You can easily modify your WordPress page width by editing your style.css file: Edit your style.css file and add .site-content { max-width: [your preferred width]; }. Edit [your preferred width] to set the page width. Save changes and clear cache (optional).

How to use gRPC to implement file upload in Golang? How to use gRPC to implement file upload in Golang? Jun 03, 2024 pm 04:54 PM

How to implement file upload using gRPC? Create supporting service definitions, including request and response messages. On the client, the file to be uploaded is opened and split into chunks, then streamed to the server via a gRPC stream. On the server side, file chunks are received and stored into a file. The server sends a response after the file upload is completed to indicate whether the upload was successful.

In which folder are wordpress articles located? In which folder are wordpress articles located? Apr 16, 2024 am 10:29 AM

WordPress posts are stored in the /wp-content/uploads folder. This folder uses subfolders to categorize different types of uploads, including articles organized by year, month, and article ID. Article files are stored in plain text format (.txt), and the filename usually includes its ID and title.

Where is the wordpress template file? Where is the wordpress template file? Apr 16, 2024 am 11:00 AM

WordPress template files are located in the /wp-content/themes/[theme name]/ directory. They are used to determine the appearance and functionality of the website, including header (header.php), footer (footer.php), main template (index.php), single article (single.php), page (page.php), Archive (archive.php), category (category.php), tag (tag.php), search (search.php) and 404 error page (404.php). By editing and modifying these files, you can customize the appearance of your WordPress website

How to search for authors in WordPress How to search for authors in WordPress Apr 16, 2024 am 01:18 AM

Search for authors in WordPress: 1. Once logged in to your admin panel, navigate to Posts or Pages, enter the author name using the search bar, and select Author in Filters. 2. Other tips: Use wildcards to broaden your search, use operators to combine criteria, or enter author IDs to search for articles.

Simplify file upload processing with Golang functions Simplify file upload processing with Golang functions May 02, 2024 pm 06:45 PM

Answer: Yes, Golang provides functions that simplify file upload processing. Details: The MultipartFile type provides access to file metadata and content. The FormFile function gets a specific file from the form request. The ParseForm and ParseMultipartForm functions are used to parse form data and multipart form data. Using these functions simplifies the file processing process and allows developers to focus on business logic.

Which version of wordpress is stable? Which version of wordpress is stable? Apr 16, 2024 am 10:54 AM

The most stable WordPress version is the latest version because it contains the latest security patches, performance enhancements, and introduces new features and improvements. In order to update to the latest version, log into your WordPress dashboard, go to the Updates page and click Update Now.

See all articles