0

phpを使用して、jsonを使用してiOSアプリにデータを提供しています。しかし、ブラウザでコードを実行すると、サーバーエラーが表示されます。データベースに値がない場合は{"posts":null} 、コードで提供されているとおりに表示されます。しかし、データベースに値がある場合に問題が発生します。エラーが表示されます

Server error The website encountered an error while retrieving http://path to the server file/php/categoryitemlisting.php?category=11. It may be down for maintenance or configured incorrectly. Here are some suggestions: Reload this webpage later. HTTP Error 500 (Internal Server Error): An unexpected condition was encountered while the server was attempting to fulfill the request. このエラーは、このphpファイルに対してのみ発生しています。他のファイルを使用して、データを転送できます。

私のconnection.phpファイル:

<?php
$link = mysql_connect("127.0.0.1","root","") or die('Cannot connect to the DB');
mysql_set_charset("utf8");
mysql_select_db('cotton',$link) or die('Cannot select the DB');
?>

カテゴリitemlisting.php

 <?php

   require('connection.php');
   $item = array()       ;

   /* connect to the db */
      if(isset($_REQUEST['category']))
      {
            $k=$_REQUEST['category'];
        /* grab the posts from the db */
             // $k=11;
            $catid = mysql_query("SELECT entity_id FROM  field_data_field_cat WHERE field_cat_tid= $k");
            while($r = mysql_fetch_assoc($catid))
           {

               $category[] = $r['entity_id'];   
               foreach ( $category as $cat );
              {

                 $data= mysql_query("SELECT field_data_field_name.entity_id, field_data_field_name.field_name_value, file_managed.uri, field_data_field_sec.field_sec_tid FROM file_managed INNER JOIN ( field_data_field_thumb, field_data_field_name, field_data_field_sec ) ON ( file_managed.fid = field_data_field_thumb.field_thumb_fid AND field_data_field_name.entity_id = field_data_field_thumb.entity_id AND field_data_field_thumb.entity_id = field_data_field_sec.entity_id ) WHERE field_data_field_name.entity_id = $cat");  

               $items = mysql_fetch_assoc($data);
               $item[]= $items;
              }
            }
                $re="public:\/\/";
                $list = json_encode(array('posts'=>$item));
            $list = str_replace( $re, "http://localhost/sites/default/files/" ,$list);
                echo $list;

             @mysql_close($link);

      }

      else
      {
      echo "connection failed";
      }
?>

このエラーを修正して値を取得するにはどうすればよいですか? 私はそれがサーバーの問題だとは思わない。コードに他の間違いがある場合は?

4

2 に答える 2

0

yout php.ini を調べて、次のように設定します。

display_errors = on
error_reporting = E_ALL

display_error がオフで、コードになんらかの問題 (解析エラーなど) がある場合、応答は 500 ステータス ページになります。

于 2013-05-14T12:38:19.963 に答える