尝试修改变量的JSON时出现“无效的数字文字”错误

时间:2018-09-28 21:04:19

标签: json bash jq

我想将值传递到bash脚本中,该脚本将使用jq更改json文件中的值。我已经为此工作了一段时间,无法克服第一组错误。

这是我简单的json文件:

{
    "0000000": {
        "pogo": "AJHVUYKJBOIHKNNLNM"
    },
    "7000000": {
        "pogo": "PPPVUYKJBOIHKNNLNM"
    }
}

这是我的脚本

#!/bin/bash

#-- pass into script
pgid="${1}"
tpogo="${2}"
file="file.json"

#-- tmp files
tmp_dir="$(mktemp -d -t 'text.XXXXX' || mktemp -d 2>/dev/null)"
tmp_input1="${tmp_dir}/temp_input1.txt"

if [ ! -n "$2" ]; then
   { echo "Check your command as you are missing a variable ..."; echo "Example: script.sh "00000001" "jvkkjbkjbd" ..."; }
   exit 1;
fi

jq -r ".${pgid}.pogo = \"${tpogo}\"" "$file" > "$tmp_input1"
cat "$tmp_input1"
rm -rf "$tmp_dir"

以下是错误:

jq: error: Invalid numeric literal at EOF at line 1, column 9 (while parsing '.0000000.') at <top-level>, line 1:
.0000000.pogo = "XXXXXXX"
jq: error: syntax error, unexpected IDENT, expecting $end (Unix shell quoting issues?) at <top-level>, line 1:
.0000000.pogo = "XXXXXXX"
jq: 2 compile errors

我从堆栈中尝试了很多变体,其中大多数看起来与我现在正在做的事情相似。

1 个答案:

答案 0 :(得分:3)

对于当前问题:.key{ "foo": "value" }一起使用,但是.100{ "100": "value" }不一起使用;您所依赖的语法是糖,仅适用于键的有限子集。 .["100"]可以工作,但是通过将shell变量扩展为解析为代码的字符串来生成该代码是脆弱的(jq在当前版本中不是副作用,但是在 do < / em>支持I / O操作,这样的替代可以用于注入攻击。要以正确的方式进行操作,请将代码中的变量带外传递,并以不依赖于变量内容的方式将其用于查找。


与awk的jq等效的-v var="$value"--arg var "$value",因此可以这样使用:

jq --arg pgid "$pgid" \
   --arg tpogo "$tpogo" \
   '.[$pgid].pogo = $tpogo'

使用您的数据进行测试:

json='{"0000000":{"pogo":"AJHVUYKJBOIHKNNLNM"},"7000000":{"pogo":"PPPVUYKJBOIHKNNLNM"}}'
pgid="0000000"
tpogo="XXXXXXX"

jq --arg pgid "$pgid" --arg tpogo "$tpogo" \
   '.[$pgid].pogo = $tpogo' <<<"$json"

...作为输出发出:

{
  "0000000": {
    "pogo": "XXXXXXX"
  },
  "7000000": {
    "pogo": "PPPVUYKJBOIHKNNLNM"
  }
}