我的编程空间,编程开发者的网络收藏夹
学习永远不晚

使用Java验证Golang中创建的签名

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

使用Java验证Golang中创建的签名

编程网今天将给大家带来《使用Java验证Golang中创建的签名》,感兴趣的朋友请继续看下去吧!以下内容将会涉及到等等知识点,如果你是正在学习Golang或者已经是大佬级别了,都非常欢迎也希望大家都能给我建议评论哈~希望能帮助到大家!

问题内容

我正在 go 中创建签名,例如:

//i'm reading a file with -----begin rsa private key-----
privatekeypem := strings.replace(privatekeystring, `\n`, "\n", -1) //file has '/n' instead of break lines for dev purposes
block, _ := pem.decode([]byte(privatekeypem))
key, _ := x509.parsepkcs1privatekey(block.bytes)
hashedstring := sha256.sum256([]byte(stringtosign))
signature, err = rsa.signpkcs1v15(rand.reader, key, crypto2.sha256, hashedstring[:])
signaturestring := base64.stdencoding.encodetostring(signature)

java程序接收变量signaturestring并执行以下操作:

byte[] keyBytes = Files.readAllBytes(Paths.get("./golangSignerPubKey.der"));
X509EncodedKeySpec spec = new X509EncodedKeySpec(keyBytes);
KeyFactory kf = KeyFactory.getInstance("RSA");
PublicKey publicKey =  kf.generatePublic(spec);
Signature signature = Signature.getInstance("SHA256withRSA", "BC");
signature.initVerify(publicKey);
signature.update(stringUnsigned.getBytes());
boolean signatureIsValid = signature.verify(Base64.getDecoder().decode(signatureString.getBytes()));

但是signatureisvalid布尔值总是假的,我做错了什么吗?


解决方案


我能够验证签名。我在这里发帖以防有人遇到同样的问题:

在 go 中创建签名:

bytestosign := []byte (stringtosign)
block, err8 := pem.decode([]byte(privatekeypem)) //-----begin rsa private key----
if err8 != nil {
    logger.debugf("error trying decode endorser private key")
}
key, _ := x509.parsepkcs1privatekey(block.bytes)
h := sha256.new()
h.write(bytestosign)
d := h.sum(nil)
signature, err = rsa.signpkcs1v15(rand.reader, key, crypto.sha256, d)
if err != nil {
    panic(err)
}
signaturestring = base64.stdencoding.encodetostring(signature)

java中的签名验证(接收signaturestring): 我的公钥位于 .pub 文件中并且:

byte[] keyBytes = Files.readAllBytes(Paths.get("./public_key.pub"));
String temp = new String(keyBytes);
String publicKeyPEM = temp.replace("-----BEGIN PUBLIC KEY-----\n", "");
publicKeyPEM = publicKeyPEM.replace("\n-----END PUBLIC KEY-----", "");
BASE64Decoder b64= new BASE64Decoder();
byte[] decoded = b64.decodeBuffer(publicKeyPEM);
X509EncodedKeySpec spec = new X509EncodedKeySpec(decoded);
KeyFactory kf = KeyFactory.getInstance("RSA");
publicKey = kf.generatePublic(spec);
Signature signature = Signature.getInstance("SHA256withRSA", "BC");
signature.initVerify(publicKey);
signature.update(bytesToVerify); //bytesToVerify = bytesToSign in go
byte[] signatureDecoded = Base64.getDecoder().decode(signatureString);
boolean endorserSignatureIsValid = signature.verify(signatureDecoded);
//It is now valid

我无法使用 base64.getdecoder() (java.lang.illegalargumentexception:非法的 base64 字符 a)来解码 publickeypem,因此我使用了 base64decoder。不知道为什么。

我昨天也遇到了这个问题,最后解决了。

这可能对其他人有帮助:https://github.com/xioxu/signature_in_multiple_lang

文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《使用Java验证Golang中创建的签名》文章吧,也可关注编程网公众号了解相关技术文章。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

使用Java验证Golang中创建的签名

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

使用Java验证Golang中创建的签名

编程网今天将给大家带来《使用Java验证Golang中创建的签名》,感兴趣的朋友请继续看下去吧!以下内容将会涉及到等等知识点,如果你是正在学习Golang或者已经是大佬级别了,都非常欢迎也希望大家都能给我建议评论哈~希望能帮助到大家!问题内
使用Java验证Golang中创建的签名
2024-04-04

详解如何使用openssl创建自签名证书

这篇文章主要为大家介绍了详解如何使用openssl创建自签名证书示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-05-17

无法使用 JS 验证 Go 生成的 ECDSA 签名

php小编小新在使用Go语言生成ECDSA签名时遇到了一个问题,即无法使用JS进行验证。这个问题的解决方法是在Go代码中添加一些附加的字段,以确保签名的正确性。通过对Go代码进行一些修改,我们可以解决这个问题,并使得JS能够正确验证Go生成
无法使用 JS 验证 Go 生成的 ECDSA 签名
2024-02-10

Go 的 btcec 库中使用哪种方法来验证 secp256k1 签名?

php小编小新在 btcec 库中使用了 ECDSA 算法来验证 secp256k1 签名。ECDSA(Elliptic Curve Digital Signature Algorithm)是一种基于椭圆曲线密码学的数字签名算法,通过对签名
Go 的 btcec 库中使用哪种方法来验证 secp256k1 签名?
2024-02-08

如何构建 Golang RESTful API,并使用中间件进行身份验证?

本文介绍了如何构建 golang restful api。首先,通过导入必要的库、定义数据模型和创建路由来构建 restful api。其次,使用 go-chi/chigot 和 go-chi/chi/middleware 创建和应用中间件
如何构建 Golang RESTful API,并使用中间件进行身份验证?
2024-05-14

如何在使用golang创建的wasm中实现多线程?

积累知识,胜过积蓄金银!毕竟在Golang开发的过程中,会遇到各种各样的问题,往往都是一些细节知识点还没有掌握好而导致的,因此基础知识点的积累是很重要的。下面本文《如何在使用golang创建的wasm中实现多线程?》,就带大家讲解一下知识点
如何在使用golang创建的wasm中实现多线程?
2024-04-05

如何使用golang中的os.Mkdir函数创建新文件夹

如何使用golang中的os.Mkdir函数创建新文件夹概述:在golang中,我们可以使用os.Mkdir函数来创建新的文件夹。该函数接受一个路径作为参数,并将在指定路径下创建一个新的文件夹。本文将详细介绍如何使用该函数,并提供相应的代码
如何使用golang中的os.Mkdir函数创建新文件夹
2023-11-18

如何使用golang中的os.Link函数创建文件的硬链接

如何使用golang中的os.Link函数创建文件的硬链接在操作系统中,硬链接是指一个文件被多个文件名所指向。当一个文件有多个文件名时,它们都指向同一个i节点(inode),即它们共享相同的数据块。在Golang中,我们可以使用os.Lin
如何使用golang中的os.Link函数创建文件的硬链接
2023-11-18

尝试使用 golang 客户端为 google 工作区目录创建架构后,请求的身份验证范围不足

php小编苹果介绍,当我们尝试使用golang客户端为Google工作区目录创建架构后,可能会遇到一个问题:请求的身份验证范围不足。这是由于在进行API调用时,我们的身份验证范围不够,导致无法完成请求。为了解决这个问题,我们需要检查我们的身
尝试使用 golang 客户端为 google 工作区目录创建架构后,请求的身份验证范围不足
2024-02-10

在 Python 中使用变量创建文件名的方法

这篇文章主要介绍了在 Python 中使用变量创建文件名,格式化的字符串文字使我们能够通过在字符串前面加上f来在字符串中包含表达式和变量,本文给大家详细讲解,需要的朋友可以参考下
2023-05-14

MySQL concat() 创建要在查询中使用的列名?

要创建要在查询中使用的列名称,您需要通过 set 命令使用用户定义的变量。语法如下 -SET @anyVariableName :=(SELECT CONCAT("SELECT",GROUP_CONCAT(CONCAT(" 1 as ",
2023-10-22

如何使用golang中的io/ioutil.TempFile函数创建临时文件

如何使用golang中的io/ioutil.TempFile函数创建临时文件在许多编程语言中,我们经常需要创建临时文件来存储临时数据或进行一些临时操作。在Golang中,我们可以使用io/ioutil包中的TempFile函数来创建临时文件
如何使用golang中的io/ioutil.TempFile函数创建临时文件
2023-11-18

Java中的异步与线程池怎么创建使用

这篇文章主要介绍“Java中的异步与线程池怎么创建使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java中的异步与线程池怎么创建使用”文章能帮助大家解决问题。初始化线程的4种方式1.继承Thre
2023-07-04

如何使用golang中的http.NewRequest函数创建自定义的HTTP请求

如何使用golang中的http.NewRequest函数创建自定义的HTTP请求在golang中,我们可以使用http.NewRequest函数创建自定义的HTTP请求。这个函数可以让我们更灵活地控制请求的各个方面,包括请求的方法、URL
如何使用golang中的http.NewRequest函数创建自定义的HTTP请求
2023-11-18

如何使用golang中的os.Create函数创建新文件并写入内容

如何使用golang中的os.Create函数创建新文件并写入内容在golang中,使用os.Create函数可以创建新文件,并且可以通过相关函数将内容写入文件中。下面将详细介绍如何使用os.Create函数,并给出相应的代码示例。首先,我
如何使用golang中的os.Create函数创建新文件并写入内容
2023-11-18

如何使用golang中的net/http/httptest.NewUnstartedServer函数创建未启动的HTTP服务器

如何使用golang中的net/http/httptest.NewUnstartedServer函数创建未启动的HTTP服务器概述:在Golang中,我们可以使用net/http包来构建和处理HTTP服务器。而在进行单元测试时,有时需要创建
如何使用golang中的net/http/httptest.NewUnstartedServer函数创建未启动的HTTP服务器
2023-11-18

oracle 创建用户指定表空间报错ORA-28010: 无法使外部用户, 全局用户或没有验证方法的用户失效

我在plsql里复制了system这个用户的sql我连接了服务器上的oracle之后想执行sql创建一个用户并指定它的表空间结果在navicat里报了这个错误,我以为是system用户的问题,然后我就用sys用户登录结果,还是报这个错误我就连接远程服务器用sq
oracle 创建用户指定表空间报错ORA-28010: 无法使外部用户, 全局用户或没有验证方法的用户失效
2016-01-15

如何使用golang中的io/ioutil.TempDir函数创建带有指定前缀和后缀的临时文件夹

如何使用golang中的io/ioutil.TempDir函数创建带有指定前缀和后缀的临时文件夹,需要具体代码示例在Go语言的开发中,有时候我们需要创建用于临时存储文件的文件夹,这些文件夹往往是临时的,使用完毕后需要删除。Go语言的标准库中
如何使用golang中的io/ioutil.TempDir函数创建带有指定前缀和后缀的临时文件夹
2023-11-18

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录