<h1 style="text-align: center">开放签电子签章工具版源码</h1> #### 项目简介 将电子签章的核心技术代码和工具进行开源,开源版采用更加宽松的MIT开源协议,且不受商业限制。产品功能包括:电子印章制作,手写签名生成,数字证书生成,PDF文件转图片,电子签章(关键字签署、指定位置签署),文件验签等 #### 项目源码 | | 后端源码 | 前端源码 | |--- |--- | --- | | github | https://github.com/kaifangqian/open-sign | https://github.com/kaifangqian/open-sign-vue | | 码云 | https://gitee.com/kaifangqian/open-sign | https://gitee.com/kaifangqian/open-sign-vue | #### 官网地址 [https://www.kaifangqian.com](https://www.kaifangqian.com) #### 体验地址 [https://demo.kaifangqian.com](https://demo.kaifangqian.com) #### 工具库说明 ##### 手写签名面板 * 提供个人手写签名面板的前端页面,生成手写签名图片。 ![手写签名面板](./docs/images/signature.png) ##### 电子印章制作 * 为企业生成电子印章,生成印章的方式有两种:<br/> * 系统生成:根据印章环绕文字、横排文字生成电子印章图片; ![系统生成](./docs/images/seal-template.png) * 印模生成: * 在白纸上加盖印章; * 拍照或扫描上传,对印模图片进行裁剪; * 对裁剪后的印模图片进行自动透明化抠图,生成透明印章; ![印模生成](./docs/images/seal-ym.png) ##### 数字证书(公钥加密技术生成,非CA数字证书)生成 * 生成用于测试电子签章的数字证书,该数字证书使用公钥加密技术进行生成,主要用于帮助开发者跑通电子签章流程,非CA机构签发,不具备法律效力!<br/> * 以下从功能和用途上对SSL证书和CA证书进行简单介绍:<br/><br/> * SSL证书和CA证书都是数字证书,但它们在功能和用途上存在明显的区别。<br/><br/> * CA证书由权威的数字证书颁发机构(CA)颁发。在电子签章过程中,CA数字证书可以验证签署者的身份,将签名数据与数字证书中的公钥进行加密,以保证签名的安全和可靠性。同时,CA证书还可以确保签署的文件没有被篡改,保证电子信息的完整性、保密性和不可抵赖性。通过使用CA数字证书,可以确认签署主体的身份,确保签名是符合法律规定的、是防篡改的,让电子合同和纸质合同具有同等法律效力。在签署电子合同之前,用户需要完成实名认证,由CA机构来签发数字证书,确认签署主体的身份。因此,CA数字证书在电子签章中起到了关键的作用,可以确保签署过程的合法性和安全性,使得电子签署文件具有更高的可信度和法律效力。<br/><br/> * SSL证书是一种加密协议,用于保护网站和用户之间的数据传输安全。SSL证书通过使用公钥加密技术,将用户的敏感信息(如信用卡号、密码等)加密传输,以防止被恶意第三方截获和窃取。同时,SSL证书还可以验证网站的身份,确保用户与正确的网站进行通信。因此,SSL证书主要用于加密网站和用户之间的数据传输,保护用户的隐私和安全。<br/><br/> ![数字证书](./docs/images/pdf-cert.png) ##### PDF文件转图片 * 提供PDF文件转图片的工具类。<br/> * 电子签章过程中存在着在网页上对签署文件进行预览、指定签署位置、文件签署等操作,由于图片在浏览器上的兼容性和友好性优于PDF文件,所以一般在网页上进行电子签章时,会先将PDF文件转换成图片,展示给用户。用户在页面上确定好签署位置,并进行签署时,后端服务会通过对电子印章/手写签名位置、大小以及PDF文件的大小进行计算,在PDF文件的准确位置上完成文件签署。 ##### 电子文件签署 * 电子文件签署是指对电子文件进行电子签章的过程。<br/> * 开放签-开源版提供了两种电子签章的方式,如下:<br/> * 关键字签署:指定PDF文件中需要进行签章的关键字,签署时,会在文档中查找对应关键字的位置,并加盖电子印章/手写签名,完成电子签章;</li> * 指定位置签署:直接指定在PDF文件中需要加盖电子印章/手写签名的位置,签署时,直接在指定位置上完成电子签章。</li> ![电子文件签署](./docs/images/product.png) ##### 签署文件验证 * 验证电子文件是否被篡改以及文件中对应的电子印章/手写签名和数字证书信息。<br/> * 验证一般存在以下几种情况:<br/> * PDF文件中不存在数字签名,即该文件未进行过电子签章,无需验证; * PDF文件中存在数字证书,进行签名验证时发生错误,签名包含不正确的、无法识别的、已损坏的或可疑的数据,即文件的签名信息被篡改,验证不通过; * PDF文件中存在数字证书,且数字证书均可识别,但文件被篡改,验证不通过; * PDF文件中存在数字证书,文档未被篡改,验证通过。 ![签署文件验证](./docs/images/verify.png) #### Build Setup ``` #进入项目目录 cd open-sign #进行打包 mvn clean package #运行jar包 java -jar target/opensign-demo.jar ``` #### 代码结构 ``` - open-sign 开放签工具 - controller 提供演示接口 - enums 公共枚举类 - service 签约服务 - cert 证书服务 - image 印模图片处理、PDF转图片处理 - pdf 签署位置计算、PDF文件签署 - verify PDF文件验签 - utils 工具类 ``` #### 反馈交流 - QQ交流群:482074553