--- a/web/lib/Zend/Service/Audioscrobbler.php Thu May 07 15:10:09 2015 +0200
+++ b/web/lib/Zend/Service/Audioscrobbler.php Thu May 07 15:16:02 2015 +0200
@@ -16,9 +16,9 @@
* @category Zend
* @package Zend_Service
* @subpackage Audioscrobbler
- * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
+ * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
- * @version $Id: Audioscrobbler.php 24593 2012-01-05 20:35:02Z matthew $
+ * @version $Id$
*/
@@ -27,12 +27,14 @@
*/
require_once 'Zend/Http/Client.php';
+/** @see Zend_Xml_Security */
+require_once 'Zend/Xml/Security.php';
/**
* @category Zend
* @package Zend_Service
* @subpackage Audioscrobbler
- * @copyright Copyright (c) 2005-2012 Zend Technologies USA Inc. (http://www.zend.com)
+ * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
* @license http://framework.zend.com/license/new-bsd New BSD License
*/
class Zend_Service_Audioscrobbler
@@ -69,9 +71,15 @@
{
$this->set('version', '1.0');
- iconv_set_encoding('output_encoding', 'UTF-8');
- iconv_set_encoding('input_encoding', 'UTF-8');
- iconv_set_encoding('internal_encoding', 'UTF-8');
+ if (PHP_VERSION_ID < 50600) {
+ iconv_set_encoding('output_encoding', 'UTF-8');
+ iconv_set_encoding('input_encoding', 'UTF-8');
+ iconv_set_encoding('internal_encoding', 'UTF-8');
+ } else {
+ ini_set('output_encoding', 'UTF-8');
+ ini_set('input_encoding', 'UTF-8');
+ ini_set('default_charset', 'UTF-8');
+ }
}
/**
@@ -182,7 +190,7 @@
set_error_handler(array($this, '_errorHandler'));
- if (!$simpleXmlElementResponse = simplexml_load_string($responseBody)) {
+ if (!$simpleXmlElementResponse = Zend_Xml_Security::scan($responseBody)) {
restore_error_handler();
/**
* @see Zend_Service_Exception
@@ -640,7 +648,7 @@
* @param array $errcontext
* @return void
*/
- protected function _errorHandler($errno, $errstr, $errfile, $errline, array $errcontext)
+ public function _errorHandler($errno, $errstr, $errfile, $errline, array $errcontext)
{
$this->_error = array(
'errno' => $errno,