Function and usage of add_link() in wordpress


Answers ( 1 )


    The add_link() function in WordPress is designed to add a link to your website using the values provided in the $_POST superglobal array. This array typically contains data submitted through an HTML form using the POST method. Here's a detailed breakdown of add_link():

    Function Signature

    add_link(): int|WP_Error


    • Purpose: The primary purpose of add_link() is to add a new link (like a blogroll link) to your WordPress site.
    • Data Source: It relies on the $_POST superglobal to receive the necessary data. This means that the data should be submitted through a form using the POST method.
    • Parameters: It does not take any direct parameters as inputs since it expects data from $_POST.

    Return Values

    • Success: If the function successfully adds a link, it returns the ID of the newly created link. This ID is an integer.
    • Failure: If the function fails to add the link, it returns either 0 or a WP_Error object. This can happen due to various reasons like invalid data, database errors, etc.

    Usage Example

    Here's a hypothetical example of how add_link() might be used:

    1. HTML Form: First, you'd have an HTML form on your website where users can submit new links. This form should use the POST method.

      <form action="submit-link.php" method="post">
          <input type="text" name="link_name" placeholder="Link Name">
          <input type="url" name="link_url" placeholder="Link URL">
          <input type="submit" value="Add Link">
    2. PHP Script (submit-link.php): In the PHP script that handles the form submission, you would typically validate and sanitize the input data. After validation, you can call add_link().

      // Assuming input validation and sanitization is done
      if (isset($_POST['link_name']) && isset($_POST['link_url'])) {
          $_POST['link_name'] = sanitize_text_field($_POST['link_name']);
          $_POST['link_url'] = esc_url($_POST['link_url']);
          $result = add_link();
          if (is_wp_error($result)) {
              // Handle error
              echo 'Error adding link.';
          } else {
              echo 'Link added successfully. Link ID: ' . $result;


    • Security: Always validate and sanitize user inputs to prevent security vulnerabilities like SQL injection.
    • Error Handling: When add_link() returns a WP_Error, it's helpful to check the error message for understanding what went wrong.
    • WP Version Compatibility: Ensure that this function is compatible with your WordPress version.

    Remember that WordPress development best practices, including security and data validation, should always be followed when using functions like add_link().

Leave an answer