获取页面传递字符
String data = req.getParameter("data");
String imageData=data.substring(data.indexOf(",")+2, data.length()-2);
//System.out.println(imageData.indexOf("\\"));
//String s="\\";
//imageData=imageData.replaceAll(s, " ");
imageData=imageData.replace('\\', ' ');
imageData=imageData.replaceAll(" \"", "\"");
//保存特定的目录下面 读取配置文件的路径
StringBuffer realPathDir = new StringBuffer();
realPathDir.append(PropertiesUtil.getProperty("SaveFilePath")+Constant.PACT.CAND_SIGNATURE);
String path = realPathDir.toString();
String filename=fix+candId+".png";
String imgPath = SvgPngConverter.convertToPng(imageData,path,path+"/"+filename);
SvgPngConverter.java
package com.qk365.util;
import java.io.ByteArrayInputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import org.apache.batik.transcoder.TranscoderException;
import org.apache.batik.transcoder.TranscoderInput;
import org.apache.batik.transcoder.TranscoderOutput;
import org.apache.batik.transcoder.image.PNGTranscoder;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import com.qk365.join.comp.action.CanditorMobileController;
/**
* 将svg转换为png格式的图片
*
*
*/
public abstract class SvgPngConverter {
private static Logger logger = LoggerFactory.getLogger(SvgPngConverter.class);
/**
* 将svg字符串转换为png
*
* @param svgCode svg代码
* @param pngFilePath 保存的路径
* @throws TranscoderException svg代码异常
* @throws IOException io错误
*/
public static String convertToPng(String svgCode, String filePah,String pngFilePath) throws IOException,
TranscoderException {
File fileFloder = new File(filePah);
if(!fileFloder.exists()){
fileFloder.mkdir();
}
//File file = new File(pngFilePath);
FileOutputStream outputStream = null;
try {
// file.createNewFile();
outputStream = new FileOutputStream(pngFilePath);
convertToPng(svgCode, outputStream);
return pngFilePath;
} finally {
if (outputStream != null) {
try {
outputStream.close();
} catch (IOException e) {
logger.error("outputStream.close e:",e);
return null;
}
}
}
}
/**
* 将svgCode转换成png文件,直接输出到流中
*
* @param svgCode svg代码
* @param outputStream 输出流
* @throws TranscoderException 异常
* @throws IOException io异常
*/
public static void convertToPng(String svgCode, OutputStream outputStream)
throws TranscoderException, IOException {
try {
byte[] bytes = svgCode.getBytes("utf-8");
PNGTranscoder t = new PNGTranscoder();
TranscoderInput input = new TranscoderInput(new ByteArrayInputStream(bytes));
TranscoderOutput output = new TranscoderOutput(outputStream);
t.transcode(input, output);
outputStream.flush();
} finally {
if (outputStream != null) {
try {
outputStream.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
public static void main(String[] args) {
StringBuffer sb=new StringBuffer();
// sb.append("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?><!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\"><svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" width=\"401\" height=\"36\"><path fill=\"none\" stroke=\"#000000\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M 1 1 c 2.12 0 80.27 -1.58 121 0 c 20 0.78 38.73 3.98 59 7 c 37.69 5.61 71.69 12.77 109 18 c 16.27 2.28 31.51 2.25 48 4 c 12.78 1.35 24.53 3.99 37 5 c 8.35 0.67 25 0 25 0\"/></svg>");
sb.append("<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?><!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\"><svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" width=\"456\" height=\"132\"><path fill=\"none\" stroke=\"#000000\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M 2 44 c -0.02 0.19 -1.72 7.99 -1 11 c 0.76 3.17 3.72 7.15 6 10 c 1.53 1.91 3.86 3.53 6 5 c 3.2 2.2 6.51 4.45 10 6 c 5.4 2.4 11.31 3.69 17 6 c 6.92 2.81 13.08 6.44 20 9 c 8.58 3.17 17.02 5.98 26 8 c 27.27 6.12 53.42 11.36 81 16 c 10.73 1.8 21.12 1.57 32 3 c 9.96 1.31 18.94 3.55 29 5 c 21.04 3.04 40.39 7 61 8 c 34.85 1.69 69.52 0.59 104 0 c 4.03 -0.07 7.97 -1.12 12 -2 c 3.77 -0.82 7.42 -1.75 11 -3 c 3.1 -1.08 6.13 -2.39 9 -4 c 5.5 -3.08 11.74 -6.06 16 -10 c 4.2 -3.89 7.74 -9.98 11 -15 c 0.94 -1.45 1.43 -3.29 2 -5 c 0.44 -1.31 1 -2.75 1 -4 c 0 -1.85 -0.12 -4.39 -1 -6 c -2.8 -5.14 -6.49 -11.97 -11 -16 c -10.32 -9.23 -23.9 -16.86 -36 -26 c -4.64 -3.5 -8.36 -7.61 -13 -11 c -7.86 -5.73 -15.83 -11.05 -24 -16 c -2.79 -1.69 -6.3 -2.38 -9 -4 c -2.14 -1.28 -3.91 -3.88 -6 -5 c -1.95 -1.05 -4.59 -1.4 -7 -2 c -1.69 -0.42 -3.44 -1 -5 -1 c -1.56 0 -3.66 0.19 -5 1 c -10.4 6.29 -22.47 14.1 -33 22 c -5.45 4.09 -9.76 10.12 -15 14 l -12 6\"/></svg>");
String m="<?xml version=\"1.0\" encoding=\"UTF-8\" standalone=\"no\"?><!DOCTYPE svg PUBLIC \"-//W3C//DTD SVG 1.1//EN\" \"http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd\"><svg xmlns=\"http://www.w3.org/2000/svg\" version=\"1.1\" width=\"456\" height=\"132\"><path fill=\"none\" stroke=\"#000000\" stroke-width=\"2\" stroke-linecap=\"round\" stroke-linejoin=\"round\" d=\"M 2 44 c -0.02 0.19 -1.72 7.99 -1 11 c 0.76 3.17 3.72 7.15 6 10 c 1.53 1.91 3.86 3.53 6 5 c 3.2 2.2 6.51 4.45 10 6 c 5.4 2.4 11.31 3.69 17 6 c 6.92 2.81 13.08 6.44 20 9 c 8.58 3.17 17.02 5.98 26 8 c 27.27 6.12 53.42 11.36 81 16 c 10.73 1.8 21.12 1.57 32 3 c 9.96 1.31 18.94 3.55 29 5 c 21.04 3.04 40.39 7 61 8 c 34.85 1.69 69.52 0.59 104 0 c 4.03 -0.07 7.97 -1.12 12 -2 c 3.77 -0.82 7.42 -1.75 11 -3 c 3.1 -1.08 6.13 -2.39 9 -4 c 5.5 -3.08 11.74 -6.06 16 -10 c 4.2 -3.89 7.74 -9.98 11 -15 c 0.94 -1.45 1.43 -3.29 2 -5 c 0.44 -1.31 1 -2.75 1 -4 c 0 -1.85 -0.12 -4.39 -1 -6 c -2.8 -5.14 -6.49 -11.97 -11 -16 c -10.32 -9.23 -23.9 -16.86 -36 -26 c -4.64 -3.5 -8.36 -7.61 -13 -11 c -7.86 -5.73 -15.83 -11.05 -24 -16 c -2.79 -1.69 -6.3 -2.38 -9 -4 c -2.14 -1.28 -3.91 -3.88 -6 -5 c -1.95 -1.05 -4.59 -1.4 -7 -2 c -1.69 -0.42 -3.44 -1 -5 -1 c -1.56 0 -3.66 0.19 -5 1 c -10.4 6.29 -22.47 14.1 -33 22 c -5.45 4.09 -9.76 10.12 -15 14 l -12 6\"/></svg>";
//<?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg xmlns="http://www.w3.org/2000/svg" version="1.1" width="456" height="132"><path fill="none" stroke="#000000" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" d="M 2 44 c -0.02 0.19 -1.72 7.99 -1 11 c 0.76 3.17 3.72 7.15 6 10 c 1.53 1.91 3.86 3.53 6 5 c 3.2 2.2 6.51 4.45 10 6 c 5.4 2.4 11.31 3.69 17 6 c 6.92 2.81 13.08 6.44 20 9 c 8.58 3.17 17.02 5.98 26 8 c 27.27 6.12 53.42 11.36 81 16 c 10.73 1.8 21.12 1.57 32 3 c 9.96 1.31 18.94 3.55 29 5 c 21.04 3.04 40.39 7 61 8 c 34.85 1.69 69.52 0.59 104 0 c 4.03 -0.07 7.97 -1.12 12 -2 c 3.77 -0.82 7.42 -1.75 11 -3 c 3.1 -1.08 6.13 -2.39 9 -4 c 5.5 -3.08 11.74 -6.06 16 -10 c 4.2 -3.89 7.74 -9.98 11 -15 c 0.94 -1.45 1.43 -3.29 2 -5 c 0.44 -1.31 1 -2.75 1 -4 c 0 -1.85 -0.12 -4.39 -1 -6 c -2.8 -5.14 -6.49 -11.97 -11 -16 c -10.32 -9.23 -23.9 -16.86 -36 -26 c -4.64 -3.5 -8.36 -7.61 -13 -11 c -7.86 -5.73 -15.83 -11.05 -24 -16 c -2.79 -1.69 -6.3 -2.38 -9 -4 c -2.14 -1.28 -3.91 -3.88 -6 -5 c -1.95 -1.05 -4.59 -1.4 -7 -2 c -1.69 -0.42 -3.44 -1 -5 -1 c -1.56 0 -3.66 0.19 -5 1 c -10.4 6.29 -22.47 14.1 -33 22 c -5.45 4.09 -9.76 10.12 -15 14 l -12 6"/></svg>
//<?xml version= "1.0 " encoding= "UTF-8 " standalone= "no "?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN " "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd "><svg xmlns= "http://www.w3.org/2000/svg " version= "1.1 " width= "452 " height= "68 "><path fill= "none " stroke= "#000000 " stroke-width= "2 " stroke-linecap= "round " stroke-linejoin= "round " d= "M 1 1 c 0.39 0.3 14.23 11.67 22 17 c 10.55 7.23 20.85 14.18 32 20 c 11.91 6.21 24.32 10.98 37 16 c 5.27 2.09 10.45 3.52 16 5 c 9.88 2.63 19.3 5.35 29 7 c 5.86 1 11.8 0.92 18 1 c 20.97 0.27 40.16 0.47 61 0 c 9.25 -0.21 17.89 -0.86 27 -2 c 9.91 -1.24 19.3 -2.79 29 -5 c 9.6 -2.19 18.99 -4.56 28 -8 c 9.27 -3.54 17.58 -8.96 27 -13 c 14.53 -6.23 32.65 -16.83 43 -17 c 5.23 -0.09 11.29 11.28 17 16 c 1.64 1.36 3.98 2.27 6 3 c 1.54 0.56 3.33 0.93 5 1 c 6.55 0.26 13.96 1.31 20 0 c 8.41 -1.83 17.84 -6.29 26 -10 l 7 -5 "/></svg>
/*try {
convertToPng(sb.toString(), "e:/hr.png");
} catch (Exception e) {
e.printStackTrace();
}*/
String s="=\\\"=";
System.out.println(s.indexOf("/"));
s=s.replaceAll("\\", "*");
System.out.println(s);
}
}
jsp页面demo见附件
分享到:
相关推荐
签名完成后,可以使用提供的按钮将签名保存为Base64字符串,或者清除当前的签名。 在实际应用中,开发者可能会进一步扩展这个Demo,例如添加保存签名的功能,将Base64数据发送到服务器,或者将签名数据与表单中的...
HTML签字加时间水印(支持移动端)-jSignature-扩展。根据jSignature官方demo,制作自己的带水印签字图片,图片格式只用了base64,喜欢的朋友可以自己改全格式的图片,欢迎大家指导
Java系统源码+科研工作量管理系统 内容概要: 本资源包含了完整的Java前后端源码及说明文档,适用于想要快速搭建并部署Java Web应用程序的开发者、学习者。 技术栈: 后端:Java生态系统,包含Spring Boot、Shiro、MyBatis等,数据库使用Mysql 前端:Vue、Bootstrap、Jquery等 适用场景示例: 1、毕业生希望快速启动一个新的Java Web应用程序。 2、团队寻找一个稳定的模板来加速产品开发周期。 3、教育机构或个人学习者用于教学目的或自学练习。 4、创业公司需要一个可以立即投入使用的MVP(最小可行产品)。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、本项目仅用作交流学习参考,请切勿用于商业用途。
内容概要:本文介绍了如何在MATLAB中实现结合黏菌优化算法(SMA)和核极限学习机(KELM)的分类预测模型。SMA优化KELM的超参数,提高模型的训练效率和预测精度,特别适用于处理复杂、高维数据集。文档详细阐述了项目背景、目标、挑战、模型架构、代码实现、结果展示、GUI设计、部署与应用等多个方面。 适合人群:具备一定MATLAB编程基础,对机器学习特别是优化算法和核方法感兴趣的科研人员和工程师。 使用场景及目标:①金融预测:股票价格、外汇市场等时间序列预测;②医疗诊断:疾病预测与辅助诊断;③工业故障检测:设备故障预警;④气象预测:天气变化预测;⑤市场营销:客户行为分析与预测。通过结合SMA和KELM,提升模型在高维数据上的分类和预测性能。 其他说明:文档不仅提供了详细的理论和方法介绍,还包含了完整的程序代码和GUI设计,有助于读者快速上手并应用到实际问题中。此外,文档还讨论了模型的部署、安全性和未来改进方向。
解压到项目下的LIB目录,在IDEA上右键,选添加为库即可。 连接代码如下: import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; public class SQL { public static void main(String[] args) { String driverName = "com.microsoft.jdbc.sqlserver.SQLServerDriver"; String connectionUrl = "jdbc:microsoft:sqlserver://localhost:1433;DatabaseName=数据库名"; String username = "sa"; String password = "口令"; try { Class.forNam……
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、本项目仅用作交流学习参考,请切勿用于商业用途。
水母检测4-YOLO(v5至v9)、COCO、CreateML、Paligemma、TFRecord、VOC数据集合集.rar水族馆-V2释放 ============================= *与您的团队在计算机视觉项目上合作 *收集和组织图像 *了解非结构化图像数据 *注释,创建数据集 *导出,训练和部署计算机视觉模型 *使用主动学习随着时间的推移改善数据集 它包括638张图像。 水族馆以可可格式注释。 将以下预处理应用于每个图像: 没有应用图像增强技术。
电缆损坏检测8-YOLO(v5至v9)、COCO、CreateML、Darknet、Paligemma、TFRecord、VOC数据集合集.rar电缆损坏-V2释放 ============================= *与您的团队在计算机视觉项目上合作 *收集和组织图像 *了解非结构化图像数据 *注释,创建数据集 *导出,训练和部署计算机视觉模型 *使用主动学习随着时间的推移改善数据集 它包括1318张图像。 电缆破坏以可可格式注释。 将以下预处理应用于每个图像: 没有应用图像增强技术。
项目包含前后台完整源码。 项目都经过严格调试,确保可以运行! 具体项目介绍可查看博主文章或私聊获取 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!
2024年以来,税务稽查主要针对虚开骗税、骗取税收优惠、隐匿收入、虚增成本等行为,开展重点行业重点领域重点行为税收监管。本课程从案例出发,梳理稽查重点关注的问题行为,分析常见涉税疑点,供财务人员实务参考。
content_1734090857469.docx
阵列信号处理,MUSIC算法中,使用基于协方差矩阵的幅相误差校正法实现幅相误差校正
以下是一个关于Linux系统管理与自动化脚本项目的资源描述及源码概要: 资源描述 本项目专注于Linux系统管理与自动化脚本开发,旨在通过一系列脚本提升系统运维效率。在资源准备阶段,我们深入研究了Linux系统架构、Shell脚本编程、以及常用系统管理命令。参考了《Linux命令行与Shell脚本编程大全》等经典书籍,以及Linux官方文档和在线社区,如Stack Overflow和Linux Academy,这些资源为我们提供了丰富的知识和实战案例。 项目实施过程中,我们利用Bash Shell作为主要脚本语言,结合sed、awk、grep等文本处理工具,以及cron作业调度器,实现了系统监控、日志分析、自动备份、用户管理等一系列自动化任务。同时,通过SSH和rsync等工具,实现了远程服务器管理和文件同步,极大地提高了运维的灵活性和效率。 项目源码概要 项目源码包含多个Shell脚本文件,每个脚本负责不同的自动化任务: system_monitor.sh:监控系统资源使用情况,如CPU、内存、磁盘空间等,并生成报告。 log_analyzer.sh:分析系统日志文件,提取关
资源说明; 完好机备份的基带qcn文件 下载后解压 可以解决常规更新降级刷第三方导致的基带丢失。 会使用有需要的友友下载,不会使用的请不要下载 需要开端口才可以写入,不会开端口的请不要下载 希望我的资源可以为你带来帮助 谢谢 参考: https://blog.csdn.net/u011283906/article/details/124720894?spm=1001.2014.3001.5502
项目包含前后台完整源码。 项目都经过严格调试,确保可以运行! 具体项目介绍可查看博主文章或私聊获取 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!
情侣恋爱主题源码LikeGirlv5.2.0最终版,经过多次更新和优化,情侣小站现已正式定版为v5.2.0。从今日起,此版本将成为项目的最终版本。 维护终止:自2024年11月7日起,情侣小站将不再接受新的功能更新或bug 修复。 用户责任:如在使用过程中遇到任何问题,请自行修复或选择放弃使用。
项目包含前后台完整源码。 项目都经过严格调试,确保可以运行! 具体项目介绍可查看博主文章或私聊获取 助力学习实践,提升编程技能,快来获取这份宝贵的资源吧!