How To Add Blog Posts In Different Pages On Wordpress
Get the Right File Permissions in Your WordPress Site with our tutorial.
An interactive website needs to be able to interact with user input, which is commonly in the form of form submissions. A WordPress site is no exception to this rule. There are various interactions happening on a website on a daily basis. For example, subscribing to a newsletter, sending a message to the site owner and filling in an order form. All of these usually happen from POST
requests during a form submission.
In this article, we're going to take a simple example of handling a POST
request from a user, which is submitted via a contact form. We are going to use an internal WordPress hook to properly get the data, process it accordingly and redirect the user back to a specific page.
This article assumes you have a basic knowledge of the WordPress Plugin API. If you're not familiar, it's highly recommended to review the Codex page first.
The Background
WordPress is based on an event driven architecture. This means internally, WordPress core is filled up with various actions and filters to modify the program execution or to alter the content during runtime. Examples of actions that are running during program execution are init
, wp
, template_redirect
and wp_head
. Many plugins utilise these actions and filters to modify how WordPress works.
It is no different with what we are going to achieve. All we need to know is the proper hooks needed for the POST
request and to modify our code accordingly. This is possible by pointing all our form submissions to a specific file in the wp-admin
directory called admin-post.php
. If you have experienced integrating your application with WordPress internal AJAX API, then you will notice that the basic structure of admin-post.php
is not much different to the admin-ajax.php
counterpart.
Anatomy of admin-post.php
At the very basic level, admin-post.php
only contains 71 lines of code. It starts by defining WP_ADMIN
constant and then loading WordPress by requiring wp-load.php
. After that it sends an appropriate header and triggers the admin_init
action.
The current action is determined by this line of code:
$action = empty( $_REQUEST['action'] ) ? '' : $_REQUEST['action'];
Despite the name, admin-post.php
can actually handle both of POST
and GET
requests. However, what we're interested to go through in the context of this article will be only related to POST
request. Next,
if ( ! wp_validate_auth_cookie() ) { if ( empty( $action ) ) { /** * Fires on a non-authenticated admin post request where no action was supplied. * * @since 2.6.0 */ do_action( 'admin_post_nopriv' ); } else { /** * Fires on a non-authenticated admin post request for the given action. * * The dynamic portion of the hook name, `$action`, refers to the given * request action. * * @since 2.6.0 */ do_action( "admin_post_nopriv_{$action}" ); } } else { if ( empty( $action ) ) { /** * Fires on an authenticated admin post request where no action was supplied. * * @since 2.6.0 */ do_action( 'admin_post' ); } else { /** * Fires on an authenticated admin post request for the given action. * * The dynamic portion of the hook name, `$action`, refers to the given * request action. * * @since 2.6.0 */ do_action( "admin_post_{$action}" ); } }
We can see that two different action hooks will be triggered based on the user logged in status which is admin_post
for logged in user and admin_post_nopriv
for the non logged in user. If you need a more refined control to only processing the data related to your request, a more specific action will also be triggered, namely admin_post_nopriv_{$action}
and admin_post_{$action}
, again based on the logged in state of the user.
Let's say our POST
request has an action
with a value of foobar
. These two actions will be triggered if the current user is not logged in:
-
admin_post_nopriv
-
admin_post_nopriv_foobar
If you are currently logged in, two different actions will be triggered:
-
admin_post
-
admin_post_foobar
For GET
request, when you are accessing the URL like this:
http://www.example.com/wp-admin/admin-post.php?action=foobar&data=test
All the above four hooks are still available to you to use.
With this knowledge, we can easily hook into the appropriate actions to handle the contact form submission without actually messing with our theme template.
Proof of Concept
Let's take a contact form as an example. The simplest way to do this (not recommended) is perhaps to create a custom page template based on the basic page.php
, hardcode a form and do the processing in that file itself. This is roughly how it looks:
<?php /* * Template Name: Contact Page */ get_header(); if ( ! empty( $_POST ) ) { // Sanitize the POST field // Generate email content // Send to appropriate email } ?> <div id="content"> <form action="" method="post"> <label for="fullname">Full Name</label> <input type="text" name="fullname" id="fullname" required> <label for="email">Email Address</label> <input type="email" name="email" id="email" required> <label for="message">Your Message</label> <textarea name="message" id="message"></textarea> <input type="submit" value="Send My Message"> </form> </div> <?php get_footer();
While this implementation will work, there is no separation or concern whatsoever which will lead to trouble in the long run. Maintaining the form is a nightmare as the processing is only happening in one place, and if we are to duplicate the form somewhere else, we need to redo the processing again.
To fully utilize the event driven nature of WordPress, and also to provide a separation of concern, we can make use of the admin-post.php
provided. Converting the existing form to make it compatible with admin-post.php
is fairly straightforward too.
We first change this line from:
<form action="" method="post">
to:
<form action="<?php echo esc_url( admin_url('admin-post.php') ); ?>" method="post">
To generate a proper URL pointing to the admin-post.php
, we use the built-in function admin_url
. This will make sure that our URL is always correct in reference to the current site that is running.
We also need to add the action
hidden input so that we can trigger the more specific hook related to our contact form submission. Let's use an example of contact_form
for the action
value.
We add this line somewhere in between the <form>
tag.
<input type="hidden" name="action" value="contact_form">
This is how the page template looks like after the modification:
<?php /* * Template Name: Contact Page */ get_header(); ?> <div id="content"> <form action="<?php echo esc_url( admin_url('admin-post.php') ); ?>" method="post"> <label for="fullname">Full Name</label> <input type="text" name="fullname" id="fullname" required> <label for="email">Email Address</label> <input type="email" name="email" id="email" required> <label for="message">Your Message</label> <textarea name="message" id="message"></textarea> <input type="hidden" name="action" value="contact_form"> <input type="submit" value="Send My Message"> </form> </div> <?php get_footer();
Notice that we are removing the POST processing function on top of the template since we are going to hook into the action later on.
Actual Handling of the POST Request
For this part, we have two options, and going with either one is fine. We can either hook into the admin_post_*
action via the functions.php
of our theme, or we can create a simple plugin to handle the contact form. Let's just code this into the functions.php
for simplicity sake.
Remember that we have our custom action contact_form
in the form, so by rights, we will have these four hooks available to us:
-
admin_post_nopriv
-
admin_post_nopriv_contact_form
-
admin_post
-
admin_post_contact_form
Open up functions.php
of your current theme and add these lines in:
function prefix_send_email_to_admin() { /** * At this point, $_GET/$_POST variable are available * * We can do our normal processing here */ // Sanitize the POST field // Generate email content // Send to appropriate email } add_action( 'admin_post_nopriv_contact_form', 'prefix_send_email_to_admin` ); add_action( 'admin_post_contact_form', 'prefix_send_email_to_admin` );
Since we want to handle the form submission the same way no matter if the user is currently logged in or not, we point to the same callback function for both admin_post_nopriv_contact_form
and admin_post_contact_form
. The actual callback function, prefix_send_email_to_admin
will be your main point to do the data processing.
Conclusion
admin-post.php
is a useful, hidden gem contained in the WordPress core. By utilizing it, we can keep the separation of concern between the actual template, and unrelated code that is not needed for display separated by hooking into the appropriate hooks for processing.
Get the Right File Permissions in Your WordPress Site with our tutorial.
How To Add Blog Posts In Different Pages On Wordpress
Source: https://www.sitepoint.com/handling-post-requests-the-wordpress-way/
Posted by: madisonbablin1977.blogspot.com
0 Response to "How To Add Blog Posts In Different Pages On Wordpress"
Post a Comment