Ⅰ node 服务怎么接收表单数据
例如:A表格的A1要与B表格A1相同,那就是把两个表格都打开,在B表格的A1内输入:=,再点击A表格的A1再回车确认就OK啦. 这样A表格的A1发生变化,在打开B表格时会提示更新,点"更新"就会同步变化了.
Ⅱ 如何使用 NodeJS 将文件或图像上传到服务器
下面先介绍上传文件到服务器(多文件上传):
import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
import java.util.*;
import java.util.regex.*;
import org.apache.commons.fileupload.*;
public class upload extends HttpServlet {
private static final String CONTENT_TYPE = "text/html; charset=GB2312";
//Process the HTTP Post request
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
response.setContentType(CONTENT_TYPE);
PrintWriter out=response.getWriter();
try {
DiskFileUpload fu = new DiskFileUpload();
// 设置允许用户上传文件大小,单位:字节,这里设为2m
fu.setSizeMax(2*1024*1024);
// 设置最多只允许在内存中存储的数据,单位:字节
fu.setSizeThreshold(4096);
// 设置一旦文件大小超过getSizeThreshold()的值时数据存放在硬盘的目录
fu.setRepositoryPath("c://windows//temp");
//开始读取上传信息
List fileItems = fu.parseRequest(request);
// 依次处理每个上传的文件
Iterator iter = fileItems.iterator();
//正则匹配,过滤路径取文件名
String regExp=".+////(.+)$";
//过滤掉的文件类型
String[] errorType={".exe",".com",".cgi",".asp"};
Pattern p = Pattern.compile(regExp);
while (iter.hasNext()) {
FileItem item = (FileItem)iter.next();
//忽略其他不是文件域的所有表单信息
if (!item.isFormField()) {
String name = item.getName();
long size = item.getSize();
if((name==null||name.equals("")) && size==0)
continue;
Matcher m = p.matcher(name);
boolean result = m.find();
if (result){
for (int temp=0;temp<ERRORTYPE.LENGTH;TEMP++){
if (m.group(1).endsWith(errorType[temp])){
throw new IOException(name+": wrong type");
}
}
try{
//保存上传的文件到指定的目录
//在下文中上传文件至数据库时,将对这里改写
item.write(new File("d://" + m.group(1)));
out.print(name+" "+size+"");
}
catch(Exception e){
out.println(e);
}
}
else
{
throw new IOException("fail to upload");
}
}
}
}
catch (IOException e){
out.println(e);
}
catch (FileUploadException e){
out.println(e);
}
}
}
现在介绍上传文件到服务器,下面只写出相关代码:
以sql2000为例,表结构如下:
字段名:name filecode
类型: varchar image
数据库插入代码为:PreparedStatement pstmt=conn.prepareStatement("insert into test values(?,?)");
代码如下:
。。。。。。
try{
这段代码如果不去掉,将一同写入到服务器中
//item.write(new File("d://" + m.group(1)));
int byteread=0;
//读取输入流,也就是上传的文件内容
InputStream inStream=item.getInputStream();
pstmt.setString(1,m.group(1));
pstmt.setBinaryStream(2,inStream,(int)size);
pstmt.executeUpdate();
inStream.close();
out.println(name+" "+size+" ");
}
。。。。。。
这样就实现了上传文件至数据库
Ⅲ nodejs 怎么从request获取上传文件
可以使用第三方的js库,比如spark-md5.js。上传文件后,调用对应的api即可以获取到上传文件的md5。
Ⅳ 最近在研究nodejs如何实现文件上传功能
前端formdata或者Ajax上传文件
Node端:用multiparty接收文件,再用fs.rename将文件存储到你需要的位置。
var MULTIPARTY = require('multiparty');
var FS = require('fs');
var saveTowerFile = function (req, res, next) {
var form = new MULTIPARTY.Form({uploadDir: "../appData/excel/"});
form.parse(req, function (err, fields, files) {
if (err) {
console.log("上传失败!" + err);
var errcode = {result: "失败"};
res.send(errcode);
return;
} else {
var inputFile = files.file[0];
var uploadedPath = inputFile.path;
var dstPath = '../appData/excel/' + UUID.v1();
FS.rename(uploadedPath, dstPath, function(err) {
if (err) {
var errcode = {result: "失败"};
res.send(errcode);
return;
} else {
debug('rename ok');
res.send(“OK”);
}
})
}
});
};
Ⅳ Node.js 怎么处理批量表单数组的提交
处理的方法有两种,他们是:表单数据一种是get方式, 另一种是post 方式
方法如下:
1.get方式
对于get方式,node处理起来非常简单
如以下代码:
var urlParsed = url.parse(request.url);
var getData = querystring.parse(urlParsed.query);
//getData 为object类型 同名表单为array
get返回结果:
{
name: "blue5tar",
hobby:["read", "surfing"]
}
2. post方式
post方式处理起来比较麻烦,但是有了node-formidable 这个mole 我们就省事多了
使用npm安装 node-formidable
npm install formidable
formidable 使用方法
formidable = require("formidable"); //载入 formidable
var form = new formidable.IncomingForm();
var post = {},
file = {};
form.uploadDir = '/tmp'; //文件上传 临时文件存放路径
form
.on('error', function(err) {
console.log(err); //各种错误
})
//POST 普通数据 不包含文件 field 表单name value 表单value
.on('field', function(field, value) {
if (form.type == 'multipart') { //有文件上传时 enctype="multipart/form-data"
if (field in post) { //同名表单 checkbox 返回array 同get处理
if (util.isArray(post[field]) === false) {
post[field] = [post[field]];
}
post[field].push(value);
return;
}
}
post[field] = value;
})
.on('file', function(field, file) { //上传文件
file[field] = file;
})
.on('end', function() {
fn(); //解析完毕 做其他work
});
form.parse(request); //解析request对象
post方式有个bug
当form 有enctype=“multipart/form-data” 和没有 enctype=“multipart/form-data” 时 同名表单处理的方式不一样。
有 enctype=“multipart/form-data” 时 同名表单会被最后一个value覆盖,
没有 enctype="multipart/form-data"时,同get一样 会返回一个array
所以, 在 'field’事件时,对form.type进行不同处理 , 同名表单都返回array
还有一个问题,上传文件时 如果不选择文件 也会在临时目录生成空的临时文件, 解决办法:
修改 formidable 模块 lib/incoming_form.js handlePart方法 在183行处添加:
if (part.filename == "") {
return;
}
上传文件返回的结构如下:
{
size: 40635, //文件大小
path: '/tmp/', //临时文件路径
name: 'arrow.png', //文件名称
type: 'image/png', //文件 mime
lastModifiedDate: Sun, 11 Mar 2012 07:19:44 GMT,
_writeStream:
{ path: '/tmp/',
fd: 7,
writable: false,
flags: 'w',
encoding: 'binary',
mode: 438,
bytesWritten: 40635,
busy: false,
_queue: [],
drainable: true },
length: [Getter], //同size
filename: [Getter], //同name
mime: [Getter] //同type
}
文件上传到临时文件目录下,我们还要将临时文件, 移到我们的上传目录中
fs.rename(file.path, global.appConfig.uploadDir + '/' + file.filename);
Ⅵ nodejs解析FormData发送过来的表单数据,下图是nodejs后台打印输出的req.body
Node接收表单数据,用multiparty模块
var saveTowerFile = function (req, res, next) {
var form = new MULTIPARTY.Form({uploadDir: "../appData/excel/"});
form.parse(req, function (err, fields, files) {
if (err) {
console.log("失败!" + err);
var errcode = {result: 'INVALID_PARAM'};
res.send(errcode);
return;
} else {
var inputFile = files.file[0];
var uploadedPath = inputFile.path;
console.log(uploadedPath);
var dstPath = '../appData/excel/' + UUID.v1() + '.xls';
FS.rename(uploadedPath, dstPath, function(err) {
if (err) {
var errcode = {result: 'INVALID_PARAM'};
res.send(errcode);
console.log('rename error: ' + err);
return;
} else {
console.log('rename ok');
}
})
}
});
};
Ⅶ Nodejs中怎么获取HTML中一个form下的所有POST数据
首先获取http,并创建一个web服务,监听本地端口1337,这个可以修改,任何未被占用的端口都可以用,并坚挺data事件和end事件,整个文件保存为app.js
下面这里贴上测试代码
////////////////app.js///////
var http = require('http');
var server = http.createServer(function(req,res){
if(req.url!=="/favicon.ico"){
req.on('data',function(data){
console.log("服务器接收到的数据:"+decodeURIComponent(data));
});
req.on("end",function(){
console.log('客户端请求数据全部接收完毕');
});
}
res.end();
}).listen(1337,"localhost",function(){
console.log("listened");
});
////////////////index.html///////
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Nodejs的data事件与end事件的回调函数测试用页面</title>
</head>
<body>
<form id= "form1" action = "http://localhost:1337/" method = "post">
姓名:<input type = 'text' name = "name" value ="dragon"><br/>
年龄:<input type = "number" name = "age" value ="25">
<input type = "submit" value =" 提交"/>
</form>
</body>
</html>
Ⅷ nodejs后台,用formidable处理上传文件时,前台需要传什么参数给后端
用一个表单<form method="post" enctype="multipart/form-data" action="/file-upload"> <input type="file" name="thumbnail"> <input type="submit"></form>这样就可以了
Ⅸ node js 怎么获取request payload
你这form表单是上传附件了吗?在form表单中加上 enctype="multipart/form-data" 这个属性是就会出去你那种情况,如果你表单不需要上传附件,就把这个属性去掉应该就可以了。
Ⅹ 在Node.js中如何获取文件上传进度
前端html5支持获取上传的字节数,同时也能获取总字节大小。这样可以算出进度。
node.js的后端request一般支持流模式,于是就可以用request.on('data', () => {})获取到已上传的字节大小,前端获取总字节大小之后可以将信息放进request header里。这样也可以算出进度