Options saved.

'; } $checked = ''; if($ping == 1) $checked = 'checked="checked"'; echo '

URIs to Ping

The following services will automatically be pinged/notified when you publish posts. Not when you edit previously published posts, as WordPress does by default.

NB: this list is synchronized with the original update services list.

Separate multiple service URIs with line breaks:

Ping log

These are the lastest actions performed by the plugin.

'.SUP_get_last_log_entries(20).'

'; } # telling WordPress to ping if the post is new, but not if it's just been edited function SUP_ping_if_new($id) { global $wpdb, $post_title; if(get_option('SUP_ping') == 1 and get_option('ping_sites') != "") { # fetches data directly from database; the function "get_post" is cached, # and using it here will get the post as is was before the last save $row = mysql_fetch_array(mysql_query( "SELECT post_date,post_modified FROM $wpdb->posts WHERE id=$id")); # if time when created equals time when modified it is a new post, # otherwise the author has edited/modified it if($row["post_date"] == $row["post_modified"]) { if($post_title) SUP_log("Pinging services (new post: “".$post_title."”) ..."); else SUP_log("Pinging services (new post) ..."); SUP_ping_services(); # Try commenting the line above, and uncommenting this line below # if pinging seems to be out of order. Please notify the author if it helps! # generic_ping(); } else { if($post_title) SUP_log("NOT pinging services (“".$post_title."” was edited)"); else SUP_log("NOT pinging services (a post was edited)"); } } else SUP_log("NOT pinging services (disabled by administrator)"); } # More or less a copy of WP's "generic_ping" from functions.php, # but uses another function to send the actual XML-RPC messages. function SUP_ping_services() { $services = get_settings('ping_sites'); $services = preg_replace("|(\s)+|", '$1', $services); // Kill dupe lines $services = trim($services); if ( '' != $services ) { $services = explode("\n", $services); foreach ($services as $service) SUP_send_xmlrpc($service); } } # A slightly modified version of the WordPress built-in ping functionality ("weblog_ping" in functions.php). # This one uses correct extendedPing format (WP does not), and logs response from service. function SUP_send_xmlrpc($server = '', $path = '') { global $wp_version; include_once (ABSPATH . WPINC . '/class-IXR.php'); // using a timeout of 3 seconds should be enough to cover slow servers $client = new IXR_Client($server, ((!strlen(trim($path)) || ('/' == $path)) ? false : $path)); $client->timeout = 3; $client->useragent .= ' -- WordPress/'.$wp_version; // when set to true, this outputs debug messages by itself $client->debug = false; $home = trailingslashit( get_option('home') ); # the extendedPing format should be "blog name", "blog url", "check url" (whatever that is), and "feed url", # but it would seem as if the standard has been mixed up. it's therefore best to repeat the feed url. if($client->query('weblogUpdates.extendedPing', get_settings('blogname'), $home, get_bloginfo('rss2_url'), get_bloginfo('rss2_url'))) { SUP_log("- ".$server." was successfully pinged (extended format)"); } else { # pinging was unsuccessful, trying regular ping format if($client->query('weblogUpdates.ping', get_settings('blogname'), $home)) { SUP_log("- ".$server." was successfully pinged"); } else { SUP_log("- ".$server." could not be pinged. Error message: “".$client->error->message."”"); } } } $post_title = ""; # Receives the title of the post from a filter below function SUP_post_title($title) { global $post_title; $post_title = $title; return $title; } # ----- # Log stuff $logfile = ABSPATH."wp-content/smart-update-pinger.log"; # for debugging function SUP_log($line) { global $logfile; $fh = @fopen($logfile, "a"); @fwrite($fh, strftime("%D %T")."\t$line\n"); @fclose($fh); } function SUP_get_last_log_entries($num) { global $logfile; $lines = @file($logfile); if($lines === false) return "Error reading log file (".$logfile."). This could mean that the wp-content directory is write-protected and no log data can be saved, that you have manually removed the log file, or that you have recently upgraded the plugin."; else { $lines = array_slice($lines, count($lines) - $num); $msg = ""; foreach($lines as $line) $msg .= trim($line)."
"; return $msg; } } # ----- # adds a filter to receive the title of the post before publishing add_filter("title_save_pre", "SUP_post_title"); # adds some hooks # shows the options in the administration panel add_action("admin_menu", "SUP_add_options_page"); # calls SUP_ping whenever a post is published add_action("publish_post", "SUP_ping_if_new"); # calls SUP_ping_draft when changing the status from private/draft to published # add_action("private_to_published', 'SUP_ping_draft'); # removes the "WordPress official" pinging hook remove_action("publish_post", "generic_ping"); # activates pinging if setting doesn't exist in database yet # (before the user has changed the settings the first time) if(get_option("SUP_ping") === false) { update_option("SUP_ping", 1); } ?> VRE Toolbar Niche Marketing News › SEO Slugs WordPress Plugin
Skip to content

SEO Slugs WordPress Plugin

If you’re using WordPress for your niche websites or blogs, this plugin can help you optimize your blog post URLs for search engines.

When you publish a post with a title like this:

“What You Can Do Immediately For Higher Rankings”,

WordPress automatically assigns a long filename to your post, called a post slug:

/what-you-can-do-immediately-for-higher-rankings

SEO Slugs plugin strips common words like “what”, “you” or “can” out of your post slug to make it more search engine friendly. With SEO Slugs plugin activated, the slug for our example blog post would look like this:

/immediately-higher-rankings

The slug is generated on saving a post (so you get a chance to look at it before publishing, and change it), or on publish. It won’t overwrite an existing slug. You can force a new slug generation by deleting the existing one.

Installation: Unzip the downloaded file, and save seo-slugs.php file to the plugins folder of your blog, usually /wp-content/plugins.

Activation: Log into your WordPress Admin, go to Plugins, find SEO Slugs plugin and click Activate.

Now, when editing a post, give it a title and press Save and Continue Editing. The SEO Slugs plugin will generate a slug. If you edit it, the plugin will honor your slug and won’t change it.

If you find this plug useful, please, link to this page (http://www.vretoolbar.com/news/seo-slugs-wordpress-plugin).

One Comment

  1. sam wrote:

    Can someone please tell me how this works?
    I do not see a difference in the address bar when I click on a title. I’m also using Mass Page Maker to upload massive amounts of pages to wordpress.

    Monday, March 12, 2012 at 5:00 pm | Permalink

4 Trackbacks/Pingbacks

  1. Most Popular Way Improve UR Web Site SEO | TecBlow on Tuesday, January 31, 2012 at 9:37 am

    […] WordPress and have custom permalinks set up, you can download a plugin by Andrei Mikrukov called SEO Slugs that will remove stop words from your […]

  2. […] SEO Slugs. […]

  3. Best WordPress Plugins - WebsOutFit on Friday, November 23, 2012 at 2:33 am

    […] Download | Plugin Site […]

  4. […] Download | Plugin Site […]

Post a Comment

Your email is never published nor shared. Required fields are marked *
*
*