1

假设您有一个函数返回在您的 postgreSQL 数据库中定义的 json。

CREATE OR REPLACE FUNCTION test() RETURNS JSON AS $$
  SELECT
  '[
    {"fName":"John","lName":"Doe"},
    {"fName":"Jane","lName":"Doe"}
  ]'::JSON;
$$ 
LANGUAGE SQL STRICT IMMUTABLE;


SELECT test();
-------------------------------------
 [                                  
     {"fName":"John","lName":"Doe"},
     {"fName":"Jane","lName":"Doe"} 
 ]

此外,您有一个 Nginx,包括带有以下配置文件的 Postgres Nginx 模块(openresty):

worker_processes  1;
error_log logs/error.log;
events {
    worker_connections 1024;
}
http {

    upstream database {
        postgres_server localhost dbname=example user=postgres;
        postgres_keepalive max=200 overflow=reject;
    }

    server {
        listen 8080;
        location /test/ {
                postgres_pass database;
                rds_json  on;
                postgres_query    HEAD GET  "SELECT test()";
                postgres_rewrite  HEAD GET  no_rows 410;
        }
    }
}

打开rds_json 所有引号都在输出中转义,如下所示:

curl http://localhost:8080/test/
[{"test":"[\n    {\"fName\":\"John\",\"lName\":\"Doe\"},\n    {\"fName\":\"Jane\",\"lName\":\"Doe\"}\n  ]"}]

如果我将rds_json 设置为关闭;我收到了格式正确的 json,但返回字符串以一些尴尬的符号开始和结束:

@^C^@^@^@^@^@^@^B^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^@^A^@^@<80>r^@^D^@test^AL^@^@^@[
    {"fName":"John","lName":"Doe"},
    {"fName":"Jane","lName":"Doe"}
  ]^@

有没有办法摆脱结果对象中的附加符号或在第一种情况下不转义所有双引号?

谢谢

4

1 回答 1

0

我找到了一个原因。其实这很微不足道。而不是将 openresty 格式输出为 json。很抱歉用我的问题打扰了社区。我必须正确设置标题:

worker_processes  1;
error_log logs/error.log;
events {
    worker_connections 1024;
}
http {

    upstream database {
        postgres_server localhost dbname=example user=postgres;
        postgres_keepalive max=200 overflow=reject;
    }

    server {
        listen 8080;
        location /test/ {
                postgres_pass database;
                postgres_query    HEAD GET  "SELECT test()";
                more_set_headers  'Content-Type: application/json';
                postgres_rewrite  HEAD GET  no_rows 410;
        }
    }
}
于 2016-12-06T11:43:59.720 回答