- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我正在尝试使用 NodeJs 脚本将文件上传到服务器。我正在尝试以下操作。
HTML
<md-tab label="Upload log">
<md-content class="md-padding" id="popupContainer" ng-cloak>
<h4>Upload a zip file</h4>
<form ng-submit="$event.preventDefault()">
<md-input-container class="md-block" flex>
<label>Source</label>
<md-select name="source" ng-model="log.source" ng-click="getSources()">
<md-option ng-repeat="source in sourceInfo" value="{{source.sourceCode}}">{{source.sourceName}}</md-option>
</md-select>
</md-input-container>
<br>
<md-input-container class="md-block">
<label>Select Batch</label>
<input required type="number" step="any" name="rate" ng-model="log.batch" min="1" max="100"/>
</md-input-container>
<md-input-container class="md-block">
<label>Enter your comments about the log files</label>
<textarea ng-readonly="false" ng-model="log.comment" md-maxlength="100" rows="3" md-select-on-focus></textarea>
</md-input-container>
<div ng-if="status" id="status">
<b layout="row" layout-align="center center" class="md-padding">{{status}}</b>
</div>
<input type="file" file-model="log.file" name="inputFile"/>
<button ng-click="uploadFiles()">Upload</button>
{{log}}
<p> </p>
</form>
</md-content>
</md-tab>
指令
var logApp = angular.module('logAnalysisApp', ['ngMaterial', 'lfNgMdFileInput', 'ngRoute', 'ngMessages']);
logApp.config(['$routeProvider', '$compileProvider', '$mdThemingProvider', function ($routeProvider, $compileProvider, $mdThemingProvider) {
$compileProvider.debugInfoEnabled(false);
$routeProvider
.when('/login', {
templateUrl: 'views/login.html',
controller: 'loginControl'
})
.when('/register', {
templateUrl: 'views/register.html',
controller: 'registerControl'
})
.when('/home', {
templateUrl: 'views/filemenu.html',
controller: 'fileUploadCtrl'
})
.when('/admin', {
templateUrl: 'views/adminpanel.html',
controller: 'adminCtrl'
})
.when('/totalreport', {
templateUrl: 'views/total.html',
controller: 'totalCtrl'
})
.otherwise({
redirectTo: '/login'
});
}
])
logApp.constant('config', {
apiUrl: 'http://localhost:8080',
serverUrl: 'http://localhost:3000'
})
logApp.directive('fileModel', ['$parse', function ($parse) {
return {
restrict: 'A',
link: function (scope, element, attrs) {
var model = $parse(attrs.fileModel);
var modelSetter = model.assign;
element.bind('change', function () {
scope.$apply(function () {
modelSetter(scope, element[0].files[0]);
});
});
}
};
}
]);
Controller
logApp.controller('fileUploadCtrl', function ($rootScope, $scope, $timeout, $location, $http, config) {
$scope.log = {};
$scope.uploadFiles = function () {
console.log($scope.log);
var uploadUrl = "http://localhost:3000/testRef";
var fd = new FormData();
for (var key in $scope.log)
fd.append(key, $scope.log[key]);
for (var pair of fd.entries()) {
console.log(pair[0] + ', ' + pair[1]);
}
$http.post(uploadUrl, fd, {
transformRequest: angular.indentity,
headers: {
'Content-Type': undefined
}
})
.success(function () {
console.log("success!!");
})
.error(function () {
console.log("error!!");
});
};
});
服务器端编码
var express = require('express')
var app = express()
var multer = require('multer');
var upload = multer({ dest: './uploads' });
app.post('/testRef', upload.any("inputFile"), function(request, response) {
console.log(request.files)
console.log(request.body)
response.send("Done")
});
当我尝试在控制台中查看 request.files
时,它显示空白数组,并且 request.body
显示为空白对象。但是在客户端日志中,当我打印 $scope.log
时,它显示了适当的内容,并且在遍历 FormData 变量时,我看到了我正在发送的所需数据.此外,在我打印 {{log}}
时,在 html 中,文件数据未被填充。
欢迎任何类型的帮助。
谢谢。
最佳答案
为表单命名并访问 req.file("filename")
关于angularjs - 无法使用 multer 从 req 对象访问 req.files,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45410565/
我正在开发一个 nodejs 项目快速应用程序。我的路线看起来像这样: router.get('/observe/:fileName', function(res, req){ var req
从 Facebook 初始成功登录并使用 passport-facebook 1.0.3 和 express 4.6.1 登录重定向回调后,req.session.passport 和 req.use
req.body有什么区别和 req.params.all()何时用于风帆 Controller ? 最佳答案 req.body是从请求正文中解析出来的任何内容,例如 POST 中的有效负载要求。 r
我想知道 req.query 和 req.body 有什么区别? 下面是一段代码,其中req.query用来。如果我使用 req.body 会发生什么而不是 req.query . 以下函数被调用作为
我以前问过类似的问题,但我注意到它在 Javascript 部分。对于现在可能出现的问题,我也有更具体的想法。 基本上,req.session.passport 在我的日志中是空的。每当我开始浏览我的
我不久前从某处盗取了这段代码,并想回来进一步了解它。 iv 在 pi 上运行它已经有一段时间了,没有任何问题,但是当我运行网络服务器时,我需要恢复操作系统的备份,自从这样做以来,我一直无法让它运行,如
Req.isAuthenticated()在登录后以及注册新用户后返回false。我需要做什么来修复它? 我有一个具有两个不同登录名的应用程序。一个用于“用户”,另一个用于“雇员”。 “用户”用户是我
我一直在拼凑来自几个不同教程的代码,以使用 MEAN 堆栈构建一个基本的待办事项应用程序,使用 node、express、angular 和 mongodb。一个教程介绍了为 GET、POST 和 D
我使用以下路由接收 url 中的参数: app.get('/:lang', function(req, res) { }); 我将推送 lang 的值并将其发送到一个函数,但我希望只能在用户不输入任何
根据条件,我需要销毁用户的当前 session ,并将他重定向到带有消息的登录页面。我使用 flash 来获得只显示一次的消息。除了这里,这在我的应用程序上无处不在,因为这里我在 req.sessio
Sample 'Advanced REST Client' Request 我正在使用 Postman 和高级 REST 客户端为以下代码创建基本 POST 请求 - 'use strict'; va
if (!req.session.cart) { req.session.cart = { styles: styles,
我正在尝试使用 NodeJs 脚本将文件上传到服务器。我正在尝试以下操作。 HTML Upload a zip file
通过 req.query[myParam] 和 req.params.myParam 获取 QUERY_STRING 参数有区别吗?如果是这样,我应该什么时候使用哪个? 最佳答案 鉴于这条路线 app
在 Shiny 的应用程序中,我使用 req 检查输入的有效性如果输入的要求为 TRUE(即不为空、不为 FALSE 等),则更新输出。 如果 req 我想运行一些代码是 FALSE,即使用 req(
我正在使用 Express 和 Body Parser。给定以下标题键: X-Master-Key 当我使用下面的代码片段时,它无法输出值 req.headers['X-Master-Key'] //
要么使用正文解析器 application/x-www-form-urlencoded body parser 或 json body parser 产生相同的结果。 这就是我调用 API 的方式 $
在nodejs中我们通常会做这样的事情: req.checkBody('name', 'Group name is required.').notEmpty(); 同样,我也做了这样的事情: req.
我正在使用 Multer 在 keystone 环境中解析多部分表单,并且无法访问路由 Controller 内的 req.body 和 req.file 数据 路线/index.js var key
我想了解这是为什么: req.session._id = doc._id; req.session.id = doc._id; console.log(typeof req.session._id);
我是一名优秀的程序员,十分优秀!