2016-06-01 2 views
1

PHP에서 JSON 문자열 배열이 있습니다. 원본 JSON을 이중 인코딩하지 않고이 배열의 JSON 문자열을 만드는 방법이 있는지 알고 싶습니다.이중 인코딩없이 json 문자열 배열에서 json 문자열을 만들려면 어떻게해야합니까?

배열은 다음과 같습니다
enter image description here

json_encode($myArray, JSON_UNESCAPED_SLASHES)에 결과 호출은 다음과 같습니다 : 자사가 이런 식으로 일을 왜

{ 
    "invoice": "{\"order_id\":\"1\",\"store_id\":\"1\",\"customer_id\":\"2\",\"billing_address_id\":\"2\",\"shipping_address_id\":\"1\",\"global_currency_code\":\"USD\",\"base_currency_code\":\"USD\",\"store_currency_code\":\"USD\",\"order_currency_code\":\"USD\",\"store_to_base_rate\":\"0.0000\",\"store_to_order_rate\":\"0.0000\",\"base_to_global_rate\":\"1.0000\",\"base_to_order_rate\":\"1.0000\",\"items\":{},\"total_qty\":1,\"subtotal\":59.95,\"base_subtotal\":59.95,\"subtotal_incl_tax\":59.95,\"base_subtotal_incl_tax\":59.95,\"grand_total\":64.95,\"base_grand_total\":64.95,\"discount_amount\":0,\"base_discount_amount\":0,\"shipping_amount\":\"5.0000\",\"base_shipping_amount\":\"5.0000\",\"shipping_incl_tax\":\"5.0000\",\"base_shipping_incl_tax\":\"5.0000\",\"shipping_tax_amount\":\"0.0000\",\"base_shipping_tax_amount\":\"0.0000\",\"shipping_discount_tax_compensation_amount\":\"0.0000\",\"base_shipping_discount_tax_compensation_amnt\":null,\"tax_amount\":0,\"base_tax_amount\":0,\"discount_tax_compensation_amount\":0,\"base_discount_tax_compensation_amount\":0,\"base_cost\":0,\"can_void_flag\":false,\"state\":2}", 
    "items": "{\"totalRecords\":0,\"items\":[{\"order_item_id\":\"1\",\"product_id\":\"1\",\"sku\":\"TP1\",\"name\":\"Test Product ONE\",\"description\":null,\"price\":\"59.9500\",\"base_price\":\"59.9500\",\"base_cost\":null,\"price_incl_tax\":\"59.9500\",\"base_price_incl_tax\":\"59.9500\",\"weee_tax_applied\":\"[]\",\"weee_tax_applied_amount\":null,\"weee_tax_applied_row_amount\":0,\"base_weee_tax_applied_amount\":null,\"base_weee_tax_applied_row_amnt\":null,\"weee_tax_disposition\":null,\"base_weee_tax_disposition\":null,\"weee_tax_row_disposition\":0,\"base_weee_tax_row_disposition\":0,\"qty\":\"1.000000\",\"invoice\":{},\"parent_id\":null,\"store_id\":\"1\",\"row_total\":59.95,\"base_row_total\":59.95,\"row_total_incl_tax\":59.95,\"base_row_total_incl_tax\":59.95,\"tax_amount\":0,\"base_tax_amount\":0,\"discount_tax_compensation_amount\":0,\"base_discount_tax_compensation_amount\":0,\"base_weee_tax_applied_row_amount\":0}]}", 
    "billing-address": "{\"entity_id\":\"2\",\"parent_id\":\"1\",\"customer_address_id\":\"3\",\"quote_address_id\":null,\"region_id\":\"24\",\"customer_id\":null,\"fax\":null,\"region\":\"Indiana\",\"postcode\":\"47933\",\"lastname\":\"Thompson\",\"street\":\"204 N Grace Avenue\",\"city\":\"Crawfordsville\",\"email\":\"[email protected]\",\"telephone\":\"(987)987-9877\",\"country_id\":\"US\",\"firstname\":\"Mitchell\",\"address_type\":\"billing\",\"prefix\":null,\"middlename\":null,\"suffix\":null,\"company\":null,\"vat_id\":null,\"vat_is_valid\":null,\"vat_request_id\":null,\"vat_request_date\":null,\"vat_request_success\":null}", 
    "shipping-address": "{\"entity_id\":\"1\",\"parent_id\":\"1\",\"customer_address_id\":\"3\",\"quote_address_id\":null,\"region_id\":\"24\",\"customer_id\":null,\"fax\":null,\"region\":\"Indiana\",\"postcode\":\"47933\",\"lastname\":\"Thompson\",\"street\":\"204 N Grace Avenue\",\"city\":\"Crawfordsville\",\"email\":\"[email protected]\",\"telephone\":\"(987)987-9877\",\"country_id\":\"US\",\"firstname\":\"Mitchell\",\"address_type\":\"shipping\",\"prefix\":null,\"middlename\":null,\"suffix\":null,\"company\":null,\"vat_id\":null,\"vat_is_valid\":null,\"vat_request_id\":null,\"vat_request_date\":null,\"vat_request_success\":null}" 
} 

내가 이해, 난 그냥 차라리하지 않는 게 좋을. 또한, 이상적으로 str_replace 사용을 피하고 싶습니다. 아이디어?

답변

2

먼저 모든

$subitem = array_map('json_decode', $subitem); 
echo json_encode($subitem); 
를 인코딩, 데이터를 디코딩
관련 문제