summaryrefslogtreecommitdiff
path: root/modules/exif/helpers/exif.php
diff options
context:
space:
mode:
authorBharat Mediratta <bharat@menalto.com>2009-05-05 03:30:49 +0000
committerBharat Mediratta <bharat@menalto.com>2009-05-05 03:30:49 +0000
commit13f8a0dd7baf07ebddc72c1764b5ab13f3c9f42c (patch)
treeb0d5a2f006c1dd9a528c4eb7eca2e428b40566ac /modules/exif/helpers/exif.php
parent2434feabeb9244eabe61d906eafce7adb518319e (diff)
Detect input encodings from EXIF/IPTC data and convert to utf-8 as
appropriate. This allows us to switch the exif value column back to varchar and improves the way that we deal with non-utf8 data in our embedded EXIF/IPTC data.
Diffstat (limited to 'modules/exif/helpers/exif.php')
-rw-r--r--modules/exif/helpers/exif.php17
1 files changed, 11 insertions, 6 deletions
diff --git a/modules/exif/helpers/exif.php b/modules/exif/helpers/exif.php
index 9bdbc172..25d9eadd 100644
--- a/modules/exif/helpers/exif.php
+++ b/modules/exif/helpers/exif.php
@@ -37,10 +37,11 @@ class exif_Core {
if (isset($exif_raw['ValidEXIFData'])) {
foreach(self::_keys() as $field => $exifvar) {
if (isset($exif_raw[$exifvar[0]][$exifvar[1]])) {
- $data[] = sprintf(
- "(%d, '%s', '%s')",
- $item->id, $db->escape_str($field),
- $db->escape_str($exif_raw[$exifvar[0]][$exifvar[1]]));
+ $value = $exif_raw[$exifvar[0]][$exifvar[1]];
+ if (mb_detect_encoding($value) != "UTF-8") {
+ $value = utf8_encode($value);
+ }
+ $data[] = sprintf("(%d, '%s', '%s')", $item->id, $field, $db->escape_str($value));
}
}
}
@@ -49,10 +50,14 @@ class exif_Core {
$iptc = iptcparse($info["APP13"]);
foreach (array("Keywords" => "2#025", "Caption" => "2#120") as $keyword => $iptc_key) {
if (!empty($iptc[$iptc_key])) {
+ $value = implode(" ", $iptc[$iptc_key]);
+ if (mb_detect_encoding($value) != "UTF-8") {
+ $value = utf8_encode($value);
+ }
$data[] = sprintf(
"(%d, '%s', '%s')",
- $item->id, $db->escape_str($keyword),
- $db->escape_str(implode(" ", $iptc[$iptc_key])));
+ $item->id, $keyword,
+ $db->escape_str($value));
}
}
}