搜索

首页  >  问答  >  正文

使用PHP将Shopware 6.5中的JSON键内容替换并保存的方法

我正在处理一个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粉306523969P粉306523969447 天前700

全部回复(2)我来回复

  • P粉762730205

    P粉7627302052023-09-10 15:55:36

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

    $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);

    回复
    0
  • P粉438918323

    P粉4389183232023-09-10 11:11:10

    在使用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"

    回复
    0
  • 取消回复