pg解析json

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了pg解析json相关的知识,希望对你有一定的参考价值。

参考技术A json文本:

postgresql 解析json

未找到模块:无法解析 pg/lib 中的“dns”

【中文标题】未找到模块:无法解析 pg/lib 中的“dns”【英文标题】:Module not found: Can't resolve 'dns' in pg/lib 【发布时间】:2019-01-03 14:39:29 【问题描述】:

我做了 create-react-app 并且还安装了 sequelize 和 pg。但是当我执行 npm start 时,出现以下错误 -


./node_modules/pg/lib/connection-parameters.js

找不到模块:无法解析“/Users/vedant/Web Dev/device_psql/node_modules/pg/lib”中的“dns”

这里是 App.js 文件 -


import React,  Component  from 'react';
const Sequelize = require('sequelize');
const sequelize = new Sequelize('postgres', 'postgres', 'password', 
host: 'localhost',
dialect: 'postgres',

pool: 
  max: 5,
  min: 0,
  acquire: 30000,
  idle: 10000
,

// http://docs.sequelizejs.com/manual/tutorial/querying.html#operators
operatorsAliases: false
);

class App extends Component 
render() 
  return (
    <div >
      <p>Test</p>
    </div>
  );



export default App;

另外,在 package.json 文件中,我有 sequelize 和 pg。可能是什么问题呢?我试图删除 node_modules 文件夹并进行 npm 安装,但没有成功。

提前致谢。

【问题讨论】:

您应该检查您的 Sequelize 和 pg 版本,我记得 pg@7 与以前版本的 sequelize 不兼容时遇到了一些问题 【参考方案1】:

发生这种情况是因为您的某个包使用了 JavaScript 承诺,该承诺依赖于 dns 模块,该模块仅在 Node.js(服务器端)中可用,而不是在您的代码在浏览器中运行时可用。虽然实现依赖于它,但它并不要求它工作,因此您可以通过伪造dns 模块的存在来解决问题。

为此,请按以下步骤操作:

创建一个文件夹/src/mock/dns。在此文件夹中,创建一个文件 index.js,其中包含:

module.exports = ; 
module.exports.default = ;

也在这个文件夹中,创建一个文件package.json,其中包含:

 
  "name": "dns", 
  "version": "3.1.0", 
  "private": true 

在您的根package.json 中,将以下行添加到dependencies

"dns": "file:./src/mock/dns"

运行npm install 安装虚假依赖项,然后使用npm start 重新启动您的React 项目。

【讨论】:

非常感谢亚历山大提供的信息。我能够解决这个问题。我正在使用 React 中的 Sequelize 访问 Postgres,尽管它只能通过后端(在本例中为 Node)访问。【参考方案2】:

我在 Cloudflare Workers 中尝试使用 Nodemailer 时遇到了类似的问题。

Nodemailer 包出现以下错误:

Module not found: Error: Can't resolve 'child_process' in '~/node_modules/nodemailer/lib/sendmail-transport'

当我研究错误时,我发现 Webpack 正在尝试为客户端捆绑只能在服务器中使用的东西。见https://github.com/webpack/webpack/issues/744。

解决方案是将externals 属性添加到我的webpack.config.js 文件中,并包含Webpack 无法解析的所有模块。见https://github.com/webpack/webpack/issues/744#issuecomment-320437402。

我的webpack.config.js 文件现在看起来像这样:

module.exports = 
  target: "webworker",
  entry: "./index.js",
  externals: [
    "child_process",
    "dns",
    "fs",
    "net",
    "tls",
  ]

更新: 我发现了一些专门与 Cloudflare Workers 相关的新信息,但这偏离了最初的主题。所以我创建了一个新帖子:Cloudflare Workers: Module not found: Error: Can't resolve 'child_process' in '~/node_modules/nodemailer/lib/sendmail-transport' 。

【讨论】:

【参考方案3】:

在文件顶部导入 fetch 解决了我的问题。

import fetch from 'node-fetch';

之前别忘了安装:Install node-fetch

【讨论】:

以上是关于pg解析json的主要内容,如果未能解决你的问题,请参考以下文章

Flutter -- JSON解析

JSON在线解析,新版本JSON在线解析

Scala解析JSON

如何将这个json进行解析?

PHP解析JSON

json数据解析出错应该怎么办?