Javascript 网页包和AWS Lambda问题-模块上缺少处理程序
我正在使用ES6、babel和Webpack2捆绑AWS Lambda。然后,我使用AWS SAM local运行/测试它。当我点击api时,出现以下错误-Javascript 网页包和AWS Lambda问题-模块上缺少处理程序,javascript,amazon-web-services,lambda,webpack,webpack-2,Javascript,Amazon Web Services,Lambda,Webpack,Webpack 2,我正在使用ES6、babel和Webpack2捆绑AWS Lambda。然后,我使用AWS SAM local运行/测试它。当我点击api时,出现以下错误- Handler 'handler' missing on module 'dist/main' 这是我的webpack.config.js- const path = require('path'); module.exports = { entry: './index.js', output: { path: path
Handler 'handler' missing on module 'dist/main'
这是我的webpack.config.js-
const path = require('path');
module.exports = {
entry: './index.js',
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'main.js',
libraryTarget: 'commonjs'
},
module: {
rules: [
{
test: /\.js$/,
exclude: /node_modules/,
loader: 'babel-loader',
options: {
plugins: [require('babel-plugin-transform-flow-strip-types')],
presets: [
[
'env',
{
target: { node: 6.10 }, // Node version on AWS Lambda
useBuiltIns: false,
loose: false,
exclude: [],
debug: false
},
],
],
},
}
],
}
};
下面是编译的main.js的一个片段-
/***/ (function(module, exports, __webpack_require__) {
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.handler = handler;
var _amazonCognitoIdentityJs = __webpack_require__(60);
var _aws_profile = __webpack_require__(290);
// A signin Lambda function
function handler(event, context, callback) {
switch (event.httpMethod) {
case "GET":
一点背景。。。。这是一个Lambda,我最初不是在ES6中编写的,也不是使用Webpack绑定的,它是有效的。我现在需要它在ES6和工作的网页。注意,这是第2页
非常感谢…要解决此问题,我必须指定一个库属性并将libraryTarget更改为commonjs2。webpack.config.js文件输出现在如下所示-
output: {
path: path.resolve(__dirname, 'dist'),
filename: 'main.js',
library: 'main',
libraryTarget: 'commonjs2'
},
我也遇到了这个问题。然而,我相信我的情况与桑布里克的情况相反。我从使用babel传输ES6到在lambda/node 6.10上运行,再到不传输并以lambda/node 8.10为目标。删除
library
字段并更改libraryTarget:“commonjs”
为我解决了这个问题
这家伙的道具:你能试试目标中的一个吗:[{name:“node”,version:6}]Ortanks Pandelis。我尝试将目标更改为[{name:“node”,version:6}],但得到了相同的处理程序丢失错误。。。。你写了“或者”你有没有从你的评论中删掉的另一个建议?哦,是的,对不起,我想说我通常会将我的babel配置为只针对ES2015,比如:loader:“babel loader”,选项:{预设:['ES2015',{modules:false}],但您似乎遇到了另一个问题抱歉。谢谢,修复了我遇到的同一个问题:)