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

2018-07-17 03:58:05来源:博客园 阅读 ()

新老客户大回馈,云服务器低至5折

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
      })
 }

 

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:利用ObjectMapper readValue()和泛型解决复杂json结构

下一篇:springmvc 文件上传