给我一个Go和php 通讯的 RSA加密源码

时间: 2024-05-03 22:16:52 浏览: 62
以下是一个简单的 Go 和 PHP 通讯的 RSA 加密源码示例: Go 代码: ```go package main import ( "crypto/rand" "crypto/rsa" "crypto/x509" "encoding/pem" "fmt" "io/ioutil" "net/http" ) func main() { // 从文件中读取公钥 pubPEM, err := ioutil.ReadFile("public.pem") if err != nil { panic(err) } pubBlock, _ := pem.Decode(pubPEM) pubKey, err := x509.ParsePKCS1PublicKey(pubBlock.Bytes) if err != nil { panic(err) } // 生成随机数据 data := make([]byte, 32) _, err = rand.Read(data) if err != nil { panic(err) } // 使用公钥加密数据 encryptedData, err := rsa.EncryptPKCS1v15(rand.Reader, pubKey, data) if err != nil { panic(err) } // 发送加密后的数据到 PHP 服务器 resp, err := http.Post("http://localhost:8000/decrypt.php", "application/octet-stream", bytes.NewReader(encryptedData)) if err != nil { panic(err) } // 读取 PHP 服务器返回的解密后的数据 decryptedData, err := ioutil.ReadAll(resp.Body) if err != nil { panic(err) } fmt.Printf("加密前的数据:%x\n", data) fmt.Printf("加密后的数据:%x\n", encryptedData) fmt.Printf("解密后的数据:%x\n", decryptedData) } ``` PHP 代码: ```php <?php // 从文件中读取私钥 $privateKey = '-----BEGIN RSA PRIVATE KEY----- MIICXQIBAAKBgQCzB5hJw7Z8G3q3V7PzJkC5t7y8tQ9uEgPfN/47MOTeN8vNQ2fN AfnbY1W/8Czv3kUdOC6nIcGZf4m4v4aDzNu6U2QlUkGl6UvS6pO6g0o+IAwA0Zf4 1FVz1M+Y2S8zPvU6S+oCk/ggA+Tt8ImvLZ2ePt0sIYgO3OyGv3q3L/PHQQIDAQAB AoGADeKxH3aVJ+YJYd7R8NcH9QdLgOGhQ2CwVJj+mkalgeGg5cs5z5Y5K30n5AiF BgK7VY+1t8h7V9gPmtE3GqCp+D8eOZfJgZrH1a5fjK5Ob5G5p5J+J7+tK0Jt8F2Q Q1t6FWL+6JYU6yQlXKvU4d4HufStJf8ZwfcInAUvU3z3qkECQQDyJcK99sF+JNQ2 H1e8jwW+eyvI3oq3pOYdI8s1sXsXQJQ2RraL1j8Ww0oKvS6U7J6UzC6y2KjF1d4f 4B0L0oZJAkEAxKfmyr1Y5Dn0nW5p5GmzA7l0Kt5hZ2QgJ1xKjV7MzjB8bsV7yCtP Ej3pCtGZfVwZuA5r5FhE0zCt5HR5VLB9pQJBAKLOJj0Q0zxZ1x2L2LLcQOHPdYV7 8Pv9u3qfEi5hL1LZ8a0L+3qg3zEYrsHcJ8zv9XQg/2bFmTqwZj8vZiDmOCMCQG4n QzC6Fv9X4zfk4nL4GZc8lZv4pS+6OYU0k0AG6yv1X9f1+4JF4aMw0ZvUJZqk3C3f zjW8sHbXlQ64T/B+OZECQDr8OvPuxH7VjKf1YR7V/8v+u9q3h3gDpNwN8eblZ+gG eLGCz5J5W5+5k5p7mzdGJzKowmQ8F/b1CmYU6Lk/6S4= -----END RSA PRIVATE KEY----- '; $privateKey = openssl_pkey_get_private($privateKey); // 从请求中读取加密后的数据 $data = file_get_contents("php://input"); // 使用私钥解密数据 openssl_private_decrypt($data, $decryptedData, $privateKey); // 发送解密后的数据回到 Go 程序 header('Content-Type: application/octet-stream'); echo $decryptedData; ``` 注意事项: - 请确保你的公钥和私钥是一对。 - 请确保你的 PHP 程序在收到加密后的数据后能够正确地使用私钥解密数据。

相关推荐

最新推荐

recommend-type

Java实现的RSA加密解密算法示例

JCA提供了一个完整的加密解决方案,包括密钥对生成、加密和解密等功能。 知识点3:密钥对生成 在RSA加密解密算法中,密钥对的生成是非常重要的一步。Java中可以使用KeyPairGenerator类来生成密钥对。密钥对生成器...
recommend-type

C#实现简单的RSA非对称加密算法示例

RSACryptoServiceProvider类提供了RSA加密和解密的方法。 首先,需要生成公钥和私钥。可以使用RSACryptoServiceProvider类的ImportParameters方法将公钥和私钥导入到RSA算法中。 接下来,需要将明文转换为byte数组...
recommend-type

php接口数据加密、解密、验证签名

需要注意的是,AES用于数据加密,速度快但密钥管理复杂,而RSA用于公钥加密和签名,安全性高但计算量大。在实际应用中,通常结合两者使用:AES用于加密大量数据,RSA用于加密AES的密钥,确保密钥的安全传输。 此外...
recommend-type

C# RSA分段加解密实现方法详解

在循环中,先创建一个缓冲区,根据当前剩余数据量决定缓冲区大小,然后使用`Read`方法从原始数据流中读取数据,再用`Encrypt`方法进行加密,最后将加密后的数据写入结果流。如此反复,直到所有数据都被加密。 解密...
recommend-type

基于硬盘序列号和RSA加密算法的软件加密方法

下面我们就针对这个问题提出了一种简便易行的对正版软件进行加密的方法,保护软件开发者的合法利益。 13份WPF经典开发教程 http://download.csdn.net/album/detail/1115 C#资料合辑二[C#桌面编程入门篇] ...
recommend-type

Node.js实战:快速入门,全面解析

"Node.js即学即用是一本面向JavaScript和编程有一定基础的读者的入门书籍,旨在教授如何利用Node.js构建可扩展的互联网应用程序。本书详尽介绍了Node.js提供的API,同时深入探讨了服务器端事件驱动开发的关键概念,如并发连接处理、非阻塞I/O以及事件驱动编程。内容覆盖了对多种数据库和数据存储工具的支持,提供了Node.js API的实际使用示例。" 在Node.js的世界里,事件驱动模型是其核心特性之一。这种模型使得Node.js能够高效地处理大量并发连接,通过非阻塞I/O操作来提高性能。在本书中,读者将学习如何利用Node.js的异步编程能力来创建高性能的网络应用,这是Node.js在处理高并发场景时的一大优势。 Node.js的API涵盖了网络通信、文件系统操作、流处理等多个方面。例如,`http`模块用于创建HTTP服务器,`fs`模块提供了对文件系统的读写功能,而`stream`模块则支持数据的高效传输。书中会通过实例来展示如何使用这些API,帮助读者快速上手。 对于数据库和数据存储,Node.js有丰富的库支持,如MongoDB的`mongodb`模块、MySQL的`mysql`模块等。书中会讲解如何在Node.js应用中集成这些数据库,进行数据的增删改查操作,以及如何优化数据访问性能。 此外,本书还会介绍Node.js中的模块系统,包括内置模块和第三方模块的安装与使用,如使用`npm`(Node Package Manager)管理依赖。这使得开发者可以轻松地复用社区中的各种工具和库,加速开发进程。 《Node.js即学即用》是一本全面的实战指南,不仅适合初学者快速掌握Node.js的基础知识,也适合有一定经验的开发者深入理解Node.js的高级特性和最佳实践。通过阅读本书,读者不仅可以学习到Node.js的技术细节,还能了解到如何构建实际的、可扩展的网络应用。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

nginx配置中access_log指令的深入分析:日志记录和分析网站流量,提升网站运营效率

![nginx配置中access_log指令的深入分析:日志记录和分析网站流量,提升网站运营效率](https://img-blog.csdnimg.cn/img_convert/36fecb92e4eec12c90a33e453a31ac1c.png) # 1. nginx access_log指令概述** nginx 的 `access_log` 指令用于记录服务器处理客户端请求的信息。它可以生成日志文件,其中包含有关请求的详细信息,例如请求方法、请求 URI、响应状态代码和请求时间。这些日志对于分析网站流量、故障排除和性能优化至关重要。 `access_log` 指令的基本语法如下:
recommend-type

opencvsharp连接工业相机

OpenCVSharp是一个.NET版本的OpenCV库,它提供了一种方便的方式来在C#和Mono项目中使用OpenCV的功能。如果你想要连接工业相机并使用OpenCVSharp处理图像数据,可以按照以下步骤操作: 1. 安装OpenCVSharp:首先,你需要从GitHub或NuGet包管理器下载OpenCVSharp库,并将其添加到你的项目引用中。 2. 配置硬件支持:确保你的工业相机已安装了适当的驱动程序,并且与计算机有物理连接或通过网络相连。对于一些常见的工业相机接口,如USB、GigE Vision或V4L2,OpenCV通常能够识别它们。 3. 初始化设备:使用OpenCVS
recommend-type

张智教授详解Java入门资源:J2SE与J2ME/J2EE应用

本PPT教程由主讲教师张智精心制作,专为Java初学者设计,旨在快速提升学习者的Java编程入门能力,以应对各类考试需求。教程内容涵盖了Java的基础知识和实用技巧,从语言的历史背景和发展到核心特性。 1. **Java简介**: - Java起源于1990年由James Gosling领导的小组,原名Oak,目标是为家用电器编程,后来在1995年更名为Java。Java是一种平台无关、面向对象的语言,其特点包括:平台无关性,通过JVM实现跨平台;面向对象,强调代码重用;简单健壮,降低出错风险;解释性,源代码编译成字节码执行;分布式,支持网络通信;安全,防止非法操作;多线程,支持并发处理;动态性和可升级性;以及高性能。 2. **Java平台版本**: - Java有三个主要版本: - 微型版(J2ME):针对移动设备和嵌入式设备,如手机或IoT设备。 - 标准版(J2SE,Java SE):适用于桌面和服务器开发,涵盖了日常应用开发。 - 企业版(J2EE,Java EE):为企业级应用和Web应用设计,如企业级服务器和Web服务。 3. **Java环境配置**: - 要开始Java编程,首先需要下载Java JDK,如Java 8。然后配置Java环境变量,例如设置JAVA_HOME指向JDK安装路径,CLASSPATH用于指定类库搜索路径,以及添加JDK bin和jre bin到PATH中,以便执行Java命令。 4. **常用IDE工具**: - Eclipse是一款推荐使用的Java IDE,它提供了集成开发环境,便于代码编写、调试和测试。下载Eclipse后,通常直接解压安装即可。 整个教程围绕Java的核心概念展开,从基础语法讲解到实践项目,适合初学者系统地学习和巩固Java知识,无论是为了学术研究还是职业发展,都能提供有效的学习资源。通过本资源,初学者能够快速掌握Java编程,并为进一步深入学习和实战项目打下坚实基础。