基于DeepSeek的沉浸式对话网站开发实战(一)

一句话介绍
用JavaScript直接调用DeepSeek官网的API,让虚拟人物“活”过来和你聊天!

技术实现(超直白)​

  1. 前端:纯HTML + CSS + JavaScript(没用什么复杂框架)
  2. API调用:直接用了DeepSeek官网的聊天接口(fetch发个请求就行)
  3. 古人设定
    • 每个古人角色写了个简单的提示词​(比如告诉AI:“你现在是李白,说话要豪放,爱喝酒”)
    • 用户输入问题 → 发给DeepSeek → 返回古人风格的回答
async function askLiBai(question) {
  const response = await fetch("https://api.deepseek.com/v1/chat/completions", {
    method: "POST",
    headers: {
      "Content-Type": "application/json",
      "Authorization": "Bearer 你的API_KEY"
    },
    body: JSON.stringify({
      model: "deepseek-chat",
      messages: [
        { role: "system", content: "你是唐代诗人李白,回答要狂放不羁,带点醉意" },
        { role: "user", content: question }
      ]
    })
  });
  const data = await response.json();
  return data.choices[0].message.content;
}

// 调用示例
askLiBai("今天心情不好怎么办?").then(answer => {
  console.log("李白说:", answer); // 比如输出:"哈哈哈!不如与君共饮三百杯!"
});

为什么简单但好玩?

  • 不用训练模型,不用搞服务器,​DeepSeek的API直接搞定AI部分
  • 改个提示词就能换角色(比如把李白换成杜甫,语气立刻变沉稳)
  • 纯静态网页也能用,丢到GitHub Pages就能分享给朋友

缺点(老实人版)​

  • API免费额度用完了可能要付费(但玩玩完全够用,粗略计算,充值十元够用个两个月)
  • DeepSeek官网API有时候响应慢,等得让人想“穿越回古代”😂(可以通过更换阿里云/腾讯云部署的DeepSeek速度能快很多)
模型deepseek-chatdeepseek-reasoner
上下文长度64K64K
最大思维链长度(2)-32K
最大输出长度(3)8K8K
标准时段价格
(北京时间 08:30-00:30)
百万tokens输入(缓存命中)(4)0.5元1元
百万tokens输入(缓存未命中)2元4元
百万tokens输出 (5)8元16元
优惠时段价格(6)
(北京时间 00:30-08:30)
百万tokens输入(缓存命中)0.25元(5折)0.25元(2.5折)
百万tokens输入(缓存未命中)1元(5折)1元(2.5折)
百万tokens输出4元(5折)4元(2.5折)

话不多说,进入正题

1. 注册账号:成为“AI门派弟子”​
  • 第一步:访问DeepSeek-API开放平台(门派山门)。
  • 第二步:点击「注册」,填手机号、设密码(相当于拜师贴)。
  • 小贴士:密码要像武林秘籍一样复杂,别用123456这种“三脚猫功夫”!🐱💨

2. 领取“秘钥”:一键生成API Key
  • 登录后,找到「API Keys」页面(藏经阁的钥匙柜)。
  • 点击​「创建API Key」​——啪!系统瞬间吐出一串神秘代码(比如sk-李白斗酒诗百篇)。
  • 重点:这钥匙只显示一次!复制后立刻藏进保险箱(比如密码管理器),否则丢了只能重新“铸剑”🗡️。

注意事项(避坑指南)​
  • ❌ ​别把Key贴到GitHub!否则会被江湖黑客“顺手牵羊”。
  • 🐢 ​偶尔卡顿:AI思考时像老黄牛耕地,加个加载动画假装它在“酝酿诗兴”。

终极秘籍

想更溜?直接看官方文档(武功秘籍全本)!
现在,你已经是​“AI江湖”​的持钥少侠了,快去拯救(折腾)世界吧!🎮

1. HTML 文件 (index.html)

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>AI聊天</title>
    <!-- 引入CSS文件,就像给网页穿上漂亮衣服 -->
    <link rel="stylesheet" href="style.css">
</head>
<body>
    <!-- 聊天容器 - 这是我们的"数字客厅" -->
    <div id="chat-container"></div>
    
    <!-- 输入区域 - 用户的"数字麦克风" -->
    <div id="input-area">
        <input type="text" id="user-input" placeholder="输入消息...">
        <button id="send-button">发送</button>
    </div>

    <!-- 引入JS文件,就像给网页注入"灵魂" -->
    <script src="script.js"></script>
</body>
</html>

解释:HTML文件就像房子的框架,定义了结构但没有任何装饰或功能。它告诉浏览器"这里有个聊天框,那里有个输入框",但具体长什么样、怎么工作它不管。

2. CSS 文件 (style.css)

/* 给整个"数字客厅"定个基调 */
body {
    font-family: Arial; /* 选择清晰易读的字体 */
    max-width: 800px;  /* 不让聊天室太宽,保持舒适阅读 */
    margin: 0 auto;    /* 居中显示,像挂在墙上的画 */
    padding: 20px;     /* 留点呼吸空间 */
}

/* 聊天容器 - 我们的"数字对话泡泡浴缸" */
#chat-container {
    height: 400px;     /* 限制高度,避免无限延伸 */
    overflow-y: auto;  /* 消息多了自动滚动,像自动卷纸 */
    margin-bottom: 20px; /* 和输入框保持礼貌距离 */
}

/* 用户消息 - 蓝色泡泡,像从右边飘来的云 */
.user-message {
    background: #e3f2fd; /* 柔和的蓝色 */
    margin-left: auto;  /* 靠右对齐 */
    max-width: 80%;    /* 不让泡泡太宽 */
    padding: 10px;
    border-radius: 10px 10px 0 10px; /* 圆角只在左侧 */
    margin-bottom: 10px;
}

/* AI消息 - 灰色泡泡,像从左边飘来的云 */
.bot-message {
    background: #f1f1f1; /* 中性灰色 */
    margin-right: auto; /* 靠左对齐 */
    max-width: 80%;    /* 同样限制宽度 */
    padding: 10px;
    border-radius: 10px 10px 10px 0; /* 圆角只在右侧 */
    margin-bottom: 10px;
}

/* 输入区域 - 我们的"数字麦克风支架" */
#input-area {
    display: flex;     /* 让输入框和按钮并排站 */
    gap: 10px;        /* 保持适当距离 */
}

/* 输入框 - 用户打字的"数字键盘" */
#user-input {
    flex: 1;          /* 占据剩余空间 */
    padding: 10px;    /* 让文字有呼吸空间 */
    border: 1px solid #ddd; /* 优雅的边框 */
    border-radius: 5px; /* 轻微圆角 */
}

/* 发送按钮 - 闪亮的"发送火箭" */
button {
    padding: 10px 20px;
    background: #007bff; /* 明亮的蓝色 */
    color: white;
    border: none;
    border-radius: 5px;
    cursor: pointer;  /* 鼠标悬停变成小手 */
    transition: background 0.3s; /* 平滑的颜色过渡 */
}

/* 当鼠标悬停在按钮上时 - "火箭准备发射"效果 */
button:hover {
    background: #0056b3;
}

解释:CSS文件是网页的造型师,决定每个元素的外观。它就像室内设计师,决定"对话泡泡应该是蓝色的,圆角在左边,而AI的泡泡是灰色的,圆角在右边"。

3. JavaScript 文件 (script.js)

// 我们的"AI魔法书"的钥匙
const API_KEY = 'your-api-key'; // 替换为你的API密钥

// "记忆宫殿" - 存储对话历史
let messageHistory = [];

// "发送魔法"函数 - 把用户的话变成AI的回复
async function sendMessage() {
    const userInput = document.getElementById('user-input').value;
    if (!userInput) return; // 如果用户没输入,就像对着空气说话
    
    // 把用户的话放进"记忆宫殿"
    displayMessage(userInput, 'user');
    document.getElementById('user-input').value = ''; // 清空输入框,准备下一句话
    
    // 开始"魔法仪式" - 调用API
    try {
        const response = await fetch("https://api.deepseek.com/v1/chat/completions", {
            method: "POST",
            headers: {
                "Content-Type": "application/json",
                "Authorization": `Bearer ${API_KEY}` // 出示"魔法钥匙"
            },
            body: JSON.stringify({
                model: "deepseek-chat", // 选择"魔法书"的版本
                messages: [...messageHistory, {role: "user", content: userInput}] // 传递对话历史
            })
        });
        
        // 解读"魔法书"的回应
        const data = await response.json();
        const botResponse = data.choices[0].message.content;
        
        // 把AI的智慧放进"记忆宫殿"并展示
        displayMessage(botResponse, 'bot');
        messageHistory.push(
            {role: "user", content: userInput},
            {role: "assistant", content: botResponse}
        );
    } catch (error) {
        // 如果"魔法"出错了...
        displayMessage("魔法失灵了: " + error.message, 'bot');
    }
}

// "展示魔法"函数 - 把消息变成可见的泡泡
function displayMessage(message, sender) {
    const chatContainer = document.getElementById('chat-container');
    const messageElement = document.createElement('div');
    messageElement.classList.add(`${sender}-message`, 'message');
    messageElement.textContent = message;
    chatContainer.appendChild(messageElement);
    chatContainer.scrollTop = chatContainer.scrollHeight; // 自动滚动到底部,像自动卷轴
}

// 设置"魔法触发器" - 点击发送按钮或按回车键
document.getElementById('send-button').addEventListener('click', sendMessage);
document.getElementById('user-input').addEventListener('keypress', (e) => {
    if (e.key === 'Enter') sendMessage(); // 回车键就像"发送火箭"的发射按钮
});

解释:JavaScript文件是网页的大脑,负责所有交互和逻辑。它就像魔法师,当用户说话时(输入消息),它会把消息送到云端AI(魔法书),然后把AI的回复变成可见的泡泡显示出来。它还负责记住对话历史,就像魔法师的记忆宫殿。

4. 使用说明

  1. 创建三个文件:index.htmlstyle.cssscript.js
  2. 将上述代码分别复制到对应文件中
  3. 在**script.js中替换your-api-key你的实际API密钥**
  4. 在浏览器中打开index.html即可使用

⚠️ 前方高能预警:你的API Key正在裸奔!​

把API Key直接写在前端代码里,就像把家门钥匙插在门锁上还贴张纸条:"密码是123456"🔑。黑客们看到这种操作都会感动到流泪——这简直是给他们发"零元购"邀请函啊!

为什么这是作死行为?

  1. 浏览器脱衣舞:前端代码完全暴露,Chrome开发者工具一按F12,你的Key就像没穿衣服一样被看光光
  2. GitHub公开处刑:无数开发者把带Key的代码上传GitHub,黑客专用爬虫每天能捡到12000+个免费Key(真·白嫖怪快乐日)
  3. 钱包秒变黑洞:泄露的Key会被用来疯狂刷API,等你发现时,账单已经长得像《三体》里的二向箔

正确姿势(特工级防护)​

// ❌ 自杀式写法(请勿模仿)
const API_KEY = 'sk-我是大冤种'; 

// ✅ 特工级写法
// 后端:"钥匙我藏着,想要?验明正身先!"
fetch('/api/proxy', { 
  headers: { 'Authorization': '指纹/虹膜验证' } 
});

紧急补救套餐

  • 立刻甩掉Key!像甩掉前任一样快(控制台点两下的事)
  • 给Key上锁:IP白名单+调用限额,比银行金库还严
  • 终极奥义:用AWS KMS/阿里云密钥管家,让Key住进钛合金保险箱

记住:前端放Key等于在互联网裸奔,而黑客们都是拿着望远镜的流氓🌚 快用后端代理给Key穿上防弹衣吧!

最优解法:在前端开发一个API-KEY输入功能,每次需要手动输入才可以使用(敬请期待)

欢迎大家在评论区建议,讨论,质疑

大模型岗位需求

大模型时代,企业对人才的需求变了,AIGC相关岗位人才难求,薪资持续走高,AI运营薪资平均值约18457元,AI工程师薪资平均值约37336元,大模型算法薪资平均值约39607元。
在这里插入图片描述

掌握大模型技术你还能拥有更多可能性

• 成为一名全栈大模型工程师,包括Prompt,LangChain,LoRA等技术开发、运营、产品等方向全栈工程;

• 能够拥有模型二次训练和微调能力,带领大家完成智能对话、文生图等热门应用;

• 薪资上浮10%-20%,覆盖更多高薪岗位,这是一个高需求、高待遇的热门方向和领域;

• 更优质的项目可以为未来创新创业提供基石。

可能大家都想学习AI大模型技术,也想通过这项技能真正达到升职加薪,就业或是副业的目的,但是不知道该如何开始学习,因为网上的资料太多太杂乱了,如果不能系统的学习就相当于是白学。为了让大家少走弯路,少碰壁,这里我直接把全套AI技术和大模型入门资料、操作变现玩法都打包整理好,希望能够真正帮助到大家。

读者福利:如果大家对大模型感兴趣,这套大模型学习资料一定对你有用

零基础入门AI大模型

今天贴心为大家准备好了一系列AI大模型资源,包括AI大模型入门学习思维导图、精品AI大模型学习书籍手册、视频教程、实战学习等录播视频免费分享出来。

有需要的小伙伴,可以点击下方链接免费领取【保证100%免费

点击领取 《AI大模型&人工智能&入门进阶学习资源包》*

1.学习路线图

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
如果大家想领取完整的学习路线及大模型学习资料包,可以扫下方二维码获取
在这里插入图片描述
👉2.大模型配套视频👈

很多朋友都不喜欢晦涩的文字,我也为大家准备了视频教程,每个章节都是当前板块的精华浓缩。(篇幅有限,仅展示部分)

img

大模型教程

👉3.大模型经典学习电子书👈

随着人工智能技术的飞速发展,AI大模型已经成为了当今科技领域的一大热点。这些大型预训练模型,如GPT-3、BERT、XLNet等,以其强大的语言理解和生成能力,正在改变我们对人工智能的认识。 那以下这些PDF籍就是非常不错的学习资源。(篇幅有限,仅展示部分,公众号内领取)

img

电子书

👉4.大模型面试题&答案👈

截至目前大模型已经超过200个,在大模型纵横的时代,不仅大模型技术越来越卷,就连大模型相关的岗位和面试也开始越来越卷了。为了让大家更容易上车大模型算法赛道,我总结了大模型常考的面试题。(篇幅有限,仅展示部分,公众号内领取)

img

大模型面试

**因篇幅有限,仅展示部分资料,**有需要的小伙伴,可以点击下方链接免费领取【保证100%免费

点击领取 《AI大模型&人工智能&入门进阶学习资源包》

**或扫描下方二维码领取 **

在这里插入图片描述

### 使用DeepSeek框架构建对话型数字人的方法 构建对话型数字人涉及多个技术组件的集成,包括自然语言处理(NLP)、语音识别(ASR)以及图像生成等。DeepSeek作为个综合性平台,提供了这些功能的支持。 #### 1. 自然语言理解模块 为了使数字人能够理解和回应用户的输入,需要训练个强大的NLP模型来解析语义并提取意图。这可以通过预训练的语言模型进步微调实现,以适应特定的应用场景或行业领域的需求[^1]。 ```python from deepseek.nlu import NLUModel nlu_model = NLUModel(pretrained=True) nlu_model.finetune(dataset="custom_conversation_data") ``` #### 2. 对话管理器 创建有效的对话流对于保持良好的用户体验至关重要。开发者应该设计状态机或者采用更先进的强化学习算法来优化决策过程,从而让虚拟角色做出更加智能化的回答。 ```python class DialogueManager: def __init__(self): self.state = 'idle' def update_state(self, user_input): # 更新当前对话状态逻辑 pass def get_response(self): if self.state == 'greeting': return "Hello! How can I assist you today?" elif self.state == 'farewell': return "Goodbye!" ``` #### 3. 多模态交互界面 为了让数字形象看起来更具真实感,除了文字交流外还可以加入表情动画和声音播放等功能。利用计算机视觉技术和音频合成工具,可以使人物动作与所说的话同步协调致。 ```python import cv2 from deepseek.tts import TextToSpeechConverter tts_converter = TextToSpeechConverter() def play_animation_and_speech(text_message): animation_frames = generate_animation_based_on_text(text_message) speech_audio = tts_converter.convert_to_speech(text_message) for frame in animation_frames: cv2.imshow('Digital Human', frame) cv2.waitKey(int(speech_audio.duration * 1000)) ``` 通过上述三个主要部分的工作,即实现了基于DeepSeek框架下的对话型数字人的基本架构搭建。当然,在实际开发过程中还需要考虑更多细节问题如性能优化、安全性保障等方面的内容。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员一粟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值