一篇文章让你两种方式调用星火大模型,搭建属于自己的“chatgpt”

news2025/1/17 0:48:23

申请

网址:星火大模型api注册链接

选择零元购

获取你专属的key、密钥、appid

方法1:使用jquery直接调用
 

html: 

  //应用插件-此插件用于对url编码加密,资源包已经上传,审核通过后,会在顶部显示
    <script src="../../js/crypto-js/rollups/hmac-sha256.js" type="text/javascript"></script>
    <script src="../../js/crypto-js/components/enc-base64-min.js" type="text/javascript"></script>


<div class="QA-item-ft-cont">
                        <div class="QA-item-ft-info">
                            <textarea id="search_text"></textarea>
                        </div>
                        <div class="QA-item-ft-btn">
                        <a  onclick="aisendmsg()" class="btn blue-bg search_btn" >发送</a></div>
                    </div>

注意:如果上面资源下载不了,可以关注“墨水直达”公众号,输入“crypto-js”即可下载插件

js:

<script type="text/javascript">
 var socket;

//发送问题
   function aisendmsg() {
            var reqcontent = $("#search_text").val();
            if (reqcontent == "") {
                alert("请输入问题");
                return false;
            }
            reqcontent = reqcontent;  
            OpenWebsocket();   
        }
//开启websocket

   function OpenWebsocket() { 
        //这里需要生成专属的url里按揭
            var url = getWebsocketUrl();
            if ('WebSocket' in window) {
                socket = new WebSocket(url)
            } else if ('MozWebSocket' in window) {
                socket = new MozWebSocket(url)
            } else {
                alert('浏览器不支持WebSocket')
                return
            }
            //连接打开事件
            socket.onopen = function () {
                webSocketSend();//发送消息给websocket
            }; 
            // 接收到消息时触发的事件处理函数
            socket.onmessage = function (event) {
                //解析收到的消息
                //这里的数据是流式的,不是整体返回,所以需要自己拼接,这种流式数据的好处就是用户体验不错,接口响应速度
                var json = $.parseJSON(event.data);
                var code = json.header.code;
                if (code == 0) {

                    var status = json.payload.choices.status;
                    var content = json.payload.choices.text[0].content 
                    
                    if (status != 2) {
//                        console.log("已接收到数据:" + event.data);
                    }
                    else {
                     console.log("以收到最后一条数据")
                        var totalTokens = json.payload.usage.text.total_tokens;
                       console.log("消耗的token数");//科大讯飞免费送两百万token数
                    
                    }

                } else {
                    console.log("请求报错")
                }
                // 处理接收到的消息
            };
            //连接关闭事件
            socket.onclose = function () {
                console.log("Socket已关闭");
            };
            //发生了错误事件
            socket.onerror = function () {
                console.log("Socket发生了错误");
            }
            //窗口关闭时,关闭连接
            window.unload = function () {
                socket.close();
            };
          
        }
        //定义全局
        var api_secret = "文章前面让你保留的密钥";
        var api_key = "文章前面让你保留的key";
        var appid = "文章前面让你保留的appid";

//这里是生成专属url
 function getWebsocketUrl() {
            var date = new Date().toUTCString();
            var url = 'ws://spark-api.xf-yun.com/v2.1/chat'//这里我调用的是2.0版本的接口
            var host = "spark-api.xf-yun.com";
            var builder = "host: " + host + "\n" +
                  "date: " + date + "\n" +
                  "GET /v2.1/chat HTTP/1.1";
            var sha = hmacSha256(api_secret, builder);
            var authorization = 'api_key="' + api_key + '", algorithm="hmac-sha256", headers="host date request-line", signature="' + sha + '"';
            var path1 = "authorization" + "=" + btoa(authorization);
            var path2 = "date" + "=" + date;
            var path3 = "host" + "=" + host;
            url += "?" + path1 + "&" + path2 + "&" + path3;
            return url;
        }
//这里需要在页面中引用CryptoJS插件,插件已经上传,审核通过后将会显示在顶部

  function hmacSha256(apiSecretIsKey, buider) {
            var keyBytes = CryptoJS.enc.Utf8.parse(apiSecretIsKey);
            var messageBytes = CryptoJS.enc.Utf8.parse(buider);
            var hmac = CryptoJS.HmacSHA256(messageBytes, keyBytes);
            var signature = CryptoJS.enc.Base64.stringify(hmac);
            return signature;
        }



//发送内容
  function webSocketSend() {
            var params = {
                "header": {
                    "app_id": appid,
                    "uid": user_token_id
                },
                "parameter": {
                    "chat": {
                        "domain": "generalv2",//因为我用的接口地址是2.0,如果你用的版本是1.5,需要将参数改成general
                        "temperature": 0.5,//核采样阈值。用于决定结果随机性,取值越高随机性越强即相同的问题得到的不同答案的可能性越高
                        "max_tokens": 8192,//如果你接口地址用的1.5,这里最大值为1,4096
                        "chat_id": user_token_id//用于关联用户会话,也就是用户id,保证为一性即可,如果没有要求,你可以不写这个参数
                    }
                },
                "payload": {
                    "message": {
                        "text": [] // 创建一个空数组用于存放要赋值的内容
                    }
                }
            }
//# 如果想获取结合上下文的回答,需要开发者每次将历史问答信息一起传给服务端,如下示例
 
     //     var msg1 = {
           //   "role": "user", //
            //  "content":"第一个问题"
        //  };
     //     var msg2 = {
           //   "role": "assistant", 
            //  "content": "第一个问题的回答"
        //  }; 

           //传递参数
          var msg = {
              "role": "user", //assistant
              "content": $("#search_text").val() 
          };
          params.payload.message.text.push(msg);
       
         socket.send(JSON.stringify(params))
     }
这样就完成调用啦







</script>

视频效果如下: 

desktop 2023-10-18 15-38-13


 

方法2:使用c#后台调用

 定义全局
 private static ClientWebSocket webSocket0;
 private static CancellationToken cancellation;
 //appid
 private const string x_appid = "你的appid";
 private const string api_secret = "你的密钥";
 private const string api_key = "你的key";
 private static string hostUrl1 = "https://spark-api.xf-yun.com/v1.1/chat";
 private static string hostUrl2 = "https://spark-api.xf-yun.com/v2.1/chat"; 
        [HttpPost]
        public async Task<ResultRes> KDXF_OpenAI(string parm)
        { 
            ResultRes res = new ResultRes();
            res.code = 1;
            try
            {
                OpenAI_Entity entity = JsonConvert.DeserializeObject<OpenAI_Entity>(parm);
                string resp = "";
//加密url
                string authUrl = GetAuthUrl(entity.type);
                string url = authUrl.Replace("http://", "ws://").Replace("https://", "wss://");
//开启websocket
                using (webSocket0 = new ClientWebSocket())
                {
                    await webSocket0.ConnectAsync(new Uri(url), cancellation);
                    JsonRequest request = new JsonRequest();
                    request.header = new Header()
                    {
                        app_id = x_appid,
                        uid = entity.userid
                    };
                    
                   
                    var sqldetaillist =  xxxx;//这里是用户的历史问答数据,就不展示了,如果你们不需要历史问答,则可以省略
               
                    List<Content> contentlist = new List<Content>();
                    foreach (var item in sqldetaillist)
                    {
                        Content entity1 = new Content();
                        entity1.role = "user";
                        entity1.content= item.content;
                        contentlist.Add(entity1);
                        entity1.role = "assistant";
                        entity1.content = item.reqcontent;
                        contentlist.Add(entity1);
                    }
//如果没有历史问答,省略上面一段代码,从这里开始即可
                    Content entity2 = new Content();
                    entity2.role = "user";
                    entity2.content = entity.content;
                    contentlist.Add(entity2);

                    request.parameter = new Parameter()
                    {
                        chat = new Chat()
                        {
                            domain = entity.type == 0 ? "general" : "generalv2",
                            temperature = 0.7,//温度采样阈值,用于控制生成内容的随机性和多样性,值越大多样性越高;范围(0,1)
                            max_tokens = entity.type == 0 ? 4096 : 8192,//生成内容的最大长度,范围(0,4096);2.0版本(0,8192)
                        }
                    };
                    request.payload = new Payload()
                    {
                        message = new Message()
                        {
                            text = contentlist 
                        }
                    };
                    string jsonString = JsonConvert.SerializeObject(request);
                    //连接成功,开始发送数据
                    var frameData2 = System.Text.Encoding.UTF8.GetBytes(jsonString.ToString());
                    webSocket0.SendAsync(new ArraySegment<byte>(frameData2), WebSocketMessageType.Text, true, cancellation);
                    // 接收流式返回结果进行解析
                    byte[] receiveBuffer = new byte[1024];
                    WebSocketReceiveResult result = await webSocket0.ReceiveAsync(new ArraySegment<byte>(receiveBuffer), cancellation);
                    while (!result.CloseStatus.HasValue)
                    {
                        if (result.MessageType == WebSocketMessageType.Text)
                        {
                            string receivedMessage = Encoding.UTF8.GetString(receiveBuffer, 0, result.Count);
                            //将结果构造为json
                            JObject jsonObj = JObject.Parse(receivedMessage);
                            int code = (int)jsonObj["header"]["code"];
                            if (0 == code)
                            {
                                int status = (int)jsonObj["payload"]["choices"]["status"];
                                JArray textArray = (JArray)jsonObj["payload"]["choices"]["text"];
                                string content = (string)textArray[0]["content"];
                                resp += content;

                                if (status != 2)
                                {
                                 Console.WriteLine($"已接收到数据: {receivedMessage}");
                                }
                                else
                                {
   // Console.WriteLine($"最后一帧: {receivedMessage}");
     int totalTokens = (int)jsonObj["payload"]["usage"]["text"]["total_tokens"];
//Console.WriteLine($"整体返回结果: {resp}");
//Console.WriteLine($"本次消耗token数: {totalTokens}");
                                    res.totalTokens = totalTokens;
                                    res.result = resp;
                                    break;
                                }
                            } 
                        }
                        else if (result.MessageType == WebSocketMessageType.Close)
                        {
                            res.code = -1;
                            res.result = "已关闭WebSocket连接";
                            Console.WriteLine("已关闭WebSocket连接");
                            break;
                        }

                        result = await webSocket0.ReceiveAsync(new ArraySegment<byte>(receiveBuffer), cancellation);
                    }
                }
            }
            catch (Exception ex)
            {
                res.code = -1;
                res.result = ex.Message;
            }
            return res;
        }

       private static string GetAuthUrl(int type = 0)
        {
            string date = DateTime.UtcNow.ToString("r");

            Uri uri = new Uri(type == 0 ? hostUrl1 : hostUrl2);
            StringBuilder builder = new StringBuilder("host: ").Append(uri.Host).Append("\n").//
                                    Append("date: ").Append(date).Append("\n").//
                                    Append("GET ").Append(uri.LocalPath).Append(" HTTP/1.1");

            string sha = HMACsha256(api_secret, builder.ToString());
            string authorization = string.Format("api_key=\"{0}\", algorithm=\"{1}\", headers=\"{2}\", signature=\"{3}\"", api_key, "hmac-sha256", "host date request-line", sha);
            //System.Web.HttpUtility.UrlEncode

            string NewUrl = "https://" + uri.Host + uri.LocalPath;

            string path1 = "authorization" + "=" + Convert.ToBase64String(System.Text.Encoding.UTF8.GetBytes(authorization));
            date = date.Replace(" ", "%20").Replace(":", "%3A").Replace(",", "%2C");
            string path2 = "date" + "=" + date;
            string path3 = "host" + "=" + uri.Host;

            NewUrl = NewUrl + "?" + path1 + "&" + path2 + "&" + path3;
            return NewUrl;
        }

        public static string HMACsha256(string apiSecretIsKey, string buider)
        {
            byte[] bytes = System.Text.Encoding.UTF8.GetBytes(apiSecretIsKey);
            System.Security.Cryptography.HMACSHA256 hMACSHA256 = new System.Security.Cryptography.HMACSHA256(bytes);
            byte[] date = System.Text.Encoding.UTF8.GetBytes(buider);
            date = hMACSHA256.ComputeHash(date);
            hMACSHA256.Clear();

            return Convert.ToBase64String(date);
        }
//下面是实体类

  public class OpenAI_Entity
        {
            public string userid { get; set; }//请求用户的id,唯一性
            public string content { get; set; }//问题
            public int type { get; set; } //来源,如果type=0则调用1.5版本接口,如果type=1则调用2.0版本接口
        }
  //构造请求体
        public class JsonRequest
        {
            public Header header { get; set; }
            public Parameter parameter { get; set; }
            public Payload payload { get; set; }
        }

        public class Header
        {
            public string app_id { get; set; }
            public string uid { get; set; }
        }

        public class Parameter
        {
            public Chat chat { get; set; }
        }

        public class Chat
        {
            public string domain { get; set; }
            public double temperature { get; set; }
            public int max_tokens { get; set; }
        }

        public class Payload
        {
            public Message message { get; set; }
        }

        public class Message
        {
            public List<Content> text { get; set; }
        }

        public class Content
        {
            public string role { get; set; }
            public string content { get; set; }
        }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1107780.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

三级分类部分三级目录无法加载,后端接口能在前端返回所有数据

项目场景&#xff1a; 实现ElementUI中三级分类的功能&#xff0c;发现没有前端三级目录的二级目录可以新建三级目录&#xff0c;数据库中也有数据&#xff0c;但是无法在前端显示&#xff01;后端的接口没有返回数据库的数据。 问题描述 提示&#xff1a;这里描述项目中遇到…

MySQL数据库varchar字段求和出现精度丢失

问题描述 在MySQL数据库中&#xff0c;将varchar字段用于数值运算时&#xff0c;会将其转换为数值类型进行计算。然而&#xff0c;由于varchar字段的可变长度特性&#xff0c;可能存在数值精度丢失的问题。 我用varchar类型存储学生的分数&#xff0c;分数有两位小数&#xff…

新业务场景如何个性化配置验证码?

验证码作为人机交互界面经常出现的关键要素&#xff0c;是身份核验、防范风险、数据反爬的重要组成部分&#xff0c;广泛应用网站、App上&#xff0c;在注册、登录、交易、交互等各类场景中发挥着巨大作用&#xff0c;具有真人识别、身份核验的功能&#xff0c;在保障账户安全方…

Cron表达式每隔两小时执行一次

Cron表达式每隔两小时执行一次 0 0 */2 * * ?验证正确性

7.自定义凸多边形

愿你出走半生,归来仍是少年&#xff01; 在Gis中常用的地物表达包含点线面&#xff0c;三维场景中可通过立方体的形式表达面妆物体&#xff0c;例如房屋等等。在Unity中为提供多边形的构建对象&#xff0c;此处通过wkt构建出在三维场景中的基于面的立方体。 通过传入wkt、底部高…

【数据结构与算法】JavaScript实现栈结构(Stack)

文章目录 一、前言1.1.什么是数据结构&#xff1f;1.2.什么是算法&#xff1f; 二、栈结构&#xff08;Stack&#xff09;2.1.简介2.2.封装栈类 一、前言 1.1.什么是数据结构&#xff1f; 数据结构就是在计算机中&#xff0c;存储和组织数据的方式。 例如&#xff1a;图书管…

功率放大器如何驱动超声波换能器

驱动超声波换能器的功率放大器在超声波应用中起着至关重要的作用。它能够提供足够的功率和精确的信号控制&#xff0c;使换能器能够有效地将电能转换为超声波能量。下面安泰电子将介绍功率放大器如何驱动超声波换能器的原理和关键要点。 首先&#xff0c;让我们了解一下超声波换…

2021款别克英朗,汽车空调使用方法

2021款别克英朗&#xff0c;汽车空调使用方法 今天就给大家一起交流探讨一下别克英朗2021款1.5L配置的汽车空调该如何正确使用。 别克英朗2021款1.5L配置的空调为手动空调&#xff0c;所有的空调操作都需要我们自己判断&#xff0c;比如如何正确使用制冷制热&#xff0c;内外循…

如何理解交通部EDI报文:舱单报文IFCSUM

舱单报文IFCSUM的发送方向 发送方&#xff1a;船公司、船舶代理 接收方&#xff1a;集装箱码头、理货、港监等 舱单报文IFCSUM的功能 此文件对应IFCSUM报文的舱单子集&#xff0c;提供某一航次运输货物的信息&#xff0c;说明承运人、运输方式、运输工具、设备及联运货物的细…

大模型的实践应用2-基于BERT模型训练医疗智能诊断问答的运用研究,协助医生进行疾病诊断

大家好,我是微学AI,今天给大家介绍一下大模型的实践应用2-基于BERT模型训练医疗智能诊断问答的运用研究,协助医生进行疾病诊断。医疗大模型通过收集和分析大量的医学数据和临床信息,能够协助医生进行疾病诊断、制定治疗方案和评估预后等任务。利用医疗大模型,可以帮助医生…

南美玻利维亚市场最全分析开发攻略,收藏一篇就够了

中国也是玻利维亚最大的贸易伙伴。当地时间2023年7月27日&#xff0c;玻利维亚经济与公共财政部长蒙特内格罗表示&#xff0c;玻利维亚政府决心在对外贸易中减少对美元的依赖&#xff0c;一些玻利维亚外贸企业已经开始使用人民币进行结算。到目前为止&#xff0c;玻利维亚跟中国…

选择腾讯共享wifi贴项目公司时,有哪些注意事项?!

在如今移动互联网时代&#xff0c;无线网络已经成为人们生活中必不可少的部分。虽然公共场所和商家开始提供免费WiFi&#xff0c;但是用户在连接时都要去咨询密码很是麻烦&#xff0c;腾讯共享WiFi贴凭借着高效、快速地便捷连接方式切入顾客的需求和共享市场&#xff0c;很多创…

14.9 Socket 高效文件传输

网络上的文件传输功能也是很有必要实现一下的&#xff0c;网络传输文件的过程通常分为客户端和服务器端两部分。客户端可以选择上传或下载文件&#xff0c;将文件分块并逐块发送到服务器&#xff0c;或者从服务器分块地接收文件。服务器端接收来自客户端的请求&#xff0c;根据…

【软考】6.1 信息安全及技术

《信息安全和信息系统安全》 信息安全系统的体系架构 网络安全空间五大要素&#xff1a;认证、权限、完整、加密、不可否认&#xff08;抵赖&#xff09; 信息安全含义及属性 信息安全三要素&#xff1a;保密性、完整性、可用性最小授权原则&#xff1a;该有什么权限&#xf…

软件测试基础知识 + 面试理论(超详细)

一、什么是软件&#xff1f; 软件是计算机系统中的程序和相关文件或文档的总称。 二、什么是软件测试&#xff1f; 说法一&#xff1a;使用人工或自动的手段来运行或测量软件系统的过程&#xff0c;以检验软件系统是否满足规定的要求&#xff0c;并找出与预期结果之间的差异…

Mac系统快速切换和管理node版本

如何下载node 不要下载最新版&#xff0c;推荐先下载稳定版的nodejs.org/zh-cn/downl…&#xff0c;下载完一键式安装即可&#xff0c;安装完成后&#xff0c;命令行查看是否成功。 1、使用n切换node版本 node有一个模块n&#xff0c;是专门用来管理node.js的版本的。npm是用…

数据导入与预处理-第4章-Python标准库之json

文章目录 资源json概述json案例dumps案例dump案例中文编码问题格式化问题 loads案例load案例 资源 参考:https://zhuanlan.zhihu.com/p/436465279 https://blog.csdn.net/impoijimlq/article/details/130445399 json概述 什么是json json是一种轻量级的文本数据 交换格式jso…

【代码软实力】职场高效沟通技巧

一、沟通三要素 二、什么是沟通 三、沟通的难点 四、向上沟通-结构化表达 上级结构化表达的案例 五、平级沟通-非暴力沟通 平级非暴力沟通案例 六、下级沟通-行为影响结果原则BIC 下级沟通案例分析 思维导图

如何在MT4和MT5复制交易?有缺点吗?anzo capital昂首资本1秒答

很多投资者不知道如何在MT4和MT5上复制交易信号&#xff1f;其实很简单&#xff0c;今天anzo capital昂首资本1分钟解答&#xff0c;复制交易的方法包括&#xff1a; 在MetaQuotes社区进行交易复制和信号的传播。MT4和MT5均具备连接到这个社区的功能。以下是使用该功能的步骤&…

Crypto(2)攻防世界-幂数加密

先看题&#xff0c;给出了flag格式和幂数加密的方式。 附件里的内容为8842101220480224404014224202480122 正常的二进制幂数加密只有0&#xff0c;1&#xff0c;2&#xff0c;3&#xff0c;4&#xff0c;5&#xff0c;是不会出现8的。通过百度了解到这是云影密码、 简单说来…