我对堆栈和谷歌进行了一些研究,通过 Ajax(在 Grails 中)上传图片,我发现了一些旧链接,因此我决定问你们“有什么方法可以使用 Ajax 上传我的用户图片”?我找到了一个 Grails 插件插件链接,但是这个插件的文档还不够。我想使用这个插件(正如我所说,由于缺乏这个插件的良好文档,看起来我很难实现它)或者请告诉我一些替代选项(如果有)。
问问题
1236 次
1 回答
1
尝试这个..,。
看法:
<html>
<script src="//ajax.googleapis.com/ajax/libs/jquery/1.9.1/jquery.min.js"></script>
<script language="Javascript">
function fileUpload(form, action_url, div_id) {
// Create the iframe...
var iframe = document.createElement("iframe");
iframe.setAttribute("id", "upload_iframe");
iframe.setAttribute("name", "upload_iframe");
iframe.setAttribute("width", "0");
iframe.setAttribute("height", "0");
iframe.setAttribute("border", "0");
iframe.setAttribute("style", "width: 0; height: 0; border: none;");
// Add to document...
form.parentNode.appendChild(iframe);
window.frames['upload_iframe'].name = "upload_iframe";
iframeId = document.getElementById("upload_iframe");
// Add event...
var eventHandler = function () {
if (iframeId.detachEvent) iframeId.detachEvent("onload", eventHandler);
else iframeId.removeEventListener("load", eventHandler, false);
// Message from server...
if (iframeId.contentDocument) {
content = iframeId.contentDocument.body.innerHTML;
} else if (iframeId.contentWindow) {
content = iframeId.contentWindow.document.body.innerHTML;
} else if (iframeId.document) {
content = iframeId.document.body.innerHTML;
}
document.getElementById(div_id).innerHTML = content;
// Del the iframe...
setTimeout('iframeId.parentNode.removeChild(iframeId)', 250);
}
if (iframeId.addEventListener) iframeId.addEventListener("load", eventHandler, true);
if (iframeId.attachEvent) iframeId.attachEvent("onload", eventHandler);
// Set properties of form...
form.setAttribute("target", "upload_iframe");
form.setAttribute("action", action_url);
form.setAttribute("method", "post");
form.setAttribute("enctype", "multipart/form-data");
form.setAttribute("encoding", "multipart/form-data");
// Submit the form...
form.submit();
document.getElementById(div_id).innerHTML = "Uploading...";
}
</script>
<body>
<g:form>
<input type="file" name="myFile"/><br/><br/>
<input type="button" value="upload" onClick="fileUpload(this.form, '${g.createLink(controller: 'dashboard', action: 'test')}', 'upload'); return false;">
<div id="upload"></div>
</g:form>
</body>
</html>
行动:
def test() {
if (params.myFile) {
def fileName
def inputStream
if (params.myFile instanceof CommonsMultipartFile) {
fileName = params.myFile?.originalFilename
inputStream = params.myFile.getInputStream()
} else {
fileName = params.myFile
inputStream = request.getInputStream()
}
fileName = fileName.replaceAll(" ", "_")
File storedFile = new File("DIRECTORY_PATH_TO_SAVE_IMAGE/${fileName}")
storedFile.append(inputStream)
render '<img src="data:' + 'jpg' + ';base64,' + new String(new Base64().encode(storedFile.bytes), "UTF-8") + '" ' + ' />'
} else {
render "No Image"
}
}
于 2013-11-06T17:57:33.287 回答