首页 > 代码库 > jsp+iframe+serverlet实现文件上传
jsp+iframe+serverlet实现文件上传
实现文件上传我想大家也都会
这是jsp页面的代码
index.jsp
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title>Insert title here</title></head><body><table><tr><td colspan="2" align="center">商品添加</td></tr><tr><td><form action="Iframe.jsp" target="My_Iframe" method="post">名称: <input name="gname"/><br /><br />类别: <input name="gtype"/><br /><br />价格: <input name="gprice"/><br /><br />数量: <input name="gnumber"/><br /><br />照片: <input id="photo" name="gphoto"/><br /><br /></td><td ><iframe name="My_Iframe" src="Iframe.jsp?filename=1407170231464.jpg" style="height:180px"></iframe></td></tr><tr><td colspan="2">描述: <textarea style="width:450px" cols="30" rows="5"></textarea> </td></tr></table></form></body></html>
这是iframe框架所引用的界面
Iframe.jsp
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><title>Insert title here</title></head><% String path = request.getContextPath(); String filename = request.getParameter("filename"); String image = path+"/"+filename; // if(image==null||image=="")// {// image=path+"/"+"1407170231464.jpg"; // } System.out.print(image);%><body onload="returnParent()"><img src="<%=image %>" width="100px" height="100px"/><input id="image1" value="<%=filename %>" type="hidden"/><form action="image" method="post" enctype="multipart/form-data"> <input type="file" name="goodsImage" /> <input type="submit" value="上传" /></form><script type="text/javascript">function returnParent() { var frameValue = document.getElementById("image1").value; //window表示当前的页面 //window.parent表示获取到父窗体 window.parent.document.getElementById("photo").value = frameValue;}</script></body></html>
这里学到了新知识就是将iframe窗体中的某个元素的值赋给父窗体
var frameValue = document.getElementById("image1").value;
//window表示当前的页面
//window.parent表示获取到父窗体
window.parent.document.getElementById("photo").value = frameValue;
下面的这个是iframe内点击上传时 anction所对应的Serverlet代码
imageservlets.java
package com.shxt.lesson16homework.Servlets;import java.io.File;import java.io.FileOutputStream;import java.io.IOException;import java.io.InputStream;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import org.apache.commons.fileupload.FileItemIterator;import org.apache.commons.fileupload.FileItemStream;import org.apache.commons.fileupload.disk.DiskFileItemFactory;import org.apache.commons.fileupload.servlet.ServletFileUpload;public class imageservlets extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { request.setCharacterEncoding("utf-8"); try{ DiskFileItemFactory factory = new DiskFileItemFactory(); ServletFileUpload upload = new ServletFileUpload(factory); FileItemIterator iter = upload.getItemIterator(request); FileItemStream stream = iter.next(); //获取到文件(流默认是闭合的) InputStream input = stream.openStream(); //openStream方法将流打开,转化为标准的InputStream(字节流)// File f = new File(input);// FileInputStream fs = new FileInputStream(input);// String filename=stream.getName();// // String kzm = filename.substring(filename.length()-4); //文件名称 String tomcatPath = request.getSession().getServletContext().getRealPath("/"); String imgname= new java.util.Date().getTime()+".jpg"; String newfilename =tomcatPath+"/"+ imgname; File file = new File(newfilename); FileOutputStream output = new FileOutputStream(file); byte[] buffer = new byte[1024]; //字节数组类型的缓冲区 while (true) { //输入流input指向源,从源中读取数据,暂时存储在buffer中 int count1 = input.read(buffer); System.out.println(count1); if (count1 == -1) { break; } //输出流output指向目标,向目标写入数据,数据从buffer中获取 output.write(buffer, 0, count1); } //System.out.print(kzm); response.sendRedirect("Iframe.jsp?filename="+imgname); }catch(Exception e){ e.printStackTrace(); } }}
Serverlet处理上传文件时引入了3个包
commons-fileupload-1.2.2.jar commons-io-2.0.1.jar commons-logging.jar
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。