CPE, qui signifie Common Platform Enumeration, est un système normalisé de dénomination du matériel, des logiciels et des systèmes d'exploitation. CPE fournit un schéma de dénomination structuré pour identifier et classer de manière unique les systèmes informatiques, les plates-formes et les progiciels sur la base de certains attributs tels que le fournisseur, le nom du produit, la version, la mise à jour, l'édition et la langue.
CWE, ou Common Weakness Enumeration, est une liste complète et une catégorisation des faiblesses et des vulnérabilités des logiciels. Elle sert de langage commun pour décrire les faiblesses de sécurité des logiciels au niveau de l'architecture, de la conception, du code ou de la mise en œuvre, qui peuvent entraîner des vulnérabilités.
CAPEC, qui signifie Common Attack Pattern Enumeration and Classification (énumération et classification des schémas d'attaque communs), est une ressource complète, accessible au public, qui documente les schémas d'attaque communs utilisés par les adversaires dans les cyberattaques. Cette base de connaissances vise à comprendre et à articuler les vulnérabilités communes et les méthodes utilisées par les attaquants pour les exploiter.
Services & Prix
Aides & Infos
Recherche de CVE id, CWE id, CAPEC id, vendeur ou mots clés dans les CVE
SQL injection vulnerability in wp-includes/query.php in WordPress 2.3.1 and earlier allows remote attackers to execute arbitrary SQL commands via the s parameter, when DB_CHARSET is set to (1) Big5, (2) GBK, or possibly other character set encodings that support a "\" in a multibyte character.
Improper Neutralization of Special Elements used in an SQL Command ('SQL Injection') The product constructs all or part of an SQL command using externally-influenced input from an upstream component, but it does not neutralize or incorrectly neutralizes special elements that could modify the intended SQL command when it is sent to a downstream component. Without sufficient removal or quoting of SQL syntax in user-controllable inputs, the generated SQL query can cause those inputs to be interpreted as SQL instead of ordinary user data.
Métriques
Métriques
Score
Gravité
CVSS Vecteur
Source
V2
6.8
AV:N/AC:M/Au:N/C:P/I:P/A:P
nvd@nist.gov
EPSS
EPSS est un modèle de notation qui prédit la probabilité qu'une vulnérabilité soit exploitée.
Score EPSS
Le modèle EPSS produit un score de probabilité compris entre 0 et 1 (0 et 100 %). Plus la note est élevée, plus la probabilité qu'une vulnérabilité soit exploitée est grande.
Date
EPSS V0
EPSS V1
EPSS V2 (> 2022-02-04)
EPSS V3 (> 2025-03-07)
EPSS V4 (> 2025-03-17)
2022-02-06
–
–
4.39%
–
–
2022-04-03
–
–
4.39%
–
–
2022-08-28
–
–
4.39%
–
–
2023-03-12
–
–
–
0.39%
–
2023-06-11
–
–
–
0.39%
–
2023-12-31
–
–
–
0.39%
–
2024-01-28
–
–
–
0.55%
–
2024-02-11
–
–
–
0.55%
–
2024-06-02
–
–
–
0.55%
–
2024-09-08
–
–
–
0.94%
–
2024-10-20
–
–
–
1.1%
–
2024-12-22
–
–
–
0.8%
–
2025-01-05
–
–
–
0.85%
–
2025-02-09
–
–
–
0.84%
–
2025-01-19
–
–
–
0.85%
–
2025-02-16
–
–
–
0.84%
–
2025-03-18
–
–
–
–
6.56%
2025-04-15
–
–
–
–
6.56%
2025-07-30
–
–
–
–
5.59%
2025-09-30
–
–
–
–
4.2%
2025-10-01
–
–
–
–
4.94%
2025-10-01
–
–
–
–
4.94,%
Percentile EPSS
Le percentile est utilisé pour classer les CVE en fonction de leur score EPSS. Par exemple, une CVE dans le 95e percentile selon son score EPSS est plus susceptible d'être exploitée que 95 % des autres CVE. Ainsi, le percentile sert à comparer le score EPSS d'une CVE par rapport à d'autres CVE.
Date de publication : 2007-12-10 23h00 +00:00 Auteur : Abel Cheung EDB Vérifié : Yes
=== WordPress Charset SQL Injection Vulnerability ===
Release date: 2007-12-10
Last modified: 2007-12-12
Source: Abel Cheung <abelcheung at gmail dot com>
Affected version: WordPress <= 2.3.1
Exploit type: Remote
Risk: Moderate
CVE: pending
Reference: http://www.abelcheung.org/advisory/20071210-wordpress-charset.txt
1. Summary
2. Detail
3. Proof of concept
4. Workaround
1. Summary
Quoting from http://wordpress.org/:
WordPress is a state-of-the-art semantic personal publishing platform
with a focus on aesthetics, web standards, and usability.
What a mouthful. WordPress is both free and priceless at the same time.
It is found that the search function provided within WordPress fails to
sanitize input based on different character sets. So if WordPress tries
to query MySQL database using certain specific character sets, WordPress
search function is exploitable using charset-based SQL injection.
Currently known character sets exploitable include Big5 and GBK.
All of them may use backslash ('\') as part of multibyte character.
WordPress with MySQL database created any other character sets fulfilling
such property may also be exploitable.
Executing this attack alone results in exposure of all database
content on web interface without need of authentication. However, if
combined with other exploits (such as cookie authentication vulnerability
in http://www.cl.cam.ac.uk/~sjm217/advisories/wordpress-cookie-auth.txt),
any remote user can obtain WordPress admin privilege, resulting in server
compromise.
2. Detail
Most database query in WordPress uses escape() method to sanitize SQL
string, which is essentially filtering input via addslashes() function.
However addslashes() fails to consider character set used in SQL string,
and blindly inserts backslash before any single quote, regardless of
whether such backslashes will form another valid character or not.
In proof of concept used in this advisory, two bytes 0xB327 is
injected into search variable. After escaping string with escape(),
a backslash (0x5C) is inserted before single quote (0x27), thus becoming
0xB35C27. However 0xB35C is a valid Big5 multibyte character,
leaving the single quote behind, so SQL injection occurs. The same
multibyte character is also valid under GBK encoding.
Inside SQL statement used within proof of concept, MD5 hashes of all
users' passwords are selected from database, and presented as post
title. With suitable SQL statement, any database field can be dumped
in similar way.
Currently it is known that WordPress search function uses this
insufficient method to sanitize database query. Possibly other
database queries utilizing same method to filter user input can be
equally susceptible.
However, note that WordPress sites using such character sets is not
very common, since most default installation uses either latin1 or utf8
character set. Asian sites, in particular Chinese ones, are more likely
vulnerable.
Although all WordPress versions before 2.3.1 are vulnerable, only
WordPress 2.2 or above allows changing database query character set
via WordPress configuration file (wp-config.php). For all versions
below 2.2, modifying MySQL configuration to use those character sets
is needed for exploit to be functional. The setting of WordPress HTML
character set (adjustable within WordPress admin page) is irrelevant.
Relevant code is listed below. In wp-includes/query.php:
// If a search pattern is specified, load the posts that match
if ( !empty($q['s']) ) {
......
foreach((array)$q['search_terms'] as $term) {
$term = addslashes_gpc($term);
......
}
addslashes_gpc() is defined in wp-includes/formatting.php:
function addslashes_gpc($gpc) {
......
return $wpdb->escape($gpc);
}
Finally, escape() method belongs to wp-includes/wp-db.php:
function escape($string) {
return addslashes( $string ); // Disable rest for now, causing problems
......
}
3. Proof of concept
a. After WordPress installation, modify wp-config.php to make sure
it uses certain character set for database connection (Big5 can also be used):
define('DB_CHARSET', 'GBK');
b. http://localhost/wordpress/index.php?exact=1&sentence=1&s=%b3%27)))/**/AND/**/ID=-1/**/UNION/**/SELECT/**/1,2,3,4,5,user_pass,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24/**/FROM/**/wp_users%23
4. Workaround
Note: This vulnerability only exists for database queries performed
using certain character sets. For databases created in most other
character sets no remedy is needed.
a. It is recommended to convert WordPress database to use character sets not
vulnerable to such SQL exploit. One such charset is UTF-8, which does not
use backslash ('\') as part of character and it supports various languages.
Even if database charset conversion is inconvenient or impossible, use UTF-8
as DB_CHARSET setting to avoid sending query using vulnerable multibyte charset.
b. Alternatively, modify WordPress core (query.php) to remove search capability.
ChangeLog:
- 2007-12-12
* Modify workaround (thanks to Florian Sander for suggestion)
# milw0rm.com [2007-12-11]