“<b>解析错误</b>:语法错误,<b> /home/site/public_html/devel/modules//filter.php </b>中的意外”{“<b>行<b> 35 </b> <br/>“

时间:2016-04-27 21:35:35

标签: php joomla joomla-module

我面临一个非常奇怪的问题,一个脚本工作2周前,现在抛出以下错误:

"<br /> <b>Parse error</b>: syntax error, unexpected '{' in <b>/home/site/public_html/devel/modules/filter.php</b> on line <b>35</b><br /> "

这是代码,我看了几千次,但我无法弄清楚它有什么问题......

   <?php

define('_JEXEC',1); 
define('JPATH_BASE', realpath(dirname(__FILE__).'/../..' ));

require_once(JPATH_BASE.'/includes/defines.php');
require_once(JPATH_BASE.'/includes/framework.php');
$mainframe = JFactory::getApplication('site');
$mainframe->initialise();
$db = JFactory::getDBO();

ob_start();
header("Access-Control-Allow-Origin: *");
header('Content-Type: application/json');


  function getCountries() {
     try {
       $db = JFactory::getDBO();
       $query = "SELECT id, name FROM `#__countries`";
       $db->setQuery($query);
       $result =  $db->loadRowList();
       if(!$result) {
         throw new exception("Country not found.");
       }
       $res = array();
          foreach($result as $key=>$value) {
        $res[$value[0]] = $value[1];
       }
       $data = array('status'=>'success', 'tp'=>1, 'msg'=>"Countries fetched successfully.", 'result'=>$res);
     }
     catch (Exception $e) {
       $data = array('status'=>'error', 'tp'=>0, 'msg'=>$e->getMessage());
     } 
     finally {
        return $data;
     }
   }

  // Fetch all states list by country id
  function getStates($countryId) {
     try {
       $db = JFactory::getDBO();
       $query = "SELECT id, name FROM #__states WHERE country_id=".$countryId;
       $db->setQuery($query);
       $result =  $db->loadRowList();
       if(!$result) {
         throw new exception("State not found.");
       }
       $res = array();
         foreach($result as $key=>$value) {
        $res[$value[0]] = $value[1];
       }
       $data = array('status'=>'success', 'tp'=>1, 'msg'=>"States fetched successfully.", 'result'=>$res);
     } catch (Exception $e) {
       $data = array('status'=>'error', 'tp'=>0, 'msg'=>$e->getMessage());
     } finally {
        return $data;
     }
   }

 // Fetch all cities list by state id
  function getCities($stateId) {
     try {
       $db = JFactory::getDBO();
       $query = "SELECT id, name FROM #__cities WHERE state_id=".$stateId;
       $db->setQuery($query);
       $result =  $db->loadRowList();
       if(!$result) {
         throw new exception("City not found.");
       }
       $res = array();
         foreach($result as $key=>$value) {
        $res[$value[0]] = $value[1];
       }
       $data = array('status'=>'success', 'tp'=>1, 'msg'=>"Cities fetched successfully.", 'result'=>$res);
     } catch (Exception $e) {
       $data = array('status'=>'error', 'tp'=>0, 'msg'=>$e->getMessage());
     } finally {return $data;}}   

try {
  if(!isset($_GET['type']) || empty($_GET['type'])) {
    throw new exception("Type is not set.");
  }
  $type = $_GET['type'];
  if($type=='getCountries') {
    $data = getCountries();
  } 

  if($type=='getStates') {
     if(!isset($_GET['countryId']) || empty($_GET['countryId'])) {
        throw new exception("Country Id is not set.");
     }
     $countryId = $_GET['countryId'];
     $data = getStates($countryId);
  }

   if($type=='getCities') {
     if(!isset($_GET['stateId']) || empty($_GET['stateId'])) {
        throw new exception("State Id is not set.");
     }
     $stateId = $_GET['stateId'];
     $data = getCities($stateId);
  }

} catch (Exception $e) {
   $data = array('status'=>'error', 'tp'=>0, 'msg'=>$e->getMessage());
} finally {
  echo json_encode($data);
}

ob_flush();
?>

有人可以告诉我出了什么问题吗?

1 个答案:

答案 0 :(得分:1)

在PHP 5.6上解析得很好。第35行是finally关键字。如果你的PHP版本早于5.5,我想你会在这里得到一个解析错误。