highcharts jpg java_highcharts本地导出图片,pdf服务端代码

先要在exporting.js中修改导出图片的url是本地的服务器地址

String type = getPara("type");//getRequest().getParameter("type");

String svg =getPara("svg");// getRequest().getParameter("svg");

String filename = getPara("filename");//getRequest().getParameter("filename");

ServletOutputStream out1 =  null;

try {

//getRequest().setCharacterEncoding("utf-8");

System.out.println(type);

System.out.println(svg);

System.out.println(filename);

filename = filename==null?"chart":filename;

out1 = getResponse().getOutputStream();

if (null != type && null != svg) {

svg = svg.replaceAll(":rect", "rect");

String ext = "";

Transcoder t = null;

if (type.equals("image/png")) {

ext = "png";

t = new PNGTranscoder();

} else if (type.equals("image/jpeg")) {

ext = "jpg";

t = new JPEGTranscoder();

} else if(type.equals("image/svg+xml")) {

ext = "svg";

}else if(type.equals("application/pdf")){

t = new PDFTranscoder();

ext = "pdf";

}

getResponse().addHeader("Content-Disposition", "attachment; filename="+ filename + "."+ext);

getResponse().addHeader("Content-Type", type);

if (null != t) {

TranscoderInput input = new TranscoderInput(new StringReader(svg));

TranscoderOutput output = new TranscoderOutput(out1);

try {

t.transcode(input, output);

} catch (TranscoderException e) {

out1.print("Problem transcoding stream. See the web logs for more details.");

e.printStackTrace();

}

} else if (ext.equals("svg")) {

//    out.print(svg);

OutputStreamWriter writer = new OutputStreamWriter(out1, "UTF-8");

writer.append(svg);

writer.flush();

writer.close();

} /*else

out.print("Invalid type: " + type);*/

} else {

//getResponse().addHeader("Content-Type", "text/html");

// out.println("Usage:\n\tParameter [svg]: The DOM Element to be converted." +

//         "\n\tParameter [type]: The destination MIME type for the elment to be transcoded.");

}

} catch (Exception e) {

e.printStackTrace();

}finally{

try {

out1.flush();

getResponse().flushBuffer();

out1.close();

} catch (Exception e2) {

}

}需要的jar包:

b944988d82248fda2caefe2a0cee2ba6.png

posted on 2013-03-12 13:47 杨军威 阅读(2068) 评论(0)  编辑  收藏

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值