使用C# 调用deepseek api接口实现正常访问的过程
作者:火星大能猫
本文介绍了使用C#调用deepseek API接口实现正常访问的方法,包括解决SSL/TLS安全通道问题和切换模型等常见问题,并提供了默认使用的reasoner模型和账户余额信息,感兴趣的朋友一起看看吧
先上图,结果如图
先去官方网站充值api费用,默认
对应的C#代码封装
public class DeepSeekHelper { private static readonly HttpClient client = new HttpClient(); private const string ApiEndpoint = "https://api.deepseek.com/v1/chat/completions"; private static readonly string apiKey = "你的apikey"; public static async Task<string> CallDeepSeekAPI(string userQuestion) { ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12; try { // 设置请求头 client.DefaultRequestHeaders.Clear(); client.DefaultRequestHeaders.Add("Authorization", $"Bearer {apiKey}"); client.DefaultRequestHeaders.Add("Accept", "application/json"); // 构建请求体 var requestBody = new { model = "deepseek-reasoner", // 根据实际模型调整 messages = new[] { new { role = "user", content = userQuestion } }, temperature = 0.7 }; // 序列化请求体 //var jsonContent = JsonSerializer.Serialize(requestBody); var jsonContent = JsonConvert.SerializeObject(requestBody); var content = new StringContent(jsonContent, Encoding.UTF8, "application/json"); // 发送请求 var response = await client.PostAsync(ApiEndpoint, content); // 处理响应 if (!response.IsSuccessStatusCode) { throw new Exception($"API请求失败: {response.StatusCode}"); } var responseContent = await response.Content.ReadAsStringAsync(); var resultModel = JsonConvert.DeserializeObject<DeepSeekResponse>(responseContent); if (resultModel != null && resultModel.Choices.Count > 0) return resultModel.Choices[0].Message.Content; return responseContent; } catch (Exception ex) { // 处理异常 return $"调用API时发生错误: {ex.Message}"; } } } public class DeepSeekResponse { public string Id { get; set; } public string Object { get; set; } public long Created { get; set; } public string Model { get; set; } public List<Choice> Choices { get; set; } public Usage Usage { get; set; } public string SystemFingerprint { get; set; } // 重写ToString方法以便更好地显示对象信息 public override string ToString() { return $"DeepSeekResponse(Id={Id}, Object={Object}, Created={Created}, Model={Model}, Choices={string.Join(", ", Choices)}, Usage={Usage}, SystemFingerprint={SystemFingerprint})"; } } public class Choice { public int Index { get; set; } public Message Message { get; set; } // 其他Choice相关的属性... // 重写ToString方法以便更好地显示Choice信息(这里仅展示Index和Message作为示例) public override string ToString() { return $"Choice(Index={Index}, Message={Message})"; } } public class Message { public string Role { get; set; } public string Content { get; set; } // 其他Message相关的属性... } public class Usage { public int PromptTokens { get; set; } public int CompletionTokens { get; set; } public int TotalTokens { get; set; } // 其他Usage相关的属性,包括嵌套的字典等,可以根据需要添加 }
调用示例
private async void SendButton_Click(object sender, RoutedEventArgs e) { string requestText = RequestTextBox.Text; if (!string.IsNullOrWhiteSpace(requestText)) { try { string responseData = await DeepSeekHelper.CallDeepSeekAPI(requestText); // await new DeepSeekApi().CallDeepSeekAPI(chatRequest); ResponseTextBox.Text = responseData; } catch (Exception ex) { ResponseTextBox.Text = $"Error: {ex.Message}"; } } else { MessageBox.Show("Please enter a request."); } }
常见问题:
1发送请求时出错 InnerException = {"请求被中止: 未能创建 SSL/TLS 安全通道。"}
指定使用TLS1.2加密协议,添加如下代码
ServicePointManager.SecurityProtocol = SecurityProtocolType.Tls12;
2 收到内容为空白
服务器繁忙,请把deepseek-chat模型切换到deepseek-reasoner 试试,或者换个时间再次尝试.
模型区别如下.代码中默认使用了reasoner模型,俗称满血版.
默认账户赠送10元余额.
到此这篇关于使用C# 调用deepseek api接口,来实现正常访问的文章就介绍到这了,更多相关C# 调用deepseek api内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!