A while back (yesterday), I penned a blog post highlighting the ORDS REST-Enabled SQL Service. And in that blog, I displayed the output of a cURL command. A cURL command I issued to an ORDS REST-Enabled SQL Service endpoint. Unfortunately, it was very messy and very unreadable. I mentioned that I would fix it later. Well…it’s now…later (temporal paradox, anybody 🤨?).
Recap
If you recall, the output of my POST request looked like this:
data:image/s3,"s3://crabby-images/61383/61383d11ef64a6ea3cb6a5e4deb14e7f4914e420" alt="crap-response-from-curl-command-post-request-to-rest-enabled-sql-endpoint-chris-hoina-senior-product-manager-database-actions-oracle"
JSON is not displaying correctly
Well, the reason why I didn’t originally pipe in the json_pp
command is because this is what happened when I attempted it:
data:image/s3,"s3://crabby-images/4bb4b/4bb4bcc27ed2429f8cd469878dd35e657e3624da" alt="attempting-to-use-the-json-pp-command-for-post-request-curl-chris-hoina-senior-product-manager-database-actions-oracle"
Jefe to the rescue
After reading my newly published article, Jefe suggested I try the jq
command.
data:image/s3,"s3://crabby-images/9014b/9014bc8dd293d75edd0459dc3c6f065cc586abea" alt="jeff-sage-advice-on-slack-ords-post-chris-hoina-senior-product-manager-database-actions-oracle"
Which, of course, I did. Still no luck:
data:image/s3,"s3://crabby-images/7e6ab/7e6abf8c39b48b8bb299eb58ff9e6178de083a78" alt="jeffs-suggestion-for-jq-command-for-post-request-curl-chris-hoina-senior-product-manager-database-actions-oracle"
Andiamo a googliare!
Online search to the rescue
Search online using the keywords “parse error: Invalid numeric literal at,” and you’ll quickly discover that you’re not the only one with this problem.
Five minutes of research revealed a potential culprit. What I was experiencing seemed to be a known issue. For example, a long-standing jq
bug on GitHub details this exact scenario. This doesn’t seem to be a jq or json_pp issue. Instead, the problem is somehow related to the -i cUR
L command option and JSON
parsing.
After another few minutes, as luck would have it, I found a Stack Overflow thread discussing the same issue I encountered! After scrolling to the bottom of the thread, I found this golden nugget:
data:image/s3,"s3://crabby-images/5e6c4/5e6c4e019704598ba85b23ef5f6464249b6c3af0" alt="removing-header-information-from-curl-request-for-ords-post-chris-hoina-senior-product-manager-database-actions-oracle"
Testing without -i
So, I did just what Mattias and nhs503 suggested. I removed the -i
option (-i, or –include) from my cURL command, and wouldn’t you know? The damn thing works as expected! I tested while piping jq and json_pp. I also concede that jq
is the prettier of the two; I appreciate the colors (although, admittedly, this would NOT pass any accessibility testing).
The modified commands used:
curl -X POST --user ORDSTEST:password1234 --data-binary "@sportCountryMatrix.sql" -H "Content-Type: application/sql" -k http://localhost:8080/ords/ordstest/_/sql | jq
curl -X POST --user ORDSTEST:password1234 --data-binary "@sportCountryMatrix.sql" -H "Content-Type: application/sql" -k http://localhost:8080/ords/ordstest/_/sql | json_pp
And the results:
data:image/s3,"s3://crabby-images/a3aad/a3aadf4e3560429d3ef85b14e06873db365791ee" alt="jq-part-one-response-ords-post-chris-hoina-senior-product-manager-database-actions-oracle"
jq
part one of the responsedata:image/s3,"s3://crabby-images/2d39d/2d39d8df5ff2d2da077a0c2d7b70bba674a6540b" alt="jq-part-two-response-ords-post-chris-hoina-senior-product-manager-database-actions-oracle"
jq
part two of the responsedata:image/s3,"s3://crabby-images/0b0ea/0b0ea9769959f419c779dceb16d3a3e8932d60cd" alt="json_pp-part-one-response-ords-post-chris-hoina-senior-product-manager-database-actions-oracle"
json_pp
part one of the responsedata:image/s3,"s3://crabby-images/2ea72/2ea72e0e1507bb36ef9857c1a042611bc5b1b06b" alt="json_pp-part-two-response-ords-post-chris-hoina-senior-product-manager-database-actions-oracle"
json_pp
part two of the responseFinal thoughts
And for some final thoughts…
- It turns out it’s NOT ORDS – it’s something to do with an underlying JSON parser not liking the header info that is coming through
json_pp
andjq
both work; they output the information in different order- The ORDS REST-Enabled SQL Service returns to you not only your results, but the SQL statement initially used (that is cool and I didn’t originally realize or mention this)
And that’s it for this one! I really hope you find this useful. I hope this saves you some time from having to troubleshoot and/or hunt for a fix for this tricky problem. That’s all for now!
Follow
And don’t forget to follow, like, subscribe, share, taunt, troll, or stalk me!