JsonParser.php 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. <?php
  2. /**
  3. * @link https://www.yiiframework.com/
  4. * @copyright Copyright (c) 2008 Yii Software LLC
  5. * @license https://www.yiiframework.com/license/
  6. */
  7. namespace yii\web;
  8. use yii\base\InvalidArgumentException;
  9. use yii\helpers\Json;
  10. /**
  11. * Parses a raw HTTP request using [[\yii\helpers\Json::decode()]].
  12. *
  13. * To enable parsing for JSON requests you can configure [[Request::parsers]] using this class:
  14. *
  15. * ```php
  16. * 'request' => [
  17. * 'parsers' => [
  18. * 'application/json' => 'yii\web\JsonParser',
  19. * ]
  20. * ]
  21. * ```
  22. *
  23. * @author Dan Schmidt <danschmidt5189@gmail.com>
  24. * @since 2.0
  25. */
  26. class JsonParser implements RequestParserInterface
  27. {
  28. /**
  29. * @var bool whether to return objects in terms of associative arrays.
  30. */
  31. public $asArray = true;
  32. /**
  33. * @var bool whether to throw a [[BadRequestHttpException]] if the body is invalid JSON
  34. */
  35. public $throwException = true;
  36. /**
  37. * Parses a HTTP request body.
  38. * @param string $rawBody the raw HTTP request body.
  39. * @param string $contentType the content type specified for the request body.
  40. * @return array|\stdClass parameters parsed from the request body
  41. * @throws BadRequestHttpException if the body contains invalid json and [[throwException]] is `true`.
  42. */
  43. public function parse($rawBody, $contentType)
  44. {
  45. // converts JSONP to JSON
  46. if (strpos($contentType, 'application/javascript') !== false) {
  47. $rawBody = preg_filter('/(^[^{]+|[^}]+$)/', '', $rawBody);
  48. }
  49. try {
  50. $parameters = Json::decode($rawBody, $this->asArray);
  51. return $parameters === null ? [] : $parameters;
  52. } catch (InvalidArgumentException $e) {
  53. if ($this->throwException) {
  54. throw new BadRequestHttpException('Invalid JSON data in request body: ' . $e->getMessage());
  55. }
  56. return [];
  57. }
  58. }
  59. }