在项目中调用本地Deepseek(接入本地Deepseek)
前言
之前发表的文章已经讲了如何本地部署Deepseek模型,并且如何给Deepseek模型投喂数据、搭建本地知识库,但大部分人不知道怎么应用,让自己的项目接入AI模型。
文末有彩蛋哦!!!
要接入本地部署的deepseek,我就要利用到我们之前部署时安装的ollama服务,并调用其API
本地API接口
1、生成文本(Generate Text)
url: POST /api/generate
功能:向模型发送提示词(prompt),并获取生成的文本。
请求格式:
{"model": "<model-name>", // 模型名称"prompt": "<input-text>", // 输入的提示词"stream": false, // 是否启用流式响应(默认 false)"options": { // 可选参数"temperature": 0.7, // 温度参数"max_tokens": 100 // 最大 token 数}
}
响应格式:
{"response": "<generated-text>", // 生成的文本"done": true // 是否完成
}
2、生成对话补全
url:POST /api/chat
功能:支持多轮对话,模型会记住上下文。
请求格式:
{"model": "<model-name>", // 模型名称"messages": [ // 消息列表{"role": "user", // 用户角色"content": "<input-text>" // 用户输入}],"stream": false, // 是否启用流式响应"options": { // 可选参数"temperature": 0.7,"max_tokens": 100}
}
响应格式:
{"message": {"role": "assistant", // 助手角色"content": "<generated-text>" // 生成的文本},"done": true
}
3、列出本地模型(List Models)
url:GET /api/tags
功能:列出本地已下载的模型。
响应格式:
{"models": [{"name": "<model-name>", // 模型名称"size": "<model-size>", // 模型大小"modified_at": "<timestamp>" // 修改时间}]
}
4、模型的详细信息
url:POST /api/show
功能:查看特定模型的详细信息。
请求格式:
{"name": model}
响应格式:
{"license": "...","template": "...","details": {...},"model_info": {...},"modified_at": "2025-02-10T13:26:44.0736757+08:00"
}
5、生成嵌入向量
url:POST /api/embed
功能:为输入的文本生成嵌入向量。
请求格式:
{"model": model,"input": text
}
响应格式:
{"model": "deepseek-r1:7b","embeddings": [[0.00245497,...]],"total_duration": 8575498700,"load_duration": 7575292200,"prompt_eval_count": 4
}
使用实例
1、启动 Ollama 服务
在使用 API 之前,需要确保 Ollama 服务正在运 行。可以双击打开或通过以下命令启动服务:
ollama serve
2、在项目中调用API(这里以react为例实现简单效果)
AI.jsx:
import { useEffect, useState, useRef } from 'react';
import './AI.css';export default function AI() {const [outputContent, setOutput] = useState('');// ref 存储textarea 内容const inputRef = useRef(null);useEffect(() => {// const userPrompt = "介绍";// streamOllamaResponse(userPrompt);}, []);let handleSubmit = async (event) => {event.preventDefault();streamOllamaResponse(inputRef.current.value);}async function streamOllamaResponse(prompt) {const url = 'http://localhost:11434/api/generate';const headers = {'Content-Type': 'application/json'};const data = {"model": "deepseek-r1:7b","prompt": prompt,"stream": true};const response = await fetch(url, {method: 'POST',headers: headers,body: JSON.stringify(data)});if (!response.ok) {console.error(`请求失败,状态码: ${response.status}`);return;}const reader = response.body.getReader();const decoder = new TextDecoder('utf-8');while (true) {const { done, value } = await reader.read();if (done) {break;}const chunk = decoder.decode(value, { stream: true });const chunkResponse = JSON.parse(chunk).responseconsole.log(chunkResponse);setOutput((outputContent) => outputContent + chunkResponse);}}return (<div className='ai-container'><h2>AI Page</h2><div className='ai-content'><div className='output-container'><pre>{outputContent}</pre></div><div className='input-container'><textarea ref={inputRef} name="" id="" placeholder='请输入您的问题'></textarea><button onClick={handleSubmit}>提交</button></div></div></div>)
}
效果

文末彩蛋!!(粉丝福利)
DeepSeek使用技巧大全.rar:https://pan.quark.cn/s/6e769f336d4b
相关文章:
在项目中调用本地Deepseek(接入本地Deepseek)
前言 之前发表的文章已经讲了如何本地部署Deepseek模型,并且如何给Deepseek模型投喂数据、搭建本地知识库,但大部分人不知道怎么应用,让自己的项目接入AI模型。 文末有彩蛋哦!!! 要接入本地部署的deepsee…...
notepad++右键菜单不见了
卸载时没点击完成,又重新安装了一个,最终导致了一些bug,导致右键没有notepad菜单。 解决方式: 新建一个register.reg文件,加入以下代码,然后双击执行即可 代码说明:Open with Notepad 是右…...
如何用ollama快速布署deepseek-r1大模型
deepseek在春节期间因为特朗普的一番发言而在中国已几乎人尽皆知,热度到了连90高寿的老父亲都向我推荐这个中国产的AI大模型,而且它是开源的!我试验了下,用ollama也可以快速度安装布署deepseek-r1大模型。本想写篇文章来介绍下dee…...
python-leetcode 36.二叉树的最大深度
题目: 给定一个二叉树root,返回其最大深度 二叉树的最大深度是指从根节点到最远叶子节点的最长路径上的节点数 方法一:深度优先搜索 知道了左子树和右子树的最大深度l和r,那么该二叉树的最大深度即为:max(l,r)1 而左子树和右子树的最大深…...
MySQL事务的特性和隔离级别
一、事务的特性 事务是一组操作的集合,它是一个不可分割的工作单位,事务会把所有的操作作为一个整体一起向系统提交或撤销操作,即这些操作要么同时成功,要么同时失败 事务的有以下四个特性(acid)…...
Oracle视图(基本使用)
视图 视图是通过定制的方式显示一个或者多个表的数据。 视图可以视为“虚拟表”或“存储的查询”。 视图的优点: 提供了另外一种级别的表安全性隐藏了数据的复杂性简化了用户的SQL命令隔离基表结构的改变通过重命名列,从另一个角度提供数据。 视图里…...
C++ Primer 类的作用域
欢迎阅读我的 【CPrimer】专栏 专栏简介:本专栏主要面向C初学者,解释C的一些基本概念和基础语言特性,涉及C标准库的用法,面向对象特性,泛型特性高级用法。通过使用标准库中定义的抽象设施,使你更加适应高级…...
【学习笔记】Cadence电子设计全流程(二)原理图库的创建与设计(上)
【学习笔记】Cadence电子设计全流程(二)原理图库的创建与设计(上) 2.1 OrCAD X Capture 界面预览2.2 原理图元件符号的组成2.3 原理图库的创建和元件的创建2.4 以 STM32F103T8U6 芯片为例创建元件 全部内容见专栏:【Ca…...
学习数据结构(11)二叉树(堆)下
1.堆的概念 如果有⼀个集合 K {k0,k1,k2,...,k(n-1)} ,把它的所有元素按完全二叉树的形式存储在一个一维数组中,并满足:K(i)<2*i1且K(i)<2*i2(K(i)>2*i1且K(i)>2*i2&a…...
HarmonyOS NEXT网络状态监听HTTP和RCP请求网络
当我们在HarmonyOS NEXT中开发的应用,基本上都会使用网络请求,从服务端获取数据在客户端显示或者供用户交互,有时候网络发生变化时,我们需要做一些相应的操作,接下来我们一起来了解下在HarmonyOS NEXT下如何监听网络状…...
MySQL数据库(4)—— 数据类型
目录 一,数据类型分类 二,数值类型 2.1 tinyint类型 2.2 bit类型 2.3 float类型 2.4 decimal类型 三,字符串类型 3.1 char类型 3.2 varchar类型 四,时间日期类型 五,enum和set类型 5.1 基本使用 5.2 解释查…...
如何在Odoo 18中创建记录规则Rule
如何在Odoo 18中创建记录规则Rule 记录规则是管理访问控制的关键,它能让你依据用户角色,定义谁可以在系统内查看、创建或修改特定记录。例如,公司中的普通员工只能查看或修改与与自己直接相关的数据,而经理则有权限访问和编辑所有…...
petalinux高版本设置自动登录和开机自启动配置
petalinux-config -c rootfs 依次选择 Image Features -> serial-autologin-root 这是配置 进来就是root权限 创建并安装名为 myapp-init 的新建应用程序 petalinux-create -t apps --template install -n myapp-init --enable 编辑 project-spec/meta-user/recipes-…...
操作系统2.4
一、死锁,饥饿,死循环 死锁:各进程互相等待对方手里的资源,导致各进程都阻塞,无法向前推进的现象 饥饿:由于长期得不到想要的资源,某进程无法向前推进的现象,例如:短进…...
Springboot + Ollama + IDEA + DeepSeek 搭建本地deepseek简单调用示例
1. 版本说明 springboot 版本 3.3.8 Java 版本 17 spring-ai 版本 1.0.0-M5 deepseek 模型 deepseek-r1:7b 需要注意一下Ollama的使用版本: 2. springboot项目搭建 可以集成在自己的项目里,也可以到 spring.io 生成一个项目 生成的话,如下…...
解析DrugBank数据库数据|Python
一、DrugBank 数据库简介 DrugBank 是一个综合性的生物信息学和化学信息学数据库,专门收录药物和靶点的详细信息。它由加拿大阿尔伯塔大学的 Wishart 研究组 维护,提供化学、药理学、相互作用、代谢、靶点等多方面的药物数据。DrugBank 结合了实验数据和…...
CUDA Toolkit 历史版本 cuda安装
cuda安装 CUDA Toolkit 版本选择1. NVIDIA-SMI 525.60.11静默安装2. CUDA Toolkit 12.6.0 安装禁用 nouveau依赖安装下载安装 cuda显卡驱动安装成功设置环境变量 3. 安装失败切换到多用户文本模式 参考 CUDA Toolkit 版本选择 CUDA Toolkit 历史版本 1. NVIDIA-SMI 525.60.11 …...
Aseprite详细使用教程(12)——轮廓工具和多边形工具
一、轮廓工具 (1)核心功能 轮廓生成:给鼠标起点和终点的连线以及两点经过的路径形成的轮廓,可单独指定轮廓颜色。 (2) 使用方法 选择工具后,鼠标左键点击,按住不松手,拖动…...
macos sequoia 禁用 ctrl+enter 打开鼠标右键菜单功能
macos sequoia默认ctrlenter会打开鼠标右键菜单,使得很多软件有冲突。关闭方法: end...
分布式架构与XXL-JOB
目录 先了解什么是任务调度? 什么是分布式任务调度? 了解XXL-JOB分布式任务调度平台 如何搭建XXL-JOB? 分片广播 作业分片方案 最近学习在项目的媒资管理模块如何高效处理大量视频,上传单个视频可能涉及到转码,…...
为什么你的Python桌面App启动要8秒?这7个编译期优化开关,让冷启时间压进1.2秒内!
更多请点击: https://intelliparadigm.com 第一章:Python跨端应用编译优化概览 Python 作为解释型语言,天然面临跨平台部署时的性能与体积挑战。当面向桌面(Windows/macOS/Linux)、移动(Android/iOS&#…...
NVIDIA Profile Inspector 完整指南:解锁显卡隐藏性能的10个专业技巧
NVIDIA Profile Inspector 完整指南:解锁显卡隐藏性能的10个专业技巧 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector NVIDIA Profile Inspector 是一款强大的开源工具,专为追求极…...
如何用Flowframes轻松实现视频帧率翻倍:完整AI插帧指南
如何用Flowframes轻松实现视频帧率翻倍:完整AI插帧指南 【免费下载链接】flowframes Flowframes Windows GUI for video interpolation using DAIN (NCNN) or RIFE (CUDA/NCNN) 项目地址: https://gitcode.com/gh_mirrors/fl/flowframes 还在为低帧率视频的卡…...
10分钟学会在Windows上搭建专业级RTMP流媒体服务器
10分钟学会在Windows上搭建专业级RTMP流媒体服务器 【免费下载链接】nginx-rtmp-win32 Nginx-rtmp-module Windows builds. 项目地址: https://gitcode.com/gh_mirrors/ng/nginx-rtmp-win32 你是否想过在Windows电脑上搭建自己的直播服务器?今天我们要介绍的…...
从《我的世界》到小游戏:用SFML和VS2022开启你的2D图形编程之旅
从《我的世界》到小游戏:用SFML和VS2022开启你的2D图形编程之旅 你是否曾经玩过《我的世界》,被那些简单的方块构建出的无限可能所吸引?或者梦想过亲手打造属于自己的2D小游戏?对于许多编程新手来说,游戏开发似乎是一…...
Caldera 推出 Metalayer 生态工具 拓展 Layer 生态能力
Caldera 近日正式推出 Metalayer Token Launcher,这是首个支持跨链代币部署的无代码解决方案, 为项目方提供一套无需代码的代币发行工具,帮助团队快速创建并部署 MetaTokens,进一步降低链上经济系统启动与资产发行的技术门槛。 Metalayer To…...
保姆级教程:用Fast DDS(ROS2同款)在Ubuntu上快速搭建你的第一个DDS通信Demo
从零构建DDS通信系统:Fast DDS实战指南与车载通信深度解析 在智能汽车与分布式系统开发领域,数据分发服务(DDS)正成为新一代通信架构的核心支柱。不同于传统点对点通信模式,DDS以数据为中心的发布/订阅机制࿰…...
VSCode光标自动隐藏扩展:三层防御机制与键盘流开发体验优化
1. 项目概述:为键盘流开发者定制的光标隐身术如果你和我一样,是个重度依赖键盘的开发者,尤其是在 VSCode 里用 Neovim 模式写代码,那你一定对那个碍事的鼠标光标深恶痛绝。明明在用hjkl在代码间穿梭,视线却总被那个静止…...
从仿真到芯片:手把手将Simulink定点化FOC代码部署到STM32F4/F1(含数据溢出调试实录)
从仿真到芯片:手把手将Simulink定点化FOC代码部署到STM32F4/F1(含数据溢出调试实录) 在电机控制领域,Simulink模型仿真与真实硬件部署之间往往存在一道难以逾越的鸿沟。许多工程师能够熟练搭建浮点算法模型并获得理想的仿真结果&a…...
【央行《分布式事务技术规范》V2.3解读】:Java开发者速查手册(含3类强一致性场景代码模板)
更多请点击: https://intelliparadigm.com 第一章:Java金融分布式事务优化 在高并发、强一致性的金融系统中,传统单体事务模型难以应对跨服务、跨数据库的转账、清算与对账场景。Java 生态中主流的分布式事务方案(如 Seata、Atom…...
