mysql - AES_DECRYPT 从 typescript 中的 blob 获取值

标签 mysql typescript blob aes angular5

编写一个 Angular 5/typescript 客户端,调用与 MySQL 数据库通信的 Node.js Web 服务器。已成功进行姓名征集:

SELECT *
FROM stories JOIN users
ON stories.author_id=users.id
WHERE stories.story_id = 1;

如果我需要在数据库中的字段级别加密作者的姓氏,我可以使用 AES_ENCRYPT 和 AES_DECRYPT。这会将调用更改为此。我在这里使用 dlname 来区分解密后的值和 lname 字段。

SELECT *, AES_DECRYPT(lname, UNHEX(SHA2('some phrase',512))) AS dlname
FROM stories JOIN users
ON stories.author_id=users.id
WHERE stories.story_id = 1;

这在使用 phpMyAdmin 的开发环境中工作,dlname 在返回时很好并显示为文本。但是,当使用 MySQL 推送到产品环境并调用它时, typescript (Angular 5 客户端)将 dlname 显示为 blob [object Object]。我用 MySQL Workbench 检查了它,它也将其显示为一个 blob,我可以右键单击它,然后“在查看器中打开值”,然后我就可以看到姓氏了。

我的问题是,如何编写 typescript 代码以从 blob 中获取实际的 lname 值?相关代码行是...

this.http.get<StoryRes>(sRootURI + '/getStory/' + sDocID)
    .subscribe(data => {
      this.sAuthor = data[0].fname + ' ' + data[0].dlname;

在本例中,dlname 在控制台中显示为 [object Object]。

最佳答案

我从 BLOB data returned in MySQL using AES_DECRYPT with ORDER clause 中找到的一些帮助中弄清楚了这一点。在 AES_DECRYPT 函数周围添加 CAST(... AS CHAR)...

SELECT *, CAST(AES_DECRYPT(lname, UNHEX(SHA2('some phrase',512))) AS CHAR) as dlname...

在客户端,只需确保调用新字段名称 dlname 而不是实际名称 lname。客户端不需要任何其他操作,将按预期以文本形式显示。

关于mysql - AES_DECRYPT 从 typescript 中的 blob 获取值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50685971/

相关文章:

angular - ActivatedRoute 订阅第一个子参数观察者

使用PreparedStatement 语句进行 Java Oracle Blob 与 Blob 比较失败

entity-framework - MVC 使用 EF 存储 SQL Server 中的任何文件 [BLOB]

php - 奇怪的preg_replace行为将字符变成数字

MySQL - 如果 x 不为空,则连接表

python - 使用 GetIndex() 函数

typescript - TypeScript 中的私有(private)静态属性

angular - 将 bool 值从 observable 传递到 observable

php - 当我添加一列时,它说 "Column count doesn' t 匹配第 1 行的值计数”

php - 使用存储过程、php和mysqli将图像/longblob上传到mysql数据库