使用PHP将Shopware 6.5中的JSON键内容替换并保存的方法
P粉306523969
P粉306523969 2023-09-09 23:36:03
0
2
722

我正在处理一个Shopware项目,需要设置一个包含所有已处理订单的JSON。

这个JSON被存储在一个目录中,我已经找到并将其传递给一个变量$fil

$filer =  $order1->getOrderNumber() . '_' . $country2->getIso() . '.json';
$fil = __DIR__ . '/' . $filer;

$file_contents = file_get_contents($fil);

获取到的JSON存储在变量$fil中,然后传递给变量$jsonData

$jsonData = $fil;

我试图通过将JSON解码为关联数组来替换下面的键的值。

$data = json_decode($jsonData, true);

要替换的键如下(尝试替换ID)

$data['entity']['payments'][0]['state']['id'] = $logMessageId;

然后,我尝试将其保存回变量modifiedJsonData并替换回目录。

$modifiedJsonData = json_encode($data, JSON_PRETTY_PRINT);

file_put_contents($fil, $modifiedJsonData);

它似乎部分工作,但不完全,而不仅仅是替换(ID)。

如下所示:$data['entity']['payments'][0]['state']['id']

它替换了整个JSON的内容,而不仅仅是上述内容,JSON内容应该比下面的内容更多:

{
    "entity": {
        "payments": [
            {
                "state": {
                    "id": #####
                }
            }
        ]
    }
}

请帮忙,我可能做错了什么

P粉306523969
P粉306523969

全部回复(2)
P粉762730205

我还能通过以下方式绕过它:

$data = json_decode($jsonData, true, 512, JSON_BIGINT_AS_STRING);



    $data['entity']['payments'][0]['state']['id'] = $logMessageId;

        
        



$modifiedJsonData = json_encode($data, JSON_PRETTY_PRINT);
        
  
  

  $existingData = json_decode(file_get_contents($fil), true);
        
     
  

  $existingData['entity']['payments'][0]['state']['id'] = $data['entity']['payments'][0]['state']['id'];


 $updatedJsonData = json_encode($existingData, JSON_PRETTY_PRINT);
        
   
  

  file_put_contents($fil, $updatedJsonData);
P粉438918323

在使用json_decode()解码JSON时,确保$jsonData中有正确的JSON文本,并且在当前场景下使用两个标志,第一个标志始终使用,第二个标志更具体:

  1. JSON_THROW_ON_ERROR
  2. JSON_BIGINT_AS_STRING

示例:

$data = json_decode($jsonData, true, flags: JSON_THROW_ON_ERROR | JSON_BIGINT_AS_STRING);

(自PHP 8.0起)

$data = json_decode($jsonData, true, 512, JSON_THROW_ON_ERROR | JSON_BIGINT_AS_STRING);

(自PHP 7.3起)

JSON_THROW_ON_ERROR

之所以只看到$data['entity']['payments'][0]['state']['id']的JSON,是因为$data = json_decode(...)操作返回了null,因为解析失败。使用JSON_THROW_ON_ERROR会将任何错误转换为异常,这样更容易发现,因为它会在错误时停止脚本的执行。

这样可以避免在后续输出中查找错误。

JSON_BIGINT_AS_STRING

BIGINT是指BigInt(ECMA 262),它是JavaScript中用于非常大的(负数和正数)整数的数字值类型,json_decode()在处理时可能会丢失精度(3v4l.org演示):

var_dump(json_decode('4599999999999999999999999999999999'));
var_dump(json_decode('4599999999999999999999999999999999', true, 512, JSON_BIGINT_AS_STRING));
float(4.6E+33)
string(34) "4599999999999999999999999999999999"

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板