Jquery error : too much recursion
Jquery error : too much recursion
我正在尝试创建一个使用 CryptoJS 实现客户端加密的文件上传系统。
我遇到的问题是脚本的执行因 Firebug 控制台中的以下错误而停止:too much recursion
我花了半天时间尝试解决问题,删除 var jqxhr = $.ajax
部分可以消除错误,但会从我的脚本中删除发布功能。我试过删除所有的加密线,分成不同的功能,但似乎什么也做不了。 jQuery 专业人士知道出了什么问题吗?
代码如下:
$("#successmsg").hide();
$("#errormsg").hide();
function randomString(n)
{
var text = '';
var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
for(var i=0; i < n; i++)
{
text += possible.charAt(Math.floor(Math.random() * possible.length));
}
return text;
}
$("#upload").submit(function(event) {
event.preventDefault();
input = document.getElementById('file');
if(!input.files[0]) {
$("#errormsg").html("No file selected.");
$("#successmsg").hide();
$("#errormsg").show();
}
fr = new FileReader();
fr.onload = function() {
var fname = input.files[0].name;
var fkey = CryptoJS.SHA256(randomString(128));
var skey = CryptoJS.SHA256(fkey);
var fdata = CryptoJS.AES.encrypt(fr.result, "TestPassword");
var jqxhr = $.ajax({
url: "/api/files/upload",
type: "POST",
data: {
'name': fname,
'data': fdata,
'key': skey
},
cache: false,
dataType: 'json',
processData: false
});
}
fr.readAsText(input.files[0]);
});
这是一个 JSFiddle:http://jsfiddle.net/wob66Lc0/
问题是 CryptoJS
函数 return 对象不是字符串,因此您必须在尝试发送之前将其字符串化。
var jqxhr = $.ajax({
url: "/api/files/upload",
type: "POST",
data: {
'name': fname,
'data': fdata.toString(),
'key': skey.toString()
}
});
http://jsfiddle.net/wob66Lc0/1/
加密也适用于字节而不是文本,因此您应该将文件读取为二进制字符串而不是文本
fr.readAsBinaryString(input.files[0]);
我正在尝试创建一个使用 CryptoJS 实现客户端加密的文件上传系统。
我遇到的问题是脚本的执行因 Firebug 控制台中的以下错误而停止:too much recursion
我花了半天时间尝试解决问题,删除 var jqxhr = $.ajax
部分可以消除错误,但会从我的脚本中删除发布功能。我试过删除所有的加密线,分成不同的功能,但似乎什么也做不了。 jQuery 专业人士知道出了什么问题吗?
代码如下:
$("#successmsg").hide();
$("#errormsg").hide();
function randomString(n)
{
var text = '';
var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
for(var i=0; i < n; i++)
{
text += possible.charAt(Math.floor(Math.random() * possible.length));
}
return text;
}
$("#upload").submit(function(event) {
event.preventDefault();
input = document.getElementById('file');
if(!input.files[0]) {
$("#errormsg").html("No file selected.");
$("#successmsg").hide();
$("#errormsg").show();
}
fr = new FileReader();
fr.onload = function() {
var fname = input.files[0].name;
var fkey = CryptoJS.SHA256(randomString(128));
var skey = CryptoJS.SHA256(fkey);
var fdata = CryptoJS.AES.encrypt(fr.result, "TestPassword");
var jqxhr = $.ajax({
url: "/api/files/upload",
type: "POST",
data: {
'name': fname,
'data': fdata,
'key': skey
},
cache: false,
dataType: 'json',
processData: false
});
}
fr.readAsText(input.files[0]);
});
这是一个 JSFiddle:http://jsfiddle.net/wob66Lc0/
问题是 CryptoJS
函数 return 对象不是字符串,因此您必须在尝试发送之前将其字符串化。
var jqxhr = $.ajax({
url: "/api/files/upload",
type: "POST",
data: {
'name': fname,
'data': fdata.toString(),
'key': skey.toString()
}
});
http://jsfiddle.net/wob66Lc0/1/
加密也适用于字节而不是文本,因此您应该将文件读取为二进制字符串而不是文本
fr.readAsBinaryString(input.files[0]);