java 图片上传

6 篇文章 0 订阅
extjs 图片上传的两种方式
第一种图片上传到 数据库,页面从数据图读取图片显示,这种方式适合小图片上传,占用小,安全,这种方法我使用传统的流的读写进行图片的处理。

第二种图片上传到本地目录,然后将图片名称上传保存到数据库,这种方法没有第一种方法安全,但是这个方法比较方便,可以将图片保存在项目里,像icon图标就可以不用每次换一个环境就重新上传,这种方法使用的是架包(import org.apache.commons.io.FileUtils;)自带的相当成熟的方法也比较简单。

第一种

java类

    public String addSysMenu() {
        HttpServletRequest req = ServletActionContext.getRequest();
        MultiPartRequestWrapper wrapper = (MultiPartRequestWrapper) req;
        File[] fileNames = wrapper.getFiles("modIconId");
        String[] filenames = wrapper.getFileNames("modIconId");
//流的操作,将图片存入数据库
        byte[] file =null;
        InputStream is=null;
        ByteArrayOutputStream isr=null;
        ByteArrayOutputStream bs=null;
        ImageOutputStream imout=null;
        try {
            isr = new ByteArrayOutputStream();
            for (int i=0;fileNames!=null&&i<fileNames.length;i++) {
                
                Image srcImg=ImageIO.read(fileNames[i]);
                int width =srcImg.getWidth(null);
                int height =srcImg.getHeight(null);
                
                if(width>=height){
                    int x= width/16;
                    height=height/x;
                    width=16;
                } else{
                    int y=height/16;
                    width=width/y;
                    height=16;
                }
                
                BufferedImage buffImg= null;
                buffImg= new BufferedImage(width, height, BufferedImage.TYPE_4BYTE_ABGR);
                buffImg.getGraphics().drawImage(srcImg.getScaledInstance(width, height, Image.SCALE_SMOOTH), 0, 0, null);
                
                bs = new ByteArrayOutputStream();
                
                imout =ImageIO.createImageOutputStream(bs);
                ImageIO.write(buffImg, "PNG", isr );
                
                is= new ByteArrayInputStream(bs.toByteArray());
                
//                is = new FileInputStream(fileNames[i]);
                byte[] fileDate = new byte[256];
                int offset = 0;
                while (offset != -1) {
                    offset = is.read(fileDate);
                    if(offset!=-1){
                        isr.write(fileDate,0,offset);
                    }
                }
                file = isr.toByteArray();
            }
        } catch (Exception e1) {
            e1.printStackTrace();
        }finally{
            try {
                if(is!=null){
                    is.close();
                }
                if(isr!=null){
                    isr.close();
                }
                if(bs!=null){
                    bs.close();
                }
                if(imout!=null){
                    imout.close();
                }
            } catch (Exception e) {
                log.warn("流关闭失败",e);
            }
        }
                sysMenu.setIcon(file);
        
        String id = service.addSysMenu(sysMenu);
        this.setJsonStr("{success:true,id:'" + id + "'}");
        return SUCCESS;
    }

serviceimpl

    @Override
    public String addSysMenu(SysMenu sysMenu) {
        SysMenuHome sysMenuHome=(SysMenuHome)home;
        String id=sysMenuHome.getId();
        sysMenu.setId(id);
        sysMenuHome.save(sysMenu);
        return id;
    }

jsp页面
  

                        var time = new Date();
                        var tPanel = Ext.create('Ext.tree.Panel',{
                            title:    "<img style='vertical-align:middle;' src='findIcon.action?time=" + time
                                    + "&sysMenu.id=" + sonnode.data.id
                                    +"'/>"
                           + "'  οnlοad='DrawImage(this,16,16)'/>"
                                    +sonnode.data.name,
                    
                        });
                                          
 第二种

java类

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.OutputStream;

import javax.servlet.http.HttpServletRequest;

import org.apache.commons.io.FileUtils;
import org.apache.struts2.ServletActionContext;
import org.apache.struts2.dispatcher.multipart.MultiPartRequestWrapper;

import com.opensymphony.xwork2.ActionSupport;

public class FileUploadAction extends ActionSupport
{
    private String username;
    
    //注意,file并不是指前端jsp上传过来的文件本身,而是文件上传过来存放在临时文件夹下面的文件
    private File file;
    
    //提交过来的file的名字
    private String fileFileName;
    
    //提交过来的file的MIME类型
    private String fileContentType;

    public String getUsername()
    {
        return username;
    }

    public void setUsername(String username)
    {
        this.username = username;
    }

    public File getFile()
    {
        return file;
    }

    public void setFile(File file)
    {
        this.file = file;
    }

    public String getFileFileName()
    {
        return fileFileName;
    }

    public void setFileFileName(String fileFileName)
    {
        this.fileFileName = fileFileName;
    }

    public String getFileContentType()
    {
        return fileContentType;
    }

    public void setFileContentType(String fileContentType)
    {
        this.fileContentType = fileContentType;
    }
    
    @Override
    public String execute() throws Exception
    {
        //这边是web项目的路径,寻找合适的路径
        String root = ServletActionContext.getServletContext().getRealPath("/upload")
       //这边是架包在带的文件复制方法,非常方便
        FileUtils.copyFile(file, new File(root, fileFileName));
        System.out.println("fileFileName: " + fileFileName);
        System.out.println( root + " \\" +fileFileName);

         // 因为file是存放在临时文件夹的文件,我们可以将其文件名和文件路径打印出来,看和之前的fileFileName是否相同
        System.out.println("file: " + file.getName());
        System.out.println("file: " + file.getPath());

        return SUCCESS;
    }
}                    


    jsp页面,这边使用到了ajax的同步请求,只有执行完success方法后才继续进行别的方法,                  
     var iconPath;
                        Ext.Ajax.request({
                            url : 'findIcon.action',
                            method : 'post',
                             async: false,
                            params : {
                                'sysMenu.id':sonnode.data.id
                            },
                            success : function(response, options) {
                                var o = Ext.JSON.decode(response.responseText);
                                iconPath=o.iconPath;
                            },
                            failure : function() {
                                Ext.Msg.alert("提示", "系统忙!");
                            }
                        });
                        
                        var tPanel = Ext.create('Ext.tree.Panel',{
                            title:    "<img style='vertical-align:middle;' src='upload/"+iconPath+";'  οnlοad='DrawImage(this,16,16)'/>"
                                    +sonnode.data.name,
                        });



  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一个简单的Java图片上传接口的示例: ```java import java.io.File; import java.io.IOException; import java.io.PrintWriter; import javax.servlet.ServletException; import javax.servlet.annotation.MultipartConfig; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import javax.servlet.http.Part; @WebServlet("/upload") @MultipartConfig(fileSizeThreshold=1024*1024*2, // 2MB maxFileSize=1024*1024*10, // 10MB maxRequestSize=1024*1024*50) // 50MB public class UploadServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { response.setContentType("text/html;charset=UTF-8"); PrintWriter out = response.getWriter(); // 获取上传文件的部件 Part filePart = request.getPart("file"); // 获取文件名 String fileName = extractFileName(filePart); // 保存到服务器的文件路径 String savePath = "C:/uploads/" + fileName; // 写入文件 filePart.write(savePath); out.println("<html>"); out.println("<head>"); out.println("<title>文件上传成功</title>"); out.println("</head>"); out.println("<body>"); out.println("<h3>文件上传成功!</h3>"); out.println("</body>"); out.println("</html>"); } // 从Part获取文件名 private String extractFileName(Part part) { String contentDisp = part.getHeader("content-disposition"); String[] items = contentDisp.split(";"); for (String s : items) { if (s.trim().startsWith("filename")) { return s.substring(s.indexOf("=") + 2, s.length()-1); } } return ""; } } ``` 在示例中,使用注解`@MultipartConfig`声明上传文件的配置参数。`fileSizeThreshold`设置内存缓冲区的大小,当上传文件超过缓冲区大小时,将会保存到磁盘上。`maxFileSize`和`maxRequestSize`分别设置单个文件和整个请求的最大大小限制。在doPost方法中,使用`request.getPart("file")`获取上传的文件部件,使用`extractFileName`方法从部件中获取文件名,然后将文件写入到指定路径。最后返回上传成功的消息给客户端。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值