好吧,我已经尝试了不同的方式来上传一个 200k 的文件,增加了限制,改变了参数,做了我改变 multer 的一切。 Fucei 我知道我在堆栈中阅读的所有内容,这是我在谷歌上发现的,基本的谷歌搜索已经完成了我的问题,而不是向上但向下图片就像一个魅力。服务器支持上传图像 我 atualemente 用 php 做这个任务,但如果不在 nodejs 中滚动,我会在 php 中做同样的文件。感谢收听。
我的代码
var express = require('express');
var app = express();
var http = require('http').Server(app);
var bodyParser = require("body-parser");
var fs = require('fs');
var multer = require('multer');
var destino = '/var/www/upload/';
var upload = multer({dest: 'uploads/',
rename: function (fieldname, filename) {
return filename + Date.now();
},
limits: {
fieldNameSize: 200,
files: 5,
fields: 5
}
});
app.use(bodyParser.urlencoded({extended: true}));
app.use(bodyParser.json());
app.post('/image', upload.single('message'), function (req, res) {
var file = req.file;
fs = require('fs')
fs.readFile(file.path, 'base64', function (err, data) {
if (err) {
return console.log(err);
}
/* do something if data*/
fs.unlinkSync(file.path);
});
});
http.listen(8080, function () {
console.log("Conectado e escutando na porta: 8080");
});
错误告诉我是这样的:错误:请求实体太大
at readStream (/var/www/likeyounode/node_modules/body-parser/node_modules/raw-body/index.js:196:17)
at getRawBody (/var/www/likeyounode/node_modules/body-parser/node_modules/raw-body/index.js:106:12)
at read (/var/www/likeyounode/node_modules/body-parser/lib/read.js:76:3)
at urlencodedParser (/var/www/likeyounode/node_modules/body-parser/lib/types/urlencoded.js:109:5)
at Layer.handle [as handle_request] (/var/www/likeyounode/node_modules/express/lib/router/layer.js:95:5)
at trim_prefix (/var/www/likeyounode/node_modules/express/lib/router/index.js:312:13)
at /var/www/likeyounode/node_modules/express/lib/router/index.js:280:7
at Function.process_params (/var/www/likeyounode/node_modules/express/lib/router/index.js:330:12)
at next (/var/www/likeyounode/node_modules/express/lib/router/index.js:271:10)
at expressInit (/var/www/likeyounode/node_modules/express/lib/middleware/init.js:33:5)
我检查了我所有的代码,只需要足够多的证据来展示我想要的东西,而不是揭示我的项目的大部分内容。
正文中有一些配置是我做的,如果您注意到它们在内容中有说明,那么怀疑您运行自己的应用程序时不会拥有所有功能。
最佳答案
在我的例子中,设置限制后@node.js (webapp)
var express = require('express'); var app = express();
var bodyParser = require('body-parser');
app.use(bodyParser.json({limit:'50mb'}));
app.use(bodyParser.urlencoded({extended:true, limit:'50mb'}));
我还(最重要的)必须设置限制@nginx(webapp反向代理)
# Max upload size.
client_max_body_size 50M;
关于javascript - Node js 请求实体太大且有多个上传,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36485333/
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
我有一个具有一些属性的模型:attr1、attr2和attr3。我需要在不执行回调和验证的情况下更新此属性。我找到了update_column方法,但我想同时更新三个属性。我需要这样的东西:update_columns({attr1:val1,attr2:val2,attr3:val3})代替update_column(attr1,val1)update_column(attr2,val2)update_column(attr3,val3) 最佳答案 您可以使用update_columns(attr1:val1,attr2:val2
我发现ActiveRecord::Base.transaction在复杂方法中非常有效。我想知道是否可以在如下事务中从AWSS3上传/删除文件:S3Object.transactiondo#writeintofiles#raiseanexceptionend引发异常后,每个操作都应在S3上回滚。S3Object这可能吗?? 最佳答案 虽然S3API具有批量删除功能,但它不支持事务,因为每个删除操作都可以独立于其他操作成功/失败。该API不提供任何批量上传功能(通过PUT或POST),因此每个上传操作都是通过一个独立的API调用完成的
我正在尝试修改当前依赖于定义为activeresource的gem:s.add_dependency"activeresource","~>3.0"为了让gem与Rails4一起工作,我需要扩展依赖关系以与activeresource的版本3或4一起工作。我不想简单地添加以下内容,因为它可能会在以后引起问题:s.add_dependency"activeresource",">=3.0"有没有办法指定可接受版本的列表?~>3.0还是~>4.0? 最佳答案 根据thedocumentation,如果你想要3到4之间的所有版本,你可以这
rails中是否有任何规定允许站点的所有AJAXPOST请求在没有authenticity_token的情况下通过?我有一个调用Controller方法的JqueryPOSTajax调用,但我没有在其中放置任何真实性代码,但调用成功。我的ApplicationController确实有'request_forgery_protection'并且我已经改变了config.action_controller.consider_all_requests_local在我的environments/development.rb中为false我还搜索了我的代码以确保我没有重载ajaxSend来发送
我正在尝试按0-9和a-z的顺序创建数字和字母列表。我有一组值value_array=['0','1','2','3','4','5','6','7','8','9','a','b','光盘','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','','u','v','w','x','y','z']和一个组合列表的数组,按顺序,这些数字可以产生x个字符,比方说三个list_array=[]和一个当前字母和数字组合的数组(在将它插入列表数组之前我会把它变成一个字符串,]current_combo['0','0','0']
是否有可能:before_filter:authenticate_user!||:authenticate_admin! 最佳答案 before_filter:do_authenticationdefdo_authenticationauthenticate_user!||authenticate_admin!end 关于ruby-on-rails-before_filter运行多个方法,我们在StackOverflow上找到一个类似的问题: https://