WordPress | |
Author: | |
Developer: |
|
Programming Language: | PHP |
Operating System: | Unix-like, Windows, Linux |
Size: | 23.2 MB (compressed) |
Genre: | Blog software, content management system, content management framework |
License: | GPLv2 or later[1] |
WordPress (WP, or WordPress.org) is a web content management system. It was originally created as a tool to publish blogs but has evolved to support publishing other web content, including more traditional websites, mailing lists and Internet forum, media galleries, membership sites, learning management systems, and online stores. Available as free and open-source software, WordPress is among the most popular content management systems – it was used by 43.1% of the top 10 million websites .[2] [3]
WordPress is written in the PHP language[4] and paired with a MySQL or MariaDB database. Features include a plugin architecture and a template system, referred to within WordPress as "Themes".
To function, WordPress has to be installed on a web server, either as part of an Internet hosting service or on a computer running the WordPress software package.[5]
WordPress was released on May 27, 2003, by its founders, American developer Matt Mullenweg[6] and English developer Mike Little.[7] [8] WordPress Foundation owns WordPress, WordPress projects, and other related trademarks.[9]
"WordPress is a factory that makes webpages"[10] is a core analogy designed to clarify the functions of WordPress: it stores content and enables a user to create and publish webpages, requiring nothing beyond a domain and a hosting service.
WordPress has a web template system using a template processor. Its architecture is a front controller, routing all requests for non-static URIs to a single PHP file that parses the URI and identifies the target page. This allows support for more human-readable permalinks.[11]
WordPress users may install and switch among many different themes. Themes allow users to change the look and functionality of a WordPress website without altering the core code or site content. Custom code can be added to the website by using a child theme or through a code editor. Every WordPress website requires at least one theme to be present. Themes may be directly installed using the WordPress "Appearance" administration tool in the dashboard, or theme folders may be copied directly into the themes directory.[12] WordPress themes are generally classified into two categories: free and premium. Many free themes are listed in the WordPress theme directory (also known as the repository), and premium themes are available for purchase from marketplaces and individual WordPress developers. WordPress users may also create and develop their own custom themes and upload them in the WordPress directory or repository.[13]
WordPress' plugin architecture allows users to extend or depreciate the features and functionality of a website or blog.[14] [15], WordPress.org has 59,756 plugins available,[16] each of which offers custom functions and features enabling users to tailor their sites to their specific needs. However, this does not include the available premium plugins (approximately 1,500+), which may not be listed in the WordPress.org repository. These customizations range from search engine optimization (SEO) to client portals used to display private information to logged-in users, to content management systems, to content displaying features, such as the addition of widgets and navigation bars. Not all available plugins are always abreast with the upgrades, and as a result, they may not function properly or may not function at all. If the plugin developer has not tested the plugin with the last two major versions of WordPress, a warning message will be displayed on the plugin directory, informing users that the plugin may not work properly with the latest WordPress version.[17] Most plugins are available through WordPress themselves, either via downloading them and installing the files manually via FTP or through the WordPress dashboard. However, many third parties offer plugins through their websites, many of which are paid packages.
Web developers who wish to develop plugins need to learn WordPress' hook system, which consists of over 2,000 hooks (as of Version 5.7 in 2021)[18] divided into two categories: action hooks and filter hooks.[19]
Plugins also represent a development strategy that can transform WordPress into all sorts of software systems and applications, limited only by the imagination and creativity of programmers. These are implemented using custom plugins to create non-website systems, such as headless WordPress applications and Software as a Service (SaaS) products.
Plugins could also be used by hackers targeting sites that use WordPress, as hackers could exploit bugs in WordPress plugins instead of bugs in WordPress itself.[20]
Phone apps for WordPress exist for WebOS,[21] Android,[22] iOS,[23] [24] Windows Phone, and BlackBerry.[25] These applications, designed by Automattic, have options such as adding new blog posts and pages, commenting, moderating comments, replying to comments in addition to the ability to view the stats.
The WordPress Accessibility Coding Standards state that "All new or updated code released in WordPress must conform with the Web Content Accessibility Guidelines 2.0 at level AA."[26]
WordPress also features integrated link management, a search engine–friendly, clean permalink structure; the ability to assign multiple categories to posts; and support for tagging of posts. Automatic filters are also included, providing standardized formatting and styling of text in posts (for example, converting regular quotes to smart quotes). WordPress also supports the Trackback and Pingback standards for displaying links to other sites that have themselves linked to a post or an article. WordPress posts can be edited in HTML, using the visual editor, or using one of several plugins that allow for a variety of customized editing features.
Before version 3, WordPress supported one blog per installation, although multiple concurrent copies may be run from different directories if configured to use separate database tables. WordPress Multisites (previously referred to as WordPress Multi-User, WordPress MU, or WPMU) was a fork of WordPress created to allow multiple blogs to exist within one installation but can be administered by a centralized maintainer. WordPress MU makes it possible for those with websites to host their own blogging communities, as well as control and moderate all the blogs from a single dashboard. WordPress MU adds eight new data tables for each blog.
As of the release of WordPress 3, WordPress MU has merged with WordPress.[27]
b2/cafelog, more commonly known as b2 or catalog, was the precursor to WordPress.[28] b2/cafelog was estimated to have been installed on approximately 2,000 blogs as of May 2003.[29] It was written in PHP for use with MySQL by Michel Valdrighi, who was a contributing developer to WordPress until 2005. Although WordPress is the official successor, another project, b2evolution, is also in active development.
As the development of b2/cafelog slowed down, Matt Mullenweg began pondering the idea of forking b2/cafelog and new features that he would want in a new CMS, in a blog post written on January 24, 2003.[30] Mike Little, a professional developer, became the first to comment on the blog post expressing interest to contribute.[31] The two worked together to create the first version of WordPress, version 0.70,[32] which was released on May 27, 2003.[33] Christine Selleck Tremoulet, a friend of Mullenweg, suggested the name WordPress.[34] [35]
In 2004, the licensing terms for the competing Movable Type package were changed by Six Apart, resulting in many of its most influential users migrating to WordPress.[36] [37] By October 2009, the Open Source CMS MarketShare Report concluded that WordPress enjoyed the greatest brand strength of any open-source content management system.
As of May 2021, WordPress is used by 64.8% of all the websites whose content management system is known, and 41.4% of the top 10 million websites.
Starting September 2024, Mullenweg engaged WordPress, Wordpress.com, and Automattic in a dispute leading to a lawsuit with hosting company WP Engine, causing widespread community concern.
Main releases of WordPress are codenamed after well-known jazz musicians, starting from version 1.0.[42] [43]
Although only the current release is officially supported, security updates are backported "as a courtesy" to all versions as far back as 4.0.[44]
Version[45] | Codename | Release date[46] | Notes | |||
---|---|---|---|---|---|---|
May 27, 2003[47] | Used the same file structure as its predecessor, b2/cafelog, and continued the numbering from its last release, 0.6.[48] Only 0.71-gold is available for download in the official WordPress Release Archive page. | |||||
Davis | January 3, 2004[49] | Added search engine-friendly permalinks, multiple categories, dead-simple installation, and upgrade, comment moderation, XFN support, and Atom support. | ||||
Blakey | March 11, 2004[50] | This was only a bugfix release and contained no new features. | ||||
Mingus | May 22, 2004[51] | Added support of Plugins; in which the same identification headers are used unchanged in WordPress releases . | ||||
Strayhorn | February 17, 2005[52] | Added a range of vital features, such as the ability to manage static pages and a template/Theme system. It was also equipped with a new default template (codenamed Kubrick).[53] designed by Michael Heilemann. | ||||
Duke | December 31, 2005[54] | Added rich editing, better administration tools, image uploading, faster posting, improved import system, fully overhauled the back end, and various improvements to Plugin developers. | ||||
Ella | January 22, 2007[55] | Corrected security issues, a redesigned interface, enhanced editing tools (including integrated spell check and auto save), and improved content management options. | ||||
Getz | May 16, 2007[56] | Added widget support for templates, updated Atom feed support, and speed optimizations. | ||||
Dexter | September 24, 2007[57] | Added native tagging support, new taxonomy system for categories, and easy notification of updates, fully supports Atom 1.0, with the publishing protocol, and some much-needed security fixes. | ||||
Brecker | March 29, 2008[58] | Major revamp to the dashboard, dashboard widgets, multi-file upload, extended search, improved editor, an improved plugin system, and more. | ||||
Tyner | July 15, 2008[59] | Added new features that made WordPress a more powerful CMS: it can now track changes to every post and page and allow easy posting from anywhere on the web. | ||||
Coltrane | December 11, 2008[60] | Administration interface was redesigned fully, added automatic upgrades, and installed plugins, from within the administration interface. | ||||
Baker | June 10, 2009[61] | Added speed improvements, automatically installing themes from within the administration interface, introducing the CodePress editor for syntax highlighting, and a redesigned widget interface. | ||||
Carmen | December 19, 2009[62] | Added global undo, built-in image editor, batch plugin updating, and many less visible tweaks. | ||||
Thelonious | June 17, 2010[63] | Added new theme APIs, merged WordPress and WordPress MU, creating the new multi-site functionality, new default theme "Twenty Ten" and a refreshed, lighter admin UI. | ||||
Reinhardt | February 23, 2011[64] | Added the Admin Bar, which is displayed on all blog pages when an admin is logged in, and Post Format, best explained as a Tumblr-like micro-blogging feature. It provides easy access to many critical functions, such as comments and updates. Includes internal linking abilities, a newly streamlined writing interface, and many other changes. | ||||
Gershwin | July 4, 2011[65] | Focused on making WordPress faster and lighter. Released only four months after version 3.1, reflecting the growing speed of development in the WordPress community. | ||||
Sonny | December 12, 2011[66] | Focused on making WordPress friendlier for beginners and tablet computer users. | ||||
Green | June 13, 2012[67] | Focused on improvements to theme customization, Twitter integration and several minor changes. | ||||
Elvin | December 11, 2012[68] | Support for the Retina Display, color picker, a new default theme "Twenty Twelve", improved image workflow. | ||||
Oscar | August 1, 2013[69] | New default theme "Twenty Thirteen", admin enhancements, post formats UI update, menus UI improvements, new revision system, autosave, and post locking. | ||||
Basie | October 24, 2013[70] | Automatically apply maintenance and security updates in the background, stronger password recommendations, and support for automatically installing the right language files and keeping them up to date. | ||||
Parker | December 12, 2013[71] | Improved admin interface, responsive design for mobile devices, new typography using Open Sans, admin color schemes, redesigned theme management interface, simplified main dashboard, "Twenty Fourteen" magazine-style default theme, second release using "Plugin-first development process". | ||||
Smith | April 16, 2014[72] | Improvements to the editor for media, live widget and header previews, and new theme browser. | ||||
Benny | September 4, 2014[73] | Improved media management, embeds, writing interface, easy language change, theme customizer, plugin discovery, and compatibility with PHP 5.5 and MySQL 5.6.[74] | ||||
Dinah | December 18, 2014[75] | Twenty Fifteen as the new default theme, distraction-free writing, easy language switch, Vine embeds, and plugin recommendations. | ||||
Powell | April 23, 2015[76] | New "Press This" features, improved characters support, emoji support, improved customizer, new embeds, and updated plugin system. | ||||
Billie | August 18, 2015[77] | Focus on the mobile experience, better passwords, and improved customizer. | ||||
Clifford | December 8, 2015[78] | Introduction of "Twenty Sixteen" theme, and improved responsive images and embeds. | ||||
Coleman | April 12, 2016[79] | Added inline linking, formatting shortcuts, live responsive previews, and other updates under the hood. | ||||
Pepper | August 16, 2016[80] | Added streamlined updates, native fonts, editor improvements with inline link checker and content recovery, and other updates under the hood. | ||||
Vaughan | December 6, 2016[81] | Comes with new default theme "Twenty Seventeen", Video Header Support, PDF preview, custom CSS in the live preview, editor Improvements, and other updates under the hood. | ||||
Evans | June 8, 2017[82] | The next-generation editor. Additional specific goals include the TinyMCE inline element/link boundaries, new media widgets, and WYSIWYG in the text widget. End Support for Internet Explorer Versions 8, 9, and 10. | ||||
Tipton | November 16, 2017[83] | Improved theme customizer experience, including scheduling, frontend preview links, autosave revisions, theme browsing, improved menu functions, and syntax highlighting. Added a new gallery widget and updated text and video widgets. Theme editor gives warnings and rollbacks when saving files that produce fatal errors.[84] | ||||
Bebo | December 6, 2018[85] | New block-based editor Gutenberg[86] with new default theme "Twenty Nineteen". | ||||
Betty | February 21, 2019[87] | PHP version upgrade notices and block editor improvements. | ||||
Jaco | May 7, 2019[88] | Include Site Health Check, PHP error protection, the all-new block directory, and update package signing. | ||||
Kirk | November 12, 2019[89] | Polish current user interactions and make user interfaces more user-friendly. New default theme "Twenty Twenty", was designed by Anders Norén. | ||||
Adderley | March 31, 2020[90] | Social Icons and Buttons blocks added, blocks customization and user interface improved, added features for personal data exports, custom fields for menu items, blocks improvements for developers.[91] | ||||
Eckstine | August 11, 2020[92] | Added lazy-loading images, XML sitemaps by default, auto-updates to plugins and themes, and improvements to the block editor.[93] | ||||
Simone | December 8, 2020[94] | New default theme "Twenty Twenty-One," Gutenberg enhancements, automatic updates for core releases, increased support for PHP 8, application passwords for REST API authentication, improved accessibility.[95] | ||||
Esperanza | March 9, 2021[96] | New editor is easier to use, do more without writing custom code, simpler default color palette, from HTTP to HTTPS in a single click, new Robots API, lazy-load your iframes and ongoing cleanup after update to jQuery 3.5.1.[97] | ||||
Tatum | July 20, 2021[98] | Block widgets, query loop blocks, block themes, List View, Pattern Transformations, Duotone, new theme.json file, dropped IE11 support, WebP image support, new block support flags.[99] | ||||
Joséphine | January 25, 2022[100] | New default theme "Twenty Twenty-Two", new WordPress Admin feature Site Editor, Block Themes manageable through Site Editor, new Navigation block, improved block controls, Pattern Directory, List View, refactored Gallery block, Theme.json child theme support, block-level locking, multiple stylesheets per block.[101] | ||||
Arturo | May 24, 2022[102] | Gutenberg writing improvements, multiple style variations and expanded template options for block themes, integrated patterns, additional design tools, multiple block selections from the list view, block locking, and various performance, and accessibility improvements.[103] | ||||
Misha | November 1, 2022[104] | Gutenberg writing improvements, design tools for more consistency and control, cleaner layouts and document settings visualization, menu management, fluid typography, improved block placeholders, and spacing presets.[105] | ||||
Dolphy | March 29, 2023[106] | Reimagined Site Editor interface, improved Navigation block, Block Inserter, and organized block settings sidebar with tabs for Settings and Styles. A collection of header and footer patterns for block themes is also available, as well as Openverse media integration and Distraction Free mode for writing. The new Style Book provides a complete overview of how each block in the site's library looks, and users can now copy and paste styles and add custom CSS for more control over their site's appearance. Other features include sticky positioning for top-level group blocks, options to import favorite widgets from Classic themes, and local fonts in default WordPress themes for better privacy with Google Fonts included.[107] | ||||
Lionel | August 8, 2023[108] | Full content management through Site Editor, Block Theme preview, new My Patterns section for saved block arrangements, template and editor preference management via Command Palette, improved design tools and workflow, new Footnotes and Details block, performance and accessibility improvements. Image aspect ratio settings, distraction-free editing for Site Editor, updated Top Toolbar, improved List View, pattern template building.[109] | ||||
Shirley | November 7, 2023[110] | New default theme "Twenty Twenty-Four," writing enhancements, improved Command Palette, advanced Pattern filtering, expanded Block design tools, image lightbox functions, Group block renaming, image previews in List View, export custom patterns as JSON files, new Block Hooks feature, and various performance and accessibility improvements.[111] | ||||
Regina | April 2, 2024[112] | Google Fonts management via Font Library, view timestamps, quick summaries, and revision history via Style Book, enhanced background tools, aspect ratios, and box shadows for Block layouts and groups, Data views, enhanced drag-and-drop, improved link controls, new Interactivity and Block Bindings API's, new appearance tools for Classic themes without using theme.json, Plugin Dependencies, and various performance and accessibility improvements.[113] | ||||
Dorsey | July 16, 2024[114] | Additional color palette and font set choices, quick previews for pages, rollbacks for automatic plugin updates, Block style overrides, and various performance and accessibility improvements.[115] | ||||
Rollins | November 12, 2024[116] | New default theme "Twenty Twenty-Five," Zoom Out preview, custom fields for Blocks, font size presets for Styles, HEIC image support, and various performance and accessibility improvements.[117] | ||||
The December 2018 release of WordPress 5.0, "Bebo", is named in homage to the pioneering Cuban jazz musician Bebo Valdés.[118]
It included a new default editor "Gutenberg" – a block-based editor; that allows users to modify their displayed content in a much more user-friendly way than prior iterations. Blocks are abstract units of markup that, composed together, form the content or layout of a web page.[119] Past content that was created on WordPress pages is listed under what is referred to as a Classic Block.[120] Before Gutenberg, there were several block-based editors available as WordPress plugins, e.g. Elementor. Following the release of Gutenberg, comparisons were made between it and those existing plugins.[121] [122]
The Classic Editor plugin was created as a result of User preferences and helped website developers maintain past plugins only compatible with WordPress 4.9, giving plugin developers time to get their plugins updated & compatible with the 5.0 release. Having the Classic Editor plugin installed restores the "classic" editing experience that WordPress has had up until the WordPress 5.0 release.[123] The Classic Editor plugin will be supported at least until 2024.[124]
As of August 2023, the Classic Editor plugin is active on over 5 million installations of WordPress.[125]
Many security issues[126] have been uncovered and patched in the software, particularly in 2007, 2008, and 2015. A cumulative list of WordPress security vulnerabilities, not all of which have been corrected in the version current at any time, is maintained by SecurityScorecard.[127]
In January 2007, many high-profile search engine optimization (SEO) blogs, as well as many low-profile commercial blogs featuring AdSense, were targeted and attacked with a WordPress exploit.[128] A separate vulnerability on one of the project site's web servers allowed an attacker to introduce exploitable code in the form of a back door to some downloads of WordPress 2.1.1. The 2.1.2 release addressed this issue; an advisory released at the time advised all users to upgrade immediately.[129]
In May 2007, a study revealed that 98% of WordPress blogs being run were exploitable because they were running outdated and unsupported versions of the software.[130] To help mitigate this problem, WordPress made updating the software a much easier, "one-click" automated process in version 2.7 (released in December 2008).[131] However, the filesystem security settings required to enable the update process can be an additional risk.[132]
In a June 2007 interview, Stefan Esser, the founder of the PHP Security Response Team, spoke critically of WordPress' security track record, citing problems with the application's architecture that made it unnecessarily difficult to write code that is secure from SQL injection vulnerabilities, as well as some other problems.[133]
In June 2013, it was found that some of the 50 most downloaded WordPress plugins were vulnerable to common Web attacks such as SQL injection and XSS. A separate inspection of the top 10 e-commerce plugins showed that seven of them were vulnerable.[134]
To promote better security and to streamline the update experience overall, automatic background updates were introduced in WordPress 3.7.[135]
Individual installations of WordPress can be protected with security plugins that prevent user enumeration, hide resources, and thwart probes. Users can also protect their WordPress installations by taking steps such as keeping all WordPress installations, themes, and plugins updated, using only trusted themes and plugins,[136] and editing the site's .htaccess configuration file if supported by the webserver to prevent many types of SQL injection attacks and block unauthorized access to sensitive files. It is especially important to keep WordPress plugins updated because would-be hackers can easily list all the plugins a site uses and then run scans searching for any vulnerabilities against those plugins. If vulnerabilities are found, they may be exploited to allow hackers to, for example, upload their files (such as a web shell) that collect sensitive information.
Developers can also use tools to analyze potential vulnerabilities, including Jetpack Protect, WPScan, WordPress Auditor, and WordPress Sploit Framework developed by 0pc0deFR. These types of tools research known vulnerabilities, such as CSRF, LFI, RFI, XSS, SQL injection, and user enumeration. However, not all vulnerabilities can be detected by tools, so it is advisable to check the code of plugins, themes, and other add-ins from other developers.
In March 2015, it was reported that the Yoast SEO plugin was vulnerable to SQL injection, allowing attackers to potentially execute arbitrary SQL commands.[137] [138] The issue was fixed in version 1.7.4 of the plugin.[139]
In January 2017, security auditors at Sucuri identified a vulnerability in the WordPress REST API that would allow any unauthenticated user to modify any post or page within a site running WordPress 4.7 or greater. The auditors quietly notified WordPress developers, and within six days WordPress released a high-priority patch to version 4.7.2, which addressed the problem.[140] [141] As of WordPress 6.0, the minimum PHP version requirement is PHP 5.6,[142] which was released on August 28, 2014,[143] and which has been unsupported by the PHP Group and not received any security patches since December 31, 2018. Thus, WordPress recommends using PHP version 7.4 or greater.
In the absence of specific alterations to their default formatting code, WordPress-based websites use the canvas element to detect whether the browser can correctly render emoji. Because Tor Browser does not currently discriminate between this legitimate use of the Canvas API and an effort to perform canvas fingerprinting, it warns that the website is attempting to 'extract HTML5 canvas image data. Ongoing efforts seek workarounds to reassure privacy advocates while retaining the ability to check for proper emoji rendering capability.[144]
Matt Mullenweg and Mike Little were co-founders of the project. Current key people are listed on WordPress's Web site.[145]
WordPress is also developed by its community, including WP tester, a group of volunteers who test each release. They have early access to nightly builds, beta versions, and release candidates. Errors are documented via a mailing list and the project's Trac tool.
Though largely developed by the community surrounding it, WordPress is closely associated with Automattic, the company founded by Matt Mullenweg.[146]
WordPress Foundation is a non-profit organization that was set up to support the WordPress project.[147] [148] [149] The purpose of the organization is to guarantee open access to WordPress's software projects forever.[147] As part of this, the organization owns and manages WordPress, WordCamp, and related trademarks.[147] [9] [150] In January 2010, Matt Mullenweg formed the organization[147] to own and manage the trademarks of WordPress project.[151] [150] Previously from 2006 onwards Automattic acted as a short-term owner of the WordPress trademarks. From the beginning, he intended later to place the WordPress trademarks with the WordPress Foundation, which did not yet exist in 2006 and which eventually took longer to set up than expected.[152]
On December 14, 2021, Matt Mullenweg announced the WordPress Photo Directory at the State of the Word 2021 event. It is an open-source image directory for open images maintained by the WordPress project.[153] The image directory aims to provide an open alternative to closed image banks, such as Unsplash, Pixbaby, and Adobe Stock, whose licensing terms have become restrictive in recent years. Use in WordPress themes, for example, is restricted.[153] [154] In January 2022, the project began to gather volunteers, and in February, its own developer website was launched, where team representatives were next selected.[155]
WordCamps are casual, locally organized conferences covering everything related to WordPress.[156] The first such event was WordCamp 2006 in August 2006 in San Francisco, which lasted one day and had over 500 attendees.[157] [158] The first WordCamp outside San Francisco was held in Beijing in September 2007.[159] Since then, there have been over 1,022 WordCamps in over 75 cities in 65 countries around the world. WordCamp San Francisco 2014 was the last official annual conference of WordPress developers and users taking place in San Francisco, having now been replaced with WordCamp US.[160] First ran in 2013 as WordCamp Europe, regional WordCamps in other geographical regions are held to connect people who are not already active in their local communities and inspire attendees to start user communities in their hometowns.[161] In 2019, the Nordic region had its own WordCamp Nordic.[162] [163] The first WordCamp Asia was to be held in 2020,[164] but cancelled due to the COVID-19 pandemic.[165]
WordPress' primary support website is WordPress.org. This support website hosts both WordPress Codex, the online manual for WordPress and a living repository for WordPress information and documentation,[166] and WordPress Forums, an active online community of WordPress users.[167]
WordPress hosting services typically offer one-click WordPress installations, automated updates and backups, and security features to safeguard against common threats. Many also provide support and are configured for optimal performance with the CMS.
There are two primary types of WordPress hosting: shared WordPress hosting and managed WordPress hosting. Shared WordPress hosting is a budget-friendly option where multiple websites reside on a single server, sharing resources. Managed WordPress hosting includes comprehensive management of a WordPress site, including technical support, security, performance optimization, and often higher server resources, but comes at a higher price.