java 将页面指定区域截图并上传到服务器

controller层:

  /**
     * 上传获取到的收据图片
     * @param request
     * @param data 获取到的图片
     * @return
   */ @RequestMapping(value = "/saveImg", method = { RequestMethod.POST }) @ResponseBody public String saveImg(HttpServletRequest request, String data) { String serverPath = request.getSession().getServletContext().getRealPath("/"); Base64 base64 = new Base64(); try { byte[] k = base64.decode(data.substring("data:image/png;base64,".length())); InputStream is = new ByteArrayInputStream(k); String fileName = UUID.randomUUID().toString();//保存的图片名称 String date = new SimpleDateFormat("yyyyMM").format(new Date()); String imgFilePath = serverPath + "服务器图片地址"+date+"/"+ fileName + ".jpg"; BufferedImage image = ImageIO.read(is); BufferedImage tag = new BufferedImage(image.getWidth(), image.getHeight(), BufferedImage.TYPE_INT_RGB); Graphics g = tag.getGraphics(); g.drawImage(image, 0, 0, null); g.dispose(); ImageIO.write(tag, "jpg", new File(imgFilePath)); return fileName; } catch (Exception e) { e.printStackTrace(); } return null; }

JavaScript代码:

function save(){
  html2canvas($("#div1"),{ // 要截图生成图片的区域
        onrendered:function(canvas){
             var  myImage =canvas.toDataURL("image/png");
             $.ajax({  
                type : "POST",  
                url : 'saveImg.jhtml',  
                data : {data:myImage},  
                timeout : 60000,  
                success : function(data){
                    alert("操作成功");
                }  
             });  
          },
          width:1000,
          height:530
      })
 }

 

posted @ 2018-07-16 17:47  横行跋扈的离家漫游者  阅读(1075)  评论(0编辑  收藏  举报