我有一个文本区域,用户在其中键入文本。一旦他们点击保存,文本区域中的内容就会发送到服务器端。在服务器端,我想使用内容来创建文件。我有一个名为" usercode"的变量。其中包含文本区域的内容。我创建了一个文件,
fs.wirteFile(name + "java", usercode, function(){})
命名文件名,由用户指定。这确实创建了一个文件,但文件中唯一的东西是" [object Object]"。
这是我的客户端我正在使用玉:
extends layout
block content
div(id="ineditortxt")
h1(name="headings") #{title}
a(href='/signout', class='text-center new-account') Sign Out
div(id="editor")
|public class #{title}{
| public static void main(String[] args) {
|
| }
|}
script(src="src/ace.js", type="text/javascript")
script(type="text/javascript").
//var myRequest = new XMLHttpRequest();
var editor=ace.edit("editor");
editor.setTheme("ace/theme/monokai");
editor.getSession().setMode("ace/mode/java");
$(document).ready(function(){
$("#save").click(function(event){
var content = editor.getValue();
$.ajax({
url:'/getcode',
type:'POST',
data: content,
jsonpCallback: 'callback'
});
event.preventDefault();
return false;
});
});
form(name="Save", id = "save")
input(type="submit", value="Save")
div(id="result")
|
这是服务器端,我没有包含所有代码,只是与此问题相关的代码:
var express = require('express');
var router = express();
var passport = require('passport');
var LocalStrategy = require('passport-local').Strategy;
var param = require('express-params');
var Parse = require('parse').Parse;
var http = require('http');
var fs = require('fs');
router.post('/editor', function(req, res){
name = req.body.newname;
res.render('Editor', {title: "" + name});
});
router.post('/getcode', function(req, res){
var usercode = req.body;
fs.writeFile(name + ".java", usercode, function(err){
if(err){
console.log(err);
} else{
console.log("The file is saved!");
}
})
res.send({code: "" + usercode});
console.log(usercode);
});
return router;
}
答案 0 :(得分:0)
您实际上是将req.body
对象写入文件,该文件是一个JSON对象,用于访问请求中的帖子数据。
您需要通过该对象内的表单字段名称访问帖子数据,因此如果您有一个名为" myField"的表单字段,它的数据将在req.body.myField
<中提供/ p>
如果您只想将整个对象写入文件,则需要先使用JSON.stringify(req.body)
JSON.stringify
将转义字符串,您可以使用unescape(string)
答案 1 :(得分:0)
在客户端,代码应为:
$(document).ready(function(){
$("#save").click(function(event){
var content = editor.getValue();
console.log("This is content: " + content);
$.ajax({
url:'/getcode',
type:'POST',
data: {'code': content},
processData: 'false',
});
event.preventDefault();
return false;
});
});
服务器端的代码应为:
router.post('/getcode', function(req, res){
var usercode = req.body.code;
newname = name+".java";