依星源码资源网,依星资源网

 找回密码
 立即注册

QQ登录

只需一步,快速开始

【好消息,好消息,好消息】VIP会员可以发表文章赚积分啦 !
查看: 168|回复: 0

OpenAI Dall-E-客户端(VB.NET源码)

[复制链接] 主动推送

1万

主题

1万

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
12061
发表于 2024-11-21 11:58:37 | 显示全部楼层 |阅读模式
OpenAI Dall-E-客户端(VB.NET源码)
有关如何在 VB.NET 中询问 Dall-E 的概述

本文展示了如何 VB.NET OpenAI 成像模型 Dall-E-2 生成 Web 请求,作为基于 Web 以及 NodeJS 和 Python 解决方案的替代方案。
该代码以 JSON 格式向 OpenAI 图像生成终端节点发送请求,编写一个标准请求,以使用 Dall-E-2 模型和标准质量大小 512x512 生成 1 个图像;对 JSON 格式的响应进行反序列化,并提取图像 URL 并显示在 Picturebox 中
使用代码
该代码由一个长过程组成,用于管理发送请求和获取响应;启用两个小过程来管理 Prompt TextBox 并将图像保存到本地磁盘。
该代码使用以下导入:
  1. Imports System.Net
  2. Imports System.IO
  3. Imports System.Configuration
  4. Imports System.Security.Cryptography
  5. Imports System.Net.SecurityProtocolType
  6. Imports System.Threading.Tasks
  7. Imports System.ComponentModel
复制代码
专用表单包含:
  • 提示的文本框
  • OpenAI API 密钥的文本框
  • 用于显示图像 URL 的 pictureBox
  • 用于发送请求的按钮
  • 用于保存图像的按钮
  • 显示活动日志的 Textbox(一种控制台)
该事件触发了所有的魔法!btnSend_Click
第一个操作是设置请求并将其 JSONify 化:
  1. logTxt.Text = "Sending request..." & vbCrLf

  2. System.Net.ServicePointManager.SecurityProtocol = DirectCast(3072, System.Net.SecurityProtocolType)

  3. Dim apiEndpoint As String = "https://api.openai.com/v1/images/generations"
  4. Dim apiKey As String = ApiKeyTextBox.Text
  5. Dim prompt As String = PromptTextBox.Text
  6. Dim model As String = "dall-e-2"
  7. Dim numberofimages As String = "1"
  8. Dim imagesize As String = "512x512"

  9. ' Creation of HTTP request
  10. Dim request As HttpWebRequest = WebRequest.Create(apiEndpoint)
  11. request.Method = "POST"
  12. request.ContentType = "application/json"
  13. request.Headers.Add("Authorization", "Bearer " & apiKey)

  14. ' Creation of JSON request
  15. Dim data As String = "{"
  16. data += " ""model"": """ & model & ""","
  17. data += " ""prompt"": """ & prompt & ""","
  18. data += " ""n"": 1,"
  19. data += " ""size"": """ & imagesize & """"
  20. data += "}"
  21. logTxt.Text += "Request grammar: " & data.ToString & vbCrLf
  22. ' Write body of request
  23. Using streamWriter As New StreamWriter(request.GetRequestStream())
  24.     streamWriter.Write(data)

  25. End Using
复制代码
第二步是收集响应并反序列化它。
  1. Dim response As HttpWebResponse = Nothing

  2. Try
  3.     response = CType(request.GetResponse(), HttpWebResponse)

  4.     'Getting JSON format
  5.     Dim responseStream As Stream = response.GetResponseStream()
  6.     Dim reader As New StreamReader(responseStream)
  7.     Dim jsonResponse As String = reader.ReadToEnd()
  8.     logTxt.Text += "Receiving response..." & vbCrLf

  9.     reader.Close()
  10.     responseStream.Close()

  11.     'Deserializing JSON response
  12.     Dim oJavaScriptSerializer As New System.Web.Script.Serialization.JavaScriptSerializer
  13.     Dim oJson As Hashtable = oJavaScriptSerializer.Deserialize(Of Hashtable)(jsonResponse)
  14.     logTxt.Text += "Response received: " & jsonResponse.ToString & vbCrLf
复制代码
完成后,我们可以拦截图像 url 并将其显示在 :PictureBox
  1. 'Extracting the image URL
  2. Dim imageUrl As String = oJson("data")(0)("url").ToString()

  3. ' Visualizing the image
  4. Dim imageClient As New WebClient()
  5. Dim imageData As Byte() = imageClient.DownloadData(imageUrl)

  6. Using ms As New MemoryStream(imageData)
  7.     PictureBox1.Image = Image.FromStream(ms)
  8. End Using
  9. saveBtn.Visible = True
复制代码
需要完成一些简单的错误处理:
  1. Catch ex As WebException
  2.     'simple error handling
  3.     MessageBox.Show("Web error: " & ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error)

  4. Finally
  5.     If response IsNot Nothing Then
  6.         response.Close()
  7.     End If
  8. End Try
复制代码
为了完整起见,下面报告了将图像保存到本地光盘的例程:
  1. If PictureBox1.Image IsNot Nothing Then
  2.     Dim saveDialog As New SaveFileDialog()
  3.     saveDialog.Filter = "JPG Image|*.jpg"
  4.     saveDialog.Title = "Save Image"

  5.     If saveDialog.ShowDialog() = DialogResult.OK Then
  6.         PictureBox1.Image.Save(saveDialog.FileName, Imaging.ImageFormat.Jpeg)
  7.         MessageBox.Show("Imge saved correctly!", "Save Image", MessageBoxButtons.OK, MessageBoxIcon.Information)
  8.     End If
  9. Else
  10.     MessageBox.Show("Image could not be saved.", "Error", MessageBoxButtons.OK, MessageBoxIcon.Error)
  11. End If
复制代码

兴趣点
对代码的主要兴趣是通过 VB.NET 询问 OpenAI API,而不必依赖 Python 或 NodeJS,这是此类操作中使用的两种主要技术,也是 OpenAI 在其文档中支持的唯一两种技术。
VB.NET 仍然允许桌面开发人员与现代技术进行交互,尤其是在不依赖第三方库的情况下。
提取码下载:
文件名称:提取码下载.txt 
下载次数:0  文件大小:16 Bytes  售价:30金钱 [记录]
下载权限: 不限 [购买VIP]   [充值]   [在线充值]   【VIP会员6折;永久VIP4折】
安全检测,请放心下载




相关帖子

扫码关注微信公众号,及时获取最新资源信息!下载附件优惠VIP会员6折;永久VIP4折
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

免责声明:
1、本站提供的所有资源仅供参考学习使用,版权归原著所有,禁止下载本站资源参与商业和非法行为,请在24小时之内自行删除!
2、本站所有内容均由互联网收集整理、网友上传,并且以计算机技术研究交流为目的,仅供大家参考、学习,请勿任何商业目的与商业用途。
3、若您需要商业运营或用于其他商业活动,请您购买正版授权并合法使用。
4、论坛的所有内容都不保证其准确性,完整性,有效性,由于源码具有复制性,一经售出,概不退换。阅读本站内容因误导等因素而造成的损失本站不承担连带责任。
5、用户使用本网站必须遵守适用的法律法规,对于用户违法使用本站非法运营而引起的一切责任,由用户自行承担
6、本站所有资源来自互联网转载,版权归原著所有,用户访问和使用本站的条件是必须接受本站“免责声明”,如果不遵守,请勿访问或使用本网站
7、本站使用者因为违反本声明的规定而触犯中华人民共和国法律的,一切后果自己负责,本站不承担任何责任。
8、凡以任何方式登陆本网站或直接、间接使用本网站资料者,视为自愿接受本网站声明的约束。
9、本站以《2013 中华人民共和国计算机软件保护条例》第二章 “软件著作权” 第十七条为原则:为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬。若有学员需要商用本站资源,请务必联系版权方购买正版授权!
10、本网站如无意中侵犯了某个企业或个人的知识产权,请来信【站长信箱312337667@qq.com】告之,本站将立即删除。
郑重声明:
本站所有资源仅供用户本地电脑学习源代码的内含设计思想和原理,禁止任何其他用途!
本站所有资源、教程来自互联网转载,仅供学习交流,不得商业运营资源,不确保资源完整性,图片和资源仅供参考,不提供任何技术服务。
本站资源仅供本地编辑研究学习参考,禁止未经资源商正版授权参与任何商业行为,违法行为!如需商业请购买各资源商正版授权
本站仅收集资源,提供用户自学研究使用,本站不存在私自接受协助用户架设游戏或资源,非法运营资源行为。
 
在线客服
点击这里给我发消息 点击这里给我发消息 点击这里给我发消息
售前咨询热线
312337667

微信扫一扫,私享最新原创实用干货

QQ|免责声明|小黑屋|依星资源网 ( 鲁ICP备2021043233号-3 )|网站地图

GMT+8, 2025-1-18 12:52

Powered by Net188.com X3.4

邮箱:312337667@qq.com 客服QQ:312337667(工作时间:9:00~21:00)

快速回复 返回顶部 返回列表