Warning: strlen() expects parameter 1












2















Im constantly seeing the following error in system.log I've gone into the file but cant see anything wrong can any one help me?



Warning: strlen() expects parameter 1 to be string, array given in /app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php on line 93










share|improve this question

























  • Do you use an old version of Amasty Order Attributes? :-) Upgrade the extension.

    – Fabian Blechschmidt
    May 28 '14 at 10:46











  • @FabianBlechschmidt Nope ive never used that module we have used the promo items though?

    – Will Wright
    May 28 '14 at 10:56











  • I know this error from the OrderAttributes extension, but maybe it happens there too...

    – Fabian Blechschmidt
    May 28 '14 at 12:15











  • Which concrete Magento version are you using?

    – Raul Sanchez
    Jan 21 at 17:43











  • @RaulSanchez it was some version of 1.9 probably 1.9.2.x any way onto M2 now

    – Will Wright
    Jan 21 at 17:46
















2















Im constantly seeing the following error in system.log I've gone into the file but cant see anything wrong can any one help me?



Warning: strlen() expects parameter 1 to be string, array given in /app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php on line 93










share|improve this question

























  • Do you use an old version of Amasty Order Attributes? :-) Upgrade the extension.

    – Fabian Blechschmidt
    May 28 '14 at 10:46











  • @FabianBlechschmidt Nope ive never used that module we have used the promo items though?

    – Will Wright
    May 28 '14 at 10:56











  • I know this error from the OrderAttributes extension, but maybe it happens there too...

    – Fabian Blechschmidt
    May 28 '14 at 12:15











  • Which concrete Magento version are you using?

    – Raul Sanchez
    Jan 21 at 17:43











  • @RaulSanchez it was some version of 1.9 probably 1.9.2.x any way onto M2 now

    – Will Wright
    Jan 21 at 17:46














2












2








2








Im constantly seeing the following error in system.log I've gone into the file but cant see anything wrong can any one help me?



Warning: strlen() expects parameter 1 to be string, array given in /app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php on line 93










share|improve this question
















Im constantly seeing the following error in system.log I've gone into the file but cant see anything wrong can any one help me?



Warning: strlen() expects parameter 1 to be string, array given in /app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php on line 93







php






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Jan 21 at 17:25







Will Wright

















asked May 28 '14 at 10:13









Will WrightWill Wright

3171213




3171213













  • Do you use an old version of Amasty Order Attributes? :-) Upgrade the extension.

    – Fabian Blechschmidt
    May 28 '14 at 10:46











  • @FabianBlechschmidt Nope ive never used that module we have used the promo items though?

    – Will Wright
    May 28 '14 at 10:56











  • I know this error from the OrderAttributes extension, but maybe it happens there too...

    – Fabian Blechschmidt
    May 28 '14 at 12:15











  • Which concrete Magento version are you using?

    – Raul Sanchez
    Jan 21 at 17:43











  • @RaulSanchez it was some version of 1.9 probably 1.9.2.x any way onto M2 now

    – Will Wright
    Jan 21 at 17:46



















  • Do you use an old version of Amasty Order Attributes? :-) Upgrade the extension.

    – Fabian Blechschmidt
    May 28 '14 at 10:46











  • @FabianBlechschmidt Nope ive never used that module we have used the promo items though?

    – Will Wright
    May 28 '14 at 10:56











  • I know this error from the OrderAttributes extension, but maybe it happens there too...

    – Fabian Blechschmidt
    May 28 '14 at 12:15











  • Which concrete Magento version are you using?

    – Raul Sanchez
    Jan 21 at 17:43











  • @RaulSanchez it was some version of 1.9 probably 1.9.2.x any way onto M2 now

    – Will Wright
    Jan 21 at 17:46

















Do you use an old version of Amasty Order Attributes? :-) Upgrade the extension.

– Fabian Blechschmidt
May 28 '14 at 10:46





Do you use an old version of Amasty Order Attributes? :-) Upgrade the extension.

– Fabian Blechschmidt
May 28 '14 at 10:46













@FabianBlechschmidt Nope ive never used that module we have used the promo items though?

– Will Wright
May 28 '14 at 10:56





@FabianBlechschmidt Nope ive never used that module we have used the promo items though?

– Will Wright
May 28 '14 at 10:56













I know this error from the OrderAttributes extension, but maybe it happens there too...

– Fabian Blechschmidt
May 28 '14 at 12:15





I know this error from the OrderAttributes extension, but maybe it happens there too...

– Fabian Blechschmidt
May 28 '14 at 12:15













Which concrete Magento version are you using?

– Raul Sanchez
Jan 21 at 17:43





Which concrete Magento version are you using?

– Raul Sanchez
Jan 21 at 17:43













@RaulSanchez it was some version of 1.9 probably 1.9.2.x any way onto M2 now

– Will Wright
Jan 21 at 17:46





@RaulSanchez it was some version of 1.9 probably 1.9.2.x any way onto M2 now

– Will Wright
Jan 21 at 17:46










2 Answers
2






active

oldest

votes


















4














This is from my copy (1.7.0.2) of app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php



_getOptionText is returning an array, not a string like the code is clearly expecting. I'd see what class getFrontend is returning and then see how that can be returning an array.



protected function _getOptionText($optionId)
{
return $this->getAttributeModel()->getFrontend()->getOption($optionId);
}

/**
* Apply attribute option filter to product collection
*
* @param Zend_Controller_Request_Abstract $request
* @param Varien_Object $filterBlock
* @return Mage_Catalog_Model_Layer_Filter_Attribute
*/
public function apply(Zend_Controller_Request_Abstract $request, $filterBlock)
{
$filter = $request->getParam($this->_requestVar);
if (is_array($filter)) {
return $this;
}
$text = $this->_getOptionText($filter);
if ($filter && strlen($text)) {
$this->_getResource()->applyFilterToCollection($this, $filter);
$this->getLayer()->getState()->addFilter($this->_createItem($text, $filter));
$this->_items = array();
}
return $this;
}





share|improve this answer
























  • +1 someone who offers some decent advice and explains how to understand the problem, not a hack.

    – ash
    May 28 '14 at 13:36



















0














strlen() is a function which gives the length of the string you passed as a parameter.



The error is that you must be passing an array in the strlen(). Please check the value you are passing.
It should be string.



Check your file "Attribute.php" at line no. 93.






share|improve this answer



















  • 2





    downvoted - because stating the obvious and rewording the error in laymans terms doesn't really answer the question. I'm presuming the point of the question is more understanding why Magentos' Core is fragmented.

    – ash
    May 28 '14 at 13:33











  • Upvote, I don't see why this answer couldn't be valid

    – Raul Sanchez
    Jan 21 at 17:44











Your Answer








StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "479"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});

function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: false,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: null,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});


}
});














draft saved

draft discarded


















StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmagento.stackexchange.com%2fquestions%2f21651%2fwarning-strlen-expects-parameter-1%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown

























2 Answers
2






active

oldest

votes








2 Answers
2






active

oldest

votes









active

oldest

votes






active

oldest

votes









4














This is from my copy (1.7.0.2) of app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php



_getOptionText is returning an array, not a string like the code is clearly expecting. I'd see what class getFrontend is returning and then see how that can be returning an array.



protected function _getOptionText($optionId)
{
return $this->getAttributeModel()->getFrontend()->getOption($optionId);
}

/**
* Apply attribute option filter to product collection
*
* @param Zend_Controller_Request_Abstract $request
* @param Varien_Object $filterBlock
* @return Mage_Catalog_Model_Layer_Filter_Attribute
*/
public function apply(Zend_Controller_Request_Abstract $request, $filterBlock)
{
$filter = $request->getParam($this->_requestVar);
if (is_array($filter)) {
return $this;
}
$text = $this->_getOptionText($filter);
if ($filter && strlen($text)) {
$this->_getResource()->applyFilterToCollection($this, $filter);
$this->getLayer()->getState()->addFilter($this->_createItem($text, $filter));
$this->_items = array();
}
return $this;
}





share|improve this answer
























  • +1 someone who offers some decent advice and explains how to understand the problem, not a hack.

    – ash
    May 28 '14 at 13:36
















4














This is from my copy (1.7.0.2) of app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php



_getOptionText is returning an array, not a string like the code is clearly expecting. I'd see what class getFrontend is returning and then see how that can be returning an array.



protected function _getOptionText($optionId)
{
return $this->getAttributeModel()->getFrontend()->getOption($optionId);
}

/**
* Apply attribute option filter to product collection
*
* @param Zend_Controller_Request_Abstract $request
* @param Varien_Object $filterBlock
* @return Mage_Catalog_Model_Layer_Filter_Attribute
*/
public function apply(Zend_Controller_Request_Abstract $request, $filterBlock)
{
$filter = $request->getParam($this->_requestVar);
if (is_array($filter)) {
return $this;
}
$text = $this->_getOptionText($filter);
if ($filter && strlen($text)) {
$this->_getResource()->applyFilterToCollection($this, $filter);
$this->getLayer()->getState()->addFilter($this->_createItem($text, $filter));
$this->_items = array();
}
return $this;
}





share|improve this answer
























  • +1 someone who offers some decent advice and explains how to understand the problem, not a hack.

    – ash
    May 28 '14 at 13:36














4












4








4







This is from my copy (1.7.0.2) of app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php



_getOptionText is returning an array, not a string like the code is clearly expecting. I'd see what class getFrontend is returning and then see how that can be returning an array.



protected function _getOptionText($optionId)
{
return $this->getAttributeModel()->getFrontend()->getOption($optionId);
}

/**
* Apply attribute option filter to product collection
*
* @param Zend_Controller_Request_Abstract $request
* @param Varien_Object $filterBlock
* @return Mage_Catalog_Model_Layer_Filter_Attribute
*/
public function apply(Zend_Controller_Request_Abstract $request, $filterBlock)
{
$filter = $request->getParam($this->_requestVar);
if (is_array($filter)) {
return $this;
}
$text = $this->_getOptionText($filter);
if ($filter && strlen($text)) {
$this->_getResource()->applyFilterToCollection($this, $filter);
$this->getLayer()->getState()->addFilter($this->_createItem($text, $filter));
$this->_items = array();
}
return $this;
}





share|improve this answer













This is from my copy (1.7.0.2) of app/code/core/Mage/Catalog/Model/Layer/Filter/Attribute.php



_getOptionText is returning an array, not a string like the code is clearly expecting. I'd see what class getFrontend is returning and then see how that can be returning an array.



protected function _getOptionText($optionId)
{
return $this->getAttributeModel()->getFrontend()->getOption($optionId);
}

/**
* Apply attribute option filter to product collection
*
* @param Zend_Controller_Request_Abstract $request
* @param Varien_Object $filterBlock
* @return Mage_Catalog_Model_Layer_Filter_Attribute
*/
public function apply(Zend_Controller_Request_Abstract $request, $filterBlock)
{
$filter = $request->getParam($this->_requestVar);
if (is_array($filter)) {
return $this;
}
$text = $this->_getOptionText($filter);
if ($filter && strlen($text)) {
$this->_getResource()->applyFilterToCollection($this, $filter);
$this->getLayer()->getState()->addFilter($this->_createItem($text, $filter));
$this->_items = array();
}
return $this;
}






share|improve this answer












share|improve this answer



share|improve this answer










answered May 28 '14 at 12:48









RichardRichard

1,662717




1,662717













  • +1 someone who offers some decent advice and explains how to understand the problem, not a hack.

    – ash
    May 28 '14 at 13:36



















  • +1 someone who offers some decent advice and explains how to understand the problem, not a hack.

    – ash
    May 28 '14 at 13:36

















+1 someone who offers some decent advice and explains how to understand the problem, not a hack.

– ash
May 28 '14 at 13:36





+1 someone who offers some decent advice and explains how to understand the problem, not a hack.

– ash
May 28 '14 at 13:36













0














strlen() is a function which gives the length of the string you passed as a parameter.



The error is that you must be passing an array in the strlen(). Please check the value you are passing.
It should be string.



Check your file "Attribute.php" at line no. 93.






share|improve this answer



















  • 2





    downvoted - because stating the obvious and rewording the error in laymans terms doesn't really answer the question. I'm presuming the point of the question is more understanding why Magentos' Core is fragmented.

    – ash
    May 28 '14 at 13:33











  • Upvote, I don't see why this answer couldn't be valid

    – Raul Sanchez
    Jan 21 at 17:44
















0














strlen() is a function which gives the length of the string you passed as a parameter.



The error is that you must be passing an array in the strlen(). Please check the value you are passing.
It should be string.



Check your file "Attribute.php" at line no. 93.






share|improve this answer



















  • 2





    downvoted - because stating the obvious and rewording the error in laymans terms doesn't really answer the question. I'm presuming the point of the question is more understanding why Magentos' Core is fragmented.

    – ash
    May 28 '14 at 13:33











  • Upvote, I don't see why this answer couldn't be valid

    – Raul Sanchez
    Jan 21 at 17:44














0












0








0







strlen() is a function which gives the length of the string you passed as a parameter.



The error is that you must be passing an array in the strlen(). Please check the value you are passing.
It should be string.



Check your file "Attribute.php" at line no. 93.






share|improve this answer













strlen() is a function which gives the length of the string you passed as a parameter.



The error is that you must be passing an array in the strlen(). Please check the value you are passing.
It should be string.



Check your file "Attribute.php" at line no. 93.







share|improve this answer












share|improve this answer



share|improve this answer










answered May 28 '14 at 10:15









WaseemWaseem

56211336




56211336








  • 2





    downvoted - because stating the obvious and rewording the error in laymans terms doesn't really answer the question. I'm presuming the point of the question is more understanding why Magentos' Core is fragmented.

    – ash
    May 28 '14 at 13:33











  • Upvote, I don't see why this answer couldn't be valid

    – Raul Sanchez
    Jan 21 at 17:44














  • 2





    downvoted - because stating the obvious and rewording the error in laymans terms doesn't really answer the question. I'm presuming the point of the question is more understanding why Magentos' Core is fragmented.

    – ash
    May 28 '14 at 13:33











  • Upvote, I don't see why this answer couldn't be valid

    – Raul Sanchez
    Jan 21 at 17:44








2




2





downvoted - because stating the obvious and rewording the error in laymans terms doesn't really answer the question. I'm presuming the point of the question is more understanding why Magentos' Core is fragmented.

– ash
May 28 '14 at 13:33





downvoted - because stating the obvious and rewording the error in laymans terms doesn't really answer the question. I'm presuming the point of the question is more understanding why Magentos' Core is fragmented.

– ash
May 28 '14 at 13:33













Upvote, I don't see why this answer couldn't be valid

– Raul Sanchez
Jan 21 at 17:44





Upvote, I don't see why this answer couldn't be valid

– Raul Sanchez
Jan 21 at 17:44


















draft saved

draft discarded




















































Thanks for contributing an answer to Magento Stack Exchange!


  • Please be sure to answer the question. Provide details and share your research!

But avoid



  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.


To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fmagento.stackexchange.com%2fquestions%2f21651%2fwarning-strlen-expects-parameter-1%23new-answer', 'question_page');
}
);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

1300-talet

1300-talet

Display a custom attribute below product name in the front-end Magento 1.9.3.8