未定义的偏移量:0(Oscommerce bm.categories.php)

时间:2013-01-22 13:59:17

标签: php oscommerce

我在oscommerce中遇到了一个问题。在自定义的bm_categories.php文件中,我收到错误:

注意:未定义的偏移量:xxx中的0 \包含第52行的\ modules \ boxes \ bm_categories.php

这是代码。 我用第52行标记://这是第52行// 我真的希望有人能给我一个提示。

以下是代码:

<?php
/*
  $Id$

  osCommerce, Open Source E-Commerce Solutions
  http://www.oscommerce.com

  Copyright (c) 2010 osCommerce

  Released under the GNU General Public License
  Modfied by Kevin Neufeld
  Date: Novemeber 16, 2010
  Released as contributions: Decenber 9th, 2010

*/

  class bm_categories {
    var $code = 'bm_categories';
    var $group = 'boxes';
    var $title;
    var $description;
    var $sort_order;
    var $enabled = false;

    function bm_categories() {
      $this->title = MODULE_BOXES_CATEGORIES_TITLE;
      $this->description = MODULE_BOXES_CATEGORIES_DESCRIPTION;

      if ( defined('MODULE_BOXES_CATEGORIES_STATUS') ) {
        $this->sort_order = MODULE_BOXES_CATEGORIES_SORT_ORDER;
        $this->enabled = (MODULE_BOXES_CATEGORIES_STATUS == 'True');

        $this->group = ((MODULE_BOXES_CATEGORIES_CONTENT_PLACEMENT == 'Left Column') ? 'boxes_column_left' : 'boxes_column_right');
      }
    }

    function tep_show_category($counter) {
      global $tree, $categories_string, $cPath_array, $pCounter;           //added $pCounter
      //additional Variables
      //$pCounter is also globally defined and initialized in getData() and gets changed at the end of this function

      $nCounter = $tree[$counter]['next_id'];

     //Get item Levels
     if($pCounter == 0){
       $pLevel = 0;
     }else{
       $pLevel = $tree[$pCounter]['level'];
     }

      $cLevel = $tree[$counter]['level'];

//<---- THIS IS LINE 52 ------>//
     $nLevel = $tree[$nCounter]['level'];


      //Start of UnsortedList <ul> if Category level > 0
      if($cLevel > 0){
        if($cLevel != $pLevel){
            $categories_string .= '<ul class="level ' . $cLevel . '">';
        }
      }

      //Start of ListItem <li> and determines if List Item is Current
      if (isset($cPath_array) && in_array($counter, $cPath_array)) {
        if($cLevel == 0){
          $categories_string .= '<li id="current" class=" active item'.$counter.'"><a href="';
        }else{
          $categories_string .= '<li class="item'.$counter.'"><a href="';
        }
      }else{
        $categories_string .= '<li class="item'.$counter.'"><a href="';
      }

      //Gets and inserts URL path for link
      if ($tree[$counter]['parent'] == 0) {
        $cPath_new = 'cPath=' . $counter;
      } else {
        $cPath_new = 'cPath=' . $tree[$counter]['path'];
      }

      $categories_string .= tep_href_link(FILENAME_DEFAULT, $cPath_new) . '">';

      //Gets CatgoryCounts if Set in Admin -- Seperator is also located here
      if (SHOW_COUNTS == 'true') {
        $products_in_category = tep_count_products_in_category($counter);
        if ($products_in_category > 0) {
          $showCount_string = '<span class="countSeperator">&nbsp;&raquo;&nbsp;</span><span class="showCounts">[' . $products_in_category . ']</span>';
        }
      }

      //Start of Span <span> around Category Name
      if (isset($cPath_array) && in_array($counter, $cPath_array)) {
        $categories_string .= '<span class="itemParentName">' . $tree[$counter]['name'] . '</span></a>';
      } else {
        $categories_string .= '<span class="itemName">'. $tree[$counter]['name'] . '</span></a></li>';
      }

      //This is used to determin the level and place the correct number of closing tags  
      if($cLevel > 0){
        if ($cLevel > $nLevel){
          $j = abs($cLevel - $nLevel);
          $categories_string .= str_repeat('</ul></li>', $j);
        }elseif ($nCounter == false){
          $categories_string .= str_repeat('</ul></li>', $tree[$counter]['level']);
        }
     }

      $pCounter = $counter;

      if ($tree[$counter]['next_id'] != false) {
        $this->tep_show_category($tree[$counter]['next_id']);
      }
    }

    function getData() {
      global $categories_string, $tree, $languages_id, $cPath, $cPath_array, $pCounter;           //added $pCounter
      $pCounter = 0;        //initialize $pCounter
      $categories_string = '';
      $tree = array();

      $categories_query = tep_db_query("select c.categories_id, cd.categories_name, c.parent_id from " . TABLE_CATEGORIES . " c, " . TABLE_CATEGORIES_DESCRIPTION . " cd where c.parent_id = '0' and c.categories_status = 1 and c.categories_id = cd.categories_id and cd.language_id='" . (int)$languages_id ."' order by sort_order, cd.categories_name");
      while ($categories = tep_db_fetch_array($categories_query))  {
        $tree[$categories['categories_id']] = array('name' => $categories['categories_name'],
                                                    'parent' => $categories['parent_id'],
                                                    'level' => 0,
                                                    'path' => $categories['categories_id'],
                                                    'next_id' => false);

        if (isset($parent_id)) {
          $tree[$parent_id]['next_id'] = $categories['categories_id'];
        }

        $parent_id = $categories['categories_id'];

        if (!isset($first_element)) {
          $first_element = $categories['categories_id'];
        }
      }

      if (tep_not_null($cPath)) {
        $new_path = '';
        reset($cPath_array);
        while (list($key, $value) = each($cPath_array)) {
          unset($parent_id);
          unset($first_id);
          $categories_query = tep_db_query("select c.categories_id, cd.categories_name, c.parent_id from " . TABLE_CATEGORIES . " c, " . TABLE_CATEGORIES_DESCRIPTION . " cd where c.parent_id = '" . (int)$value . "' and c.categories_status = 1 and c.categories_id = cd.categories_id and cd.language_id='" . (int)$languages_id ."' order by sort_order, cd.categories_name");
          if (tep_db_num_rows($categories_query)) {
            $new_path .= $value;
            while ($row = tep_db_fetch_array($categories_query)) {
              $tree[$row['categories_id']] = array('name' => ''.$row['categories_name'],
                                                   'parent' => $row['parent_id'],
                                                   'level' => $key+1,
                                                   'path' => $new_path . '_' . $row['categories_id'],
                                                   'next_id' => false);

              if (isset($parent_id)) {
                $tree[$parent_id]['next_id'] = $row['categories_id'];
              }

              $parent_id = $row['categories_id'];

              if (!isset($first_id)) {
                $first_id = $row['categories_id'];
              }

              $last_id = $row['categories_id'];
            }
            $tree[$last_id]['next_id'] = $tree[$value]['next_id'];
            $tree[$value]['next_id'] = $first_id;
            $new_path .= '_';
          } else {
            break;
          }
        }
      }

      $this->tep_show_category($first_element);

      $data = '<div id="categoryBoxContainer" class="ui-widget infoBoxContainer">' .
              '  <div class="ui-widget-header infoBoxHeading">' . MODULE_BOXES_CATEGORIES_BOX_TITLE . '</div>' .
              '  <div class="ui-widget-content infoBoxContents" style="background-color:#f5f5f5; border:none;"><ul class="menu">' . $categories_string . '</ul></div>' .
              '</div>';


      return $data;
    }

    function execute() {
      global $SID, $oscTemplate;

      if ((USE_CACHE == 'true') && empty($SID)) {
        $output = tep_cache_categories_box();
      } else {
        $output = $this->getData();
      }

      $oscTemplate->addBlock($output, $this->group);
    }

    function isEnabled() {
      return $this->enabled;
    }

    function check() {
      return defined('MODULE_BOXES_CATEGORIES_STATUS');
    }

    function install() {
      tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ('Enable Categories Module', 'MODULE_BOXES_CATEGORIES_STATUS', 'True', 'Do you want to add the module to your shop?', '6', '1', 'tep_cfg_select_option(array(\'True\', \'False\'), ', now())");
      tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, set_function, date_added) values ('Content Placement', 'MODULE_BOXES_CATEGORIES_CONTENT_PLACEMENT', 'Left Column', 'Should the module be loaded in the left or right column?', '6', '1', 'tep_cfg_select_option(array(\'Left Column\', \'Right Column\'), ', now())");
      tep_db_query("insert into " . TABLE_CONFIGURATION . " (configuration_title, configuration_key, configuration_value, configuration_description, configuration_group_id, sort_order, date_added) values ('Sort Order', 'MODULE_BOXES_CATEGORIES_SORT_ORDER', '0', 'Sort order of display. Lowest is displayed first.', '6', '0', now())");
    }

    function remove() {
      tep_db_query("delete from " . TABLE_CONFIGURATION . " where configuration_key in ('" . implode("', '", $this->keys()) . "')");
    }

    function keys() {
      return array('MODULE_BOXES_CATEGORIES_STATUS', 'MODULE_BOXES_CATEGORIES_CONTENT_PLACEMENT', 'MODULE_BOXES_CATEGORIES_SORT_ORDER');
    }
  }
?>

2 个答案:

答案 0 :(得分:0)

这样做。如果$ tree的索引为0,则获取其值,否则将其设置为空字符串或任何你想要的

$nLevel = isset($tree[$nCounter]['level']) ? $tree[$nCounter]['level'] : '';

答案 1 :(得分:0)

这意味着,您的数组没有值为0的键。检查$tree数组:

var_dump( $tree );

看看里面有什么。

似乎,那:

$nCounter = $tree[$counter]['next_id'];

没有任何价值;可能是,没有next_id?如果是,请在发布前与isset核对:

$nLevel = (isset($tree[$nCounter]['level']) ? $tree[$nCounter]['level'] : '');

或在设置nCounter时添加相同的检查:

$nCounter = (isset($tree[$counter]['next_id']) ? $tree[$counter]['next_id'] : 0);