Webpack-您如何需要捆绑包(saslprep)中的可选依赖项

问题描述 投票:0回答:1

我在部署过程中使用webpack将许多后端脚本捆绑到一个文件中。

连接到MongoDB数据库时,存在一个可选的依赖项,如果不包含该依赖项,则会引发警告。

Warning: no saslprep library specified. Passwords will not be sanitized

在我的开发环境中,通过安装可选依赖项可以轻松解决此错误。

npm install saslprep --save

但是与webpack捆绑在一起时,不包括可选的依赖项,并且警告在生产部署中仍然存在。我可以很容易地找到造成这种情况的原因,mongodb库要求将此作为可选的依赖项:

let saslprep;
try {
  saslprep = require('saslprep');
} catch (e) {
  // don't do anything;
}

我已经尝试过使用垫片,外部组件,插件来遵循webpack文档,坦率地说,对于解决此问题的正确方法,它已经完全迷失了。这是我当前的webpack.config文件(试图将此作为插件)。

const path = require('path');
const webpack = require('webpack');

module.exports = {
    entry: './src/api/index.ts',
    target: 'node',
    mode: 'production',
    module: {
        rules: [
            {
                test: /\.tsx?$/,
                loader: 'ts-loader',
                exclude: /node_modules/
            }
        ]
    },
    resolve: {
        extensions: ['.js', '.tsx', '.ts', '.json']
    },
    output: {
    filename: 'api.js',
        path: path.resolve(__dirname, 'dist'),
    },
    plugins: [
        new webpack.IgnorePlugin(/fsevents/),
        new webpack.IgnorePlugin(/blessed/),
        new webpack.ProvidePlugin({
            saslprep: path.resolve(__dirname, "node_modules/saslprep/index.js")
        })
    ],
};

提前感谢。

node.js mongodb webpack
1个回答
0
投票

webpack应该是seeing表示require('saslprep')代码并捆绑saslprep。您可以通过查看由webpack创建的文件并搜索与库源代码不同的内容来确认这一点。我看一下正在检查该依赖关系的MongoDB代码-可能是他们检查它是否存在的方式与webpack捆绑和定义依赖关系的方式不兼容。 (大多数节点库的作者可能没有考虑捆绑时的代码运行方式-webpack可以用于Node,但很少使用。)如果是这种情况,则您可以对代码进行反向工程检查并通过别名等将其放置到位。

© www.soinside.com 2019 - 2024. All rights reserved.