pgcrypto:无法正常使用



我需要在postgresql12实例上启用pgcrypto

我启用了扩展并检查它是否正常:

postgres=# CREATE EXTENSION pgcrypto;
CREATE EXTENSION
postgres=# SELECT digest('blah', 'sha256');
digest
--------------------------------------------------------------------
x8b7df143d91c716ecfa5fc1730022f6b421b05cedee8fd52b1fc65a96030ad52
(1 row)

我遵循了我在SO:上阅读的建议

postgres=# GRANT EXECUTE ON FUNCTION digest(bytea,text) TO normaluser;
GRANT
postgres=# GRANT EXECUTE ON FUNCTION digest(text,text) TO normaluser;
GRANT

遗憾的是,仍然没有办法将该函数与";正常用户";。

normaluser@planck:5432/cryptodb> SELECT digest('blah', 'sha256');
ERROR:  42883: function digest(unknown, unknown) does not exist
LINE 1: SELECT digest('blah', 'sha256');
^
HINT:  No function matches the given name and argument types. You might need to add explicit type casts.
LOCATION:  ParseFuncOrColumn, parse_func.c:631
Time: 52,065 ms

欢迎任何提示,谢谢:(

在问题中,当我创建扩展时,您可以看到我作为超级用户postgres连接,并且不是连接到用作用户normaluser的数据库cryptodb中。所以我用postgres连接到数据库cryptodb,现在normaluser可以在cryptodb上下文中使用pgcrypto函数digest

TL;DR;:CREATE EXTENSION pgcrypto;之前连接到正确的数据库

相关内容

  • 没有找到相关文章

最新更新