Как обнаружить внутреннюю ошибку сервера (500) в laravel - PullRequest
0 голосов
/ 30 апреля 2018

Я поделюсь только самым важным фрагментом кода

$product = DB::table('products')->where('id','=',$pid)->get();
//the above code makes no errors
if ($product[0]::sale == '1') // this line of code makes error
        {
            //$cost+=($product[0]->price - ($product[0]->discount*$product[0]->price/100));
        }
        else
        {
            //$cost+=$product[0]->price;
        }

ясно, что эта строка if ($product[0]::sale == '1') делает ошибку

однако я не смог поймать его - когда я отправляю запрос - я получаю только 500 (Внутренняя ошибка сервера) - событие не может поймать ошибку

- обновления

return $ product // делает ошибку

return var_dump ($ product);

возвращая это

object(stdClass)#234 (23) {
  ["title"]=>
  string(16) "oihoh jewioh 234"
  ["id"]=>
  string(9) "hew7h23iu"
  ["desciption"]=>
  string(162) "ewhniuhewch2398h9h32
32dh2398dh23dh3
d2h3d8h238dh2389hd98
3d2hd8932hd8h23329dj892
j9hd2dh8723gd7g32d
23dh9832hd8h2389dh9h239dh239
23d8h3289dh3298d9h32dh329h"
  ["sizes"]=>
  string(4) "M,XL"
  ["colors"]=>
  string(14) "#12f,#caf,#afa"
  ["amount"]=>
  int(12)
  ["category"]=>
  string(5) "Women"
  ["scategory"]=>
  string(5) "Lambs"
  ["featured"]=>
  int(1)
  ["minfo"]=>
  string(23) "sia:deuw,on:iej,od:jdiw"
  ["images"]=>
  string(288) "snoicds,nconew,ncoiwenioew,http://www.ridgetopvirtualsolutions.com/wp-content/uploads/2014/03/product-that-sells-4-ridgetopvirtualsolutions.jpg*snoicdse,nconew,ncoiwenioew,http://www.ridgetopvirtualsolutions.com/wp-content/uploads/2014/03/product-that-sells-4-ridgetopvirtualsolutions.jpg"
  ["video"]=>
  NULL
  ["fimage"]=>
  string(143) "snoicds,nconew,ncoiwenioew,http://www.ridgetopvirtualsolutions.com/wp-content/uploads/2014/03/product-that-sells-4-ridgetopvirtualsolutions.jpg"
  ["sale"]=>
  int(0)
  ["price"]=>
  float(26.5)
  ["sold"]=>
  int(32)
  ["views"]=>
  int(14)
  ["likes"]=>
  int(24)
  ["discount"]=>
  NULL
  ["dexpire"]=>
  NULL
  ["created_at"]=>
  NULL
  ["updated_at"]=>
  NULL
  ["avgreview"]=>
  float(3.4)
}

1 Ответ

0 голосов
/ 30 апреля 2018

Работая со строителем запросов, вы не должны получать этот тип ошибки. Это потому, что вы рассматриваете это как массив. Мы все это сделали.

Хорошая новость в том, что она намного лучше! Использование:

$product = DB::table('products')->find($pid);

Затем используйте код ниже, чтобы проверить, существует ли продукт.

if ( $product ) { ... }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...