I've got a log file, where each line is a JSON. Due to some Nginx security reasons, the logs are being saved in a hexadecimal format (e.g. the char " will be converted to \x22). Here is an example of a JSON line:
 { "body_bytes_sent": "474", "params": {\x22device_id\x22: \x221234567890\x22} }
My goal:
Convert each line to a readable format
{ "body_bytes_sent": "474", "params" : {"device_id": "1234567890"} }
Convert this string into a JSON object so I could manipulate it.
Any help will be appreciated.
You can use strconv.Unquote to convert the string to a normal one:
package main
import (
    "encoding/json"
    "fmt"
    "strconv"
)
func main() {
    // this is what your input string looks like...
    qs := "{\\x22device_id\\x22: \\x221234567890\\x22}"
    // now let's convert it to a normal string
    // note that it has to look like a Go string literal so we're
    // using Sprintf
    s, err := strconv.Unquote(fmt.Sprintf(`"%s"`, qs))
    if err != nil {
        panic(err)
    }
    fmt.Println(s)
    // just for good measure, let's see if it can actually be decoded.
    // SPOILER ALERT: It decodes just fine!
    var v map[string]interface{}
    if err := json.Unmarshal([]byte(s), &v); err != nil {
        panic(err)
    }
    fmt.Println(v)
}
Playground
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With