| chinaport-data-signature-app | ||
| chinaport-data-signature-data-model | ||
| doc | ||
| .gitignore | ||
| deploy.sh | ||
| HELP.md | ||
| LICENSE | ||
| pom.xml | ||
| README.md | ||
| start.sh | ||
| 中国电子口岸报文加签接口文档.md | ||
| 中国电子口岸报文加签验证.md | ||
| 使用GitBash右键运行启动脚本.md | ||
China E-Port Data Signature
中国电子口岸(海口海关)报文加签推送应用
前言
After nearly two years of open-source code maintenance and exploration, we have successfully developed an all-in-one solution that offers free access and usage for a wide range of businesses. This solution aims to digitally sign and forward XML messages to the General Administration of Customs at the Chinese Electronic Port (HaiKou Customs), facilitating cross-border e-commerce operations and import-export trade for enterprises.
经过长达近两年的开源代码维护和探索,我们终于成功开发出一站式解决方案,为更多企业提供免费接入和使用。该解决方案的目标是对中国电子口岸海关(海口海关)总署的XML报文进行加签推送,以促进企业的跨境电商业务和进出口贸易。
Weasley J(2023-07)
中国电子口岸海关(海口海关)总署XML报文&海关179数据上报加签服务,一站式的免费解决方案,开箱即用,无中间件;本项目遵守GNU 3.0
协议,本项目测试用例中用到的企业信息已经过企业的批准,企业使用ukey加签进行业务申报时, 请下载release
文件根据自己的实际情况适当修改运行参数既可。
支持:
CEBXxxMessage.xml进出口报文海关179号公告数据抓取报文业务场景:
- 中国境内的跨进电商业务, 进出口贸易
提示:
- 单体应用直接下载release的二进制文件使用即可(使用较多)
- 分布式微服务请切换到
dev-microservice分支构建(较少使用)
系统核心功能预览 访问密码: lm32
软件架构拓扑图 访问密码:O7Q8
决定将此项目开源项目的时候,地球上的搜索引擎在2022-02-14 之前还搜索不到任何有价值的信息,ChatGPT在面对这种付费的解决方案时,它能解决吗.....
![]() |
![]() |
![]() |
- Previews of China e-port data signature
项目开始前我们先了解下海关总署XML报文的加签都在什么价位?百度、CSDN里你能搜索到的仅一个海关179号文件对接,但唯独没有XML的加签,细品下图:
你没看错:你去找乙方对接,乙方不告诉你加签用到的算法,需要接入方自己开发。好,那就开发吧!
- 电子口岸的操作员
u-key长啥样:
- 启动项目:
chinaport-data-signature
Windows终端日志会乱码,推荐通过Git Bash启动
- 右键启动
- GitBash界面启动
1 项目代码质量
2 软件运行概况
| 序号 | 类目 | 版本 | 备注 |
|---|---|---|---|
| 1 | 软件运行环境 | Java SE Development Kit 17 | 基础软件最低运行要求 |
| 2 | 硬件运行环境 | Windows-10-x64/Windows-11-x64/Windows-server-x64/Linux(自行解决内网穿透问题,ukey只能插Windows电脑上) |
|
| 3 | 硬件性能要求 | > =1核CPU+2G运行内存 | 不能比这小 |
| 4 | 对技术人员的要求 | 会把电子口岸ukey插入安装好中国国际贸易单一窗口登录管理 (singlewindow.cn)Windows电脑上,会改启动脚本里面的参数,会用鼠标双击启动脚本 |
3 运行参数配置
本应用是标准的
springboot应用,支持springboot的所有配置参数,推荐通过在线yaml转properties将配置元数据复制到命令行参数中按需使用,
| 配置参数 | 是否必须(Y/N) | 解释 |
|---|---|---|
| eport.signature.algorithm | N | XML签名的算法类型,不指定时使用程序自动推断的算法, 推荐使用程序自动推断 |
| eport.signature.ukey.ws-url | Y | u-key做插Windows电脑的socket链接url,如: ws://127.0.0.1:61232,下载release直接运行的修改全局配置的UKEY_HOST即可 |
| eport.signature.ukey.password | N | u-key密码的密码,默认: 88888888, 如果密码改过,需要指定下,下载release直接运行的修改全局配置的UKEY_PASSWORD即可 |
| eport.signature.ukey.health.endpoint.client-name | N | Windows上重启的ukey可执行文件全限定文件名称,不指定将自动查找 |
| eport.signature.auth.enable | N | 是否启用token鉴权,取值:on/off |
| eport.signature.auth.token | N | 客户端请求鉴权token, 默认值: DefaultAuthToken, 请求头 |
| eport.signature.report.ceb-message.cop-code | Y | 电子口岸XML报文传输企业代码 |
| eport.signature.report.ceb-message.cop-name | Y | 传输企业名称,报文传输的企业名称 |
| eport.signature.report.ceb-message.dxp-id | Y | 文传输编号,向中国电子口岸数据中心申请数据交换平台的用户编号 |
| eport.signature.report.ceb-message.server | N | 海关服务器地址,缺省则采用Client中的密文作文默认Server URL |
| eport.signature.report.customs179.ebp-code | Y | 海关 179 数据上报的电商平台代码 |
| eport.signature.report.customs179.server | N | 数据上报服务器URL地址,链接格式: https://域名联系海关/ceb2grab/grab/realTimeDataUpload,没有配置的话采用项目内置的URL密文地址 |
4 项目启动脚本
4.1 Windows环境
4.2 Linux/MacOS环境
运行方式:终端执行
sh start.sh启动程序
#!/bin/bash
# Environment args
APP="chinaport-data-signature-app"
UKEY_HOST="127.0.0.1"
UKEY_PASSWORD="88888888"
JVM_ARGS="-Xms1g -Xmx1g"
java -Dfile.encoding=utf-8 ${JVM_ARGS} -jar ${APP}.jar \
--server.port=8080 \
--spring.profiles.active=prod \
--eport.signature.ukey.ws-url=ws://${UKEY_HOST}:61232 \
--eport.signature.ukey.password=${UKEY_PASSWORD} \
--spring.mail.enable=false \
--spring.mail.to='abc@qq.com' \
--spring.mail.cc='abc@outlook.com,cbd@qq.com' \
--spring.mail.host='smtp.189.cn' \
--spring.mail.port=465 \
--spring.mail.username='xxx@189.cn' \
--spring.mail.password='your_password' \
--spring.mail.protocol=smtp \
--spring.mail.properties.mail.smtp.ssl.enable=true \
--spring.mail.properties.mail.debug=false
5 软件架构
| 类目 | 版本 | 备注 |
|---|---|---|
| JDK 17 | 17.0.7 LTS | 软件运行的最低JDK版本 |
| spring-boot | 3.1.1 | |
| spring-cloud | 2022.0.0-M1 | |
| smart-doc | 2.7.2 | 一个自动化的API文档输出工具,效率word、rap2、swagger高 |
| sonar | 3.9.0.2155 | 一款开源的代码质量分析工具,能编码是规避很多潜在bug |
| spring-boot-starter-validation | 3.1.1 | spring新一代的参数校验器,替代javax JSR303的工具 |
| spring-boot-starter-websocket | 3.1.1 | spring官方维护的websocket starter |
单体架构,可直接开箱即用,支持集群部署,也可与分布式微服务集成,可拔插注入配置中心,通过远程RPC调用接口加签。
6 开发文档
本项目支持直接使用
JSON数据加签上报,告别XML数据、179特殊数据组装那样三拜九叩的繁琐!
启动项目,浏览器访问: http://127.0.0.1:8080 ,会打开接口文档的H5页面,可直接在页面给ukey发送请求进行调试,注意请求参数的字符串转义。
部分响应数据示例
- XML加签响应示例
{
"message": "操作成功",
"success": true,
"timestamp": "2023-07-15 12:15:47",
"code": 200,
"data": {
"success": true,
"certNo": "03000000000cde6f",
"x509Certificate": "MIIEoDCCBESgAwIBAgIIAwAAAAAM3m8wDAYIKoEcz1UBg3UFADCBmDELMAkGA1UEBhMCQ04xDzANBgNVBAgMBuWMl+S6rDEPMA0GA1UEBwwG5YyX5LqsMRswGQYDVQQKDBLkuK3lm73nlLXlrZDlj6PlsrgxGzAZBgNVBAsMEuivgeS5pueuoeeQhuS4reW/gzEtMCsGA1UEAwwk5Lit5Zu955S15a2Q5Lia5Yqh6K+B5Lmm566h55CG5Lit5b+DMB4XDTIzMDMyOTAwMDAwMFoXDTMzMDMyOTAwMDAwMFowVjELMAkGA1UEBhMCQ04xMzAxBgNVBAsMKua1t+WNl+ecgeiNo+iqiei/m+WHuuWPo+i0uOaYk+aciemZkOWFrOWPuDESMBAGA1UEAwwJ5p2o5aaC6YeRMFkwEwYHKoZIzj0CAQYIKoEcz1UBgi0DQgAE0vOQmplAr9igPZrA8F1msqnFd0U++6G6NhG5rNuIUWft0BwQn7eSJkt5/fvSSoe7pUg2/awHUWPnzkeeQc7oVqOCArUwggKxMBEGCWCGSAGG+EIBAQQEAwIFoDAOBgNVHQ8BAf8EBAMCBsAwCQYDVR0TBAIwADApBgNVHSUEIjAgBggrBgEFBQcDAgYIKwYBBQUHAwQGCisGAQQBgjcUAgIwHwYDVR0jBBgwFoAURCQxt0wEvoAVXmuo4N1bjKXTh0UwHQYDVR0OBBYEFAytGob5L0WqhOCZ5l6Lf2jUdNrAMGgGA1UdIARhMF8wXQYEVR0gADBVMFMGCCsGAQUFBwIBFkdodHRwczovL3d3dy5jaGluYXBvcnQuZ292LmNuL3RjbXNmaWxlL3UvY21zL3d3dy8yMDIyMDQvMTIxMzI5NDh4dDZwLnBkZjB/BgNVHR8EeDB2MHSgcqBwhm5sZGFwOi8vbGRhcC5jaGluYXBvcnQuZ292LmNuOjM4OS9jbj1jcmwwMzAwMDAsb3U9Y3JsMDAsb3U9Y3JsLGM9Y24/Y2VydGlmaWNhdGVSZXZvY2F0aW9uTGlzdD9iYXNlP2NuPWNybDAzMDAwMDA+BggrBgEFBQcBAQQyMDAwLgYIKwYBBQUHMAGGImh0dHA6Ly9vY3NwLmNoaW5hcG9ydC5nb3YuY246ODgwMC8wOgYKKwYBBAGpQ2QFAQQsDCrmtbfljZfnnIHojaPoqonov5vlh7rlj6PotLjmmJPmnInpmZDlhazlj7gwEgYKKwYBBAGpQ2QFAwQEDAIwMTAiBgorBgEEAalDZAUIBBQMEjUxMjMyNDE5NjQxMDE3Mjk3WDAgBgorBgEEAalDZAUJBBIMEDAzLUpKMEc5MDAyMjA3NTIwGQYKKwYBBAGpQ2QFCwQLDAlNQTVUTkZHWTkwEgYKKwYBBAGpQ2QFDAQEDAIwMDASBgorBgEEAalDZAIBBAQMAjEyMBIGCisGAQQBqUNkAgQEBAwCMTQwDAYIKoEcz1UBg3UFAANIADBFAiBM4OVAc8aaCZU4XFfcVMkC7bWIIenRnPLxrnwVeYO3CQIhANQ767YIurkJCoLtwyqQPbUZe/+3BjGZcIWqB1mAl9T+",
"digestValue": "b2FtM/jHvW4fnJpMMPWk/177RwA=",
"signatureValue": "Pa2Ge3A1iH9e+85jIraVccvf2MB4ykjgC1MjObNd/MbPOSZRWTaizlnfReH3ErRMH5Wc3m60ZM6h56v7t7lIWg==",
"signatureNode": "<ds:SignedInfo xmlns:ceb=\"http://www.chinaport.gov.cn/ceb\" xmlns:ds=\"http://www.w3.org/2000/09/xmldsig#\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"><ds:CanonicalizationMethod Algorithm=\"http://www.w3.org/TR/2001/REC-xml-c14n-20010315\"></ds:CanonicalizationMethod><ds:SignatureMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sm2-sm3\"></ds:SignatureMethod><ds:Reference URI=\"\"><ds:Transforms><ds:Transform Algorithm=\"http://www.w3.org/2000/09/xmldsig#enveloped-signature\"></ds:Transform></ds:Transforms><ds:DigestMethod Algorithm=\"http://www.w3.org/2000/09/xmldsig#sha1\"></ds:DigestMethod><ds:DigestValue>b2FtM/jHvW4fnJpMMPWk/177RwA=</ds:DigestValue></ds:Reference></ds:SignedInfo>"
}
}
- 海关179加签返回示例
提示:179加签只需要两个字即可
{
"message": "操作成功",
"success": true,
"timestamp": "2023-07-15 12:16:36",
"code": 200,
"data": {
"success": true,
"certNo": "03000000000cde6f",
"signatureValue": "pVWbjCXqCy2zk0RRqbw16hWZozjTSP444fdT2k5MjqigJDsLZ/Vfgout3o/Gg0WrPbJnH/2wlI8I0n3niqYiqw=="
}
}
感谢您使用本开源项目!为了持续改进并为更多企业提供免费的加签解决方案,我们诚恳地邀请您考虑赞助支持我们的项目。您的慷慨赞助将直接帮助我们维护和改进该项目,使其能够为更多企业节省成本、提高效率。
7 支持赞助
7.1 为什么赞助
- 降低企业成本:我们的项目为企业提供了一站式解决方案,摆脱了每年支付高额费用购买加签设备的负担。您的赞助可以帮助更多企业降低经营成本,提高竞争力。
- 促进技术共享:通过开源,我们希望能够促进技术共享和合作。您的赞助将鼓励我们继续开发和分享更多优质的解决方案,使得整个行业都能从中受益。
- 支持项目发展:我们致力于不断改进和完善该项目,包括修复漏洞、添加新功能和提供更好的文档支持。您的赞助将直接用于项目的开发、测试和维护,确保项目的持续稳定和可靠性。
7.2 如何赞助
我们非常感激您对我们项目的赞助支持!您可以通过以下方式进行赞助:
您可以根据自身能力自由选择捐赠金额,无论您选择捐赠的金额大小,我们都非常感激,您的每一份赞助都对本项目发展都起到了重要的作用。
-
捐赠:您可以通过以下链接进行捐赠:
-
AliPay
WeChatPay
-
技术贡献:如果您是开发者,您也可以通过提交代码、报告问题或者提供改进建议等方式来支持我们的项目。
-
宣传推广:如果您无法提供直接的赞助,您还可以通过在社交媒体上宣传、分享我们的项目,帮助我们扩大影响力。
7.3 感谢您的支持
我们衷心感谢您对我们项目的关注和支持!您的赞助将鼓励我们继续改进和提供更好的解决方案,造福更多的企业和开发者。如果您有任何问题或者疑问,请随时联系我们, 联系邮箱: 1432689025@qq.com
8 接入企业登记
感谢您对我们项目的赞助支持!为了更好地记录和感谢每一家接入企业,我们在此邀请您在捐赠时留下您的公司名,以便我们将您的公司列入接入企业名单中。您可以在捐赠备注中提供您的公司名,或者在捐赠后通过邮件等方式将公司名发送给我们。
您的公司名将在我们的 README 中特别标注,并列入接入企业名单,以展示对您的感激之情。同时,我们也欢迎您提供您公司的官方网站链接,以便其他用户了解更多关于您公司的信息。
感谢您的配合和支持,我们将竭诚为您提供更好的服务!
9 接入企业
排名不分先后,从2023-07-11开始登记
感谢以下公司对我们项目的赞助和支持:
- 海南省荣誉进出口贸易有限公司:官方网站
- ...
如果您的公司已赞助我们的项目,但在列表中没有找到,请及时与我们联系,我们将尽快添加您的公司名。









