我正在一個網頁,我使用即興的API對話框,其中包括HTML表單上:使用Ajax進行文件上傳?
html = '<label>Name <input type="text" id="fname" name="fname" value="'+STUDENT_NAME+'"></label><br />'
+ '<label>Sex<select id="sex"> <option value="m" >Male</option> <option value="f" selected>Female</option>'
+ '</select>'
+ '</label><br />'
+ '<label>Category<select id="cat"> <option value="a">A</option> <option value="b" selected>B</option>'
+ '</select>' + '</label>'+
'<input type="file" id="logo">'+
'<br />';
使用Ajax提交這樣的形式:
$.ajax({
url : 'AddStudent.jsp',
data : 'classId=' +
<%=class_id%>
+ '&name='
+ document.getElementById('fname').value
+ '&cat='
+ document.getElementById('cat').value
+ '&func=del' + '&sex='
+ document.getElementById('sex').value,
type : 'post',
success : function(msg) {
//events}
我已經拿到了代碼上傳這樣的文件:
String saveFile = "";
String contentType = request.getContentType();
if ((contentType != null) && (contentType.indexOf("multipart/form-data") >= 0)) {
DataInputStream in = new DataInputStream(request.getInputStream());
int formDataLength = request.getContentLength();
byte dataBytes[] = new byte[formDataLength];
int byteRead = 0;
int totalBytesRead = 0;
while (totalBytesRead < formDataLength) {
byteRead = in.read(dataBytes, totalBytesRead, formDataLength);
totalBytesRead += byteRead;
}
String file = new String(dataBytes);
saveFile = file.substring(file.indexOf("filename=\"") + 10);
saveFile = saveFile.substring(0, saveFile.indexOf("\n"));
saveFile = saveFile.substring(saveFile.lastIndexOf("\\") + 1, saveFile.indexOf("\""));
int lastIndex = contentType.lastIndexOf("=");
String boundary = contentType.substring(lastIndex + 1, contentType.length());
int pos;
pos = file.indexOf("filename=\"");
pos = file.indexOf("\n", pos) + 1;
pos = file.indexOf("\n", pos) + 1;
pos = file.indexOf("\n", pos) + 1;
int boundaryLocation = file.indexOf(boundary, pos) - 4;
int startPos = ((file.substring(0, pos)).getBytes()).length;
int endPos = ((file.substring(0, boundaryLocation)).getBytes()).length;
saveFile = "D:/SERVERE/" + saveFile;
File ff = new File(saveFile);
FileOutputStream fileOut = new FileOutputStream(ff);
fileOut.write(dataBytes, startPos, (endPos - startPos));
fileOut.flush();
fileOut.close();
}
但是,這不會與Ajax方法一起工作。我希望文件必須上傳到同一頁面。如何使用Ajax完成這項工作?或者是否有其他技術?請幫助
你能幫助我的Upload_avatar代碼?它不適合我的工作 – Navdroid