消息:implode():传递的参数无效

时间:2013-09-06 23:59:30

标签: php javascript jquery ajax

我有一个表单,通过jquery将数据从表单发送到另一个页面: -

   <?
    $counter=0;
    $sqlmasmohType = mysql_query("select * from masmoh");
    while ($rowmasmohType = mysql_fetch_array($sqlmasmohType))
    {
        $counter++;

                        if($counter % 4 == 0){

                            $class= "no-margin-left";

                        }else $class="";
    ?>


    <div class="news-element <?= $class ?>"><input type="checkbox" id="masmoh" name="masmoh[]" value="<?=$rowmasmohType['id'] ?>"  />&nbsp;&nbsp;<?=$rowmasmohType['name'] ?></div>

    <? } ?>  

<div class="clear"></div>
     <input type="hidden" name="ft_user_id" id="ft_user_id" value="<?=$iduser?>" class="input-text">
    <input type="button" id="save_masmoh_user" name="save_masmoh_user" value="Save" class="custom-btn-train-parentt">

这个表单发送到saveMasmohToUser页面的2个参数,其中一个参数是Array,我需要将这个数组保存到数据库中,如(1,5,p,55)

我会试试这个: -

public function saveMasmohToUser(){

    $ft_user_id = $_POST['ft_user_id'];
    $save_masmoh = $_POST['save_masmoh'];
    $unserializedData = array();
    parse_str($save_masmoh,$unserializedData);
    if($save_masmoh != ''){
        foreach($unserializedData as $unserializedData){
        if ($unserializedData != ""){
        $check = mysql_query("select count(*) as rowuser from masmoh_for_user where m_user_id = '".$ft_user_id."'");
        $rowUser = mysql_fetch_array($check);
        if ($rowUser['rowuser'] == 0)   
        {   
    $query = mysql_query("insert into masmoh_for_user (m_user_id,m_masmoh) values ('$ft_user_id','".implode($unserializedData, ',')."')");
        }
        else
        {
        $query = mysql_query("update masmoh_for_user set  m_masmoh = '".implode($unserializedData, ',')."' where m_user_id = '".$ft_user_id."'");
        }
    $newData = array();
    $newData['msg'] = "save";
    $data = json_encode($newData);
    echo $data ;
    }
    }
    }  


    }

但我会看到这个错误: -

  

消息:implode()[function.implode]:传递的参数无效

但是当打印数组$unserializedData时: -

Array 
(
    [0] => 1
    [1] => 2
    [2] => 3
    [3] => 4
)

我该如何解决这个错误。

3 个答案:

答案 0 :(得分:0)

问题在于:

foreach($unserializedData as $unserializedData){

您不能使用与foreach'相同的变量名称。更改它以使名称不同,例如:

foreach($unserializedData as $simpleData){

请注意,执行此操作时,还应对代码进行适当的更改。在这种情况下,只更改此行应该可以解决问题:

if ($unserializedData != ""){

假设您按原样使用了我的示例,只需将上面一行的变量名称更改为$simpleData即可。那个foreach故障也导致了内爆错误。

注意:根据PHP的文档,implode以任一顺序接受其参数。虽然有些用户报告您使用了错误的订单,但这是无关紧要的,您的代码应该适用于您想要的任何订单。

答案 1 :(得分:-1)

你对内爆的呼吁是倒退的。

implode(seperator, array);

所以你会像这样使用它:

implode(',', $unserializedData)

答案 2 :(得分:-1)

您应该使用<?php代替<?。我相信<?已被弃用。 (如果是的话,我会回来编辑这篇文章。)其次,它不应该是错误的(如果你是将一个数组作为第二个参数传递给implode)。

修改

<?未被弃用,但您仍应使用<?php

编辑2

你的内爆是错误的。它的语法是这样的。
    implode(seperator, array_to_be_seperated);