2016-01-12 88 views
1

我有兩個文件。一個是index.php,另一個是display.php。 Index.php包含一個表單,在提交之後,它會生成一個json值並將其顯示在textarea中,所以我可能會在我按下「生成」按鈕之前進行編輯,並將其重定向到display.php,其中for循環會生成一個根據發佈的兒子數據的html模板。它最多可以和3個項目一起工作,但如果我使用4個或更多,它會給我帶來一個內存限制的致命錯誤。當我還是得到了提高限價後的錯誤,我想就在Display.php的如下:JSON導致內存錯誤

ini_set('memory_limit', '-1'); 
set_time_limit(0); 

在此之後,它丟棄了我一個錯誤503 - 服務不可用。 我不知道該怎麼做,我要求你的幫助。

的index.php:

<meta charset="utf-8"> 
<style> 
    pre, textarea { background-color:#31495D;min-height:300px;color:white;margin-bottom:50px;padding:25px;width:100%;display:block;border-bottom:5px solid #A058B3; } 
    .submit { padding:15px;background-color:green;color:white;border:none;font-size:12px;width:150px;margin:0 auto;margin-top:15px;margin-bottom:15px } 
</style> 
<?php 

$json   = json_encode($_POST, JSON_PRETTY_PRINT, JSON_UNESCAPED_UNICODE); 
echo " 
<h2>JSON for template</h2> 
<form action='display.php' method='post'> 
    <textarea name='json'>$json</textarea> 
    <input class='submit' type='submit' value='Generate Template'> 
</form> 
"; 

$json   = json_decode($json, true); 


?> 

<script src="https://code.jquery.com/jquery-1.10.2.js"></script> 
<script> 
$(document).ready(function() { 
    var max_fields  = 10; //maximum input boxes allowed 
    var wrapper   = $(".input_fields_wrap"); //Fields wrapper 
    var add_button  = $(".add_field_button"); //Add button ID 

    var x = 1; //initlal text box count 
    $(add_button).click(function(e){ //on add input button click 
     e.preventDefault(); 
     if(x < max_fields){ //max input box allowed 
      x++; //text box increment 
      $(wrapper).append('<div><input type="text" name="url[]" placeholder="http://www.example.com/"/><input type="text" name="name[]" placeholder="Name"/><input type="text" name="subtext[]" placeholder="Subtext"/><input type="text" name="image[]" placeholder="Image URL"/><a href="#" class="remove_field">Remove</a></div>'); //add input box 
     } 
    }); 

    $(wrapper).on("click",".remove_field", function(e){ //user click on remove text 
     e.preventDefault(); $(this).parent('div').remove(); x--; 
    }) 
}); 
</script> 

<form action="<?php echo $_SERVER['PHP_SELF'];?>" method="post"> 
<label>Title of Block <input type="text" name="title"></label><br> 
<label>Heading of Block <input type="text" name="heading"></label><br><br> 

<div class="input_fields_wrap"> 
    <button class="add_field_button">Add More Fields</button> 
    <div><input type="text" name="url[]" placeholder="http://www.example.com/"/><input type="text" name="name[]" placeholder="Name"/><input type="text" name="subtext[]" placeholder="Subtext"/><input type="text" name="image[]" placeholder="Image URL"/></div> 
</div> 
<br><br> 

    <input type="submit" value="Generate Code"> 
</form> 

而且Display.php的

<?php 

$json = json_decode($_POST['json'], true);     
$c = count($json); 
$i = 0; 
$rows = 3; 


$content = "<table>"; 

for($i=0; $i < count($json["name"]); $i++) { 


    $content .= 

    '<td width="226" valign="top" style="padding:5px;padding-bottom:20px;" class="m-stack m-pad-b"> 
     <table width="100%" cellpadding="0" cellspacing="0" border="0"> 
      <tr> 
       <td style="font-family:Helvetica Neue,Helvetica,Arial,sans-serif;font-size:22px;padding-bottom:5px; mso-line-height-rule:exactly; line-height: 18px; padding-top: 8px;"> 
       <a href="'.$json['url'][$i].'" target="_blank" style="text-decoration:none;color:#0896ff; display:block;"> 
       '.$json['name'][$i].'<br><span style="color: #7d90a6; font-size: 14px;">'.$json['subtext'][$i].'</span> 
       </a> 
       </td> 
      </tr> 
      <tr> 
       <td background="'.$json['image'][$i].'" width="226" height="226" valign="top" style="background-size:cover; background-position:center center; border-radius:6px 6px 0 0;" class="m-ufi-bg"> 
       <!--[if gte mso 9]> 
       <v:rect xmlns:v="urn:schemas-microsoft-com:vml" fill="true" stroke="false" style="width:226px;height:226px;"> 
        <v:fill type="frame" src="'.$json['image'][$i].'" color="#7bceeb" /> 

       </v:rect> 
       <![endif]--> 
       </td> 
      </tr> 


     </table> 
    </td> 
    '; 
    if($i == 3) { $content .= '</tr><tr>'; unset($i); $i == 0; } 

    } 
    echo "</table>"; 

echo $content; 

這僅僅是我的一個實驗,任何建議/批評表示讚賞。提前致謝。

+0

你好,謝謝你的來訪。不,在這種情況下兩者是相同的。我只是檢查$ i是否等於3,也可以除以3。 – Ignity

+0

多數民衆贊成在罰款,沒有問題:) – Ignity

+0

你正在重置'$ i'到'0',所以它永遠不會比'count($ json)'更大,所以你的'for'循環變得無限。 – RoToRa

回答

0

您正在重置$i0所以它不會比count($json),且您的for循環將成爲無限

+0

謝謝你,@RoToRa。 – Ignity