0

0

FFH—AI作诗之HttpRequest实战

王林

王林

发布时间:2023-05-02 19:19:04

|

2313人浏览过

|

来源于51CTO.COM

转载

☞☞☞AI 智能聊天, 问答助手, AI 智能搜索, 免费无限量使用 DeepSeek R1 模型☜☜☜

FFH—AI作诗之HttpRequest实战

​想了解更多关于开源的内容,请访问:​

​51CTO 开源基础软件社区​

​https://ost.51cto.com​

前言

最近在一个网课上看到了一个AI作诗的接口,因为之前的fetch接口已经不再维护了,所以我就借这个机会想试试鸿蒙的http接口。接下来会重新复习一下http请求的一些基本知识,并且跟大家一起实现一个简单的AI写诗的demo实际操练一下鸿蒙的http请求。

Demo展示

FFH—AI作诗之HttpRequest实战

http接口常识补充

内容类型(Content-Type)

内容类型(Content-Type)的作用就是告诉客户端返回内容的内容类型,各种Content-Type对应的格式如下:

Content-Type

对应格式

text/html

HTML格式

text/plain

纯文本格式

text/xml

XML格式

image/gif

gif图片格式

image/jpeg

jpg图片格式

image/png

png图片格式

application/xhtml+xml

XHTML格式

application/xml

XML数据格式

application/atom+xml

Atom XML聚合格式

application/json

JSON数据格式

application/pdf

pdf格式

application/msword

Word文档格式

application/octet-stream

二进制流数据(如常见的文件下载)

application/x-www-form-urlencoded

form表单数据被编码为key/value格式发送到服务器(表单默认的提交数据的格式)

multipart/form-data

需要在表单中进行文件上传时,就需要使用该格式

响应状态码(ResponseCode)

每次接口请求,服务器都会返回一个响应状态码,每一个状态码都有不同的意思。

名称

说明

OK

200

请求成功。一般用于GET与POST请求。

CREATED

201

已创建。成功请求并创建了新的资源。

ACCEPTED

202

已接受。已经接受请求,但未处理完成。

NOT_AUTHORITATIVE

203

非授权信息。请求成功。

NO_CONTENT

204

无内容。服务器成功处理,但未返回内容。

RESET

205

重置内容。

PARTIAL

206

部分内容。服务器成功处理了部分GET请求。

MULT_CHOICE

300

多种选择。

MOVED_PERM

301

永久移动。请求的资源已被永久的移动到新URI,返回信息会包括新的URI,浏览器会自动定向到新URI。

MOVED_TEMP

302

临时移动。

SEE_OTHER

303

查看其它地址。

NOT_MODIFIED

304

未修改。

USE_PROXY

305

使用代理。

Magician
Magician

Figma插件,AI生成图标、图片和UX文案

下载

BAD_REQUEST

400

客户端请求的语法错误,服务器无法理解。

UNAUTHORIZED

401

请求要求用户的身份认证。

PAYMENT_REQUIRED

402

保留,将来使用。

FORBIDDEN

403

服务器理解请求客户端的请求,但是拒绝执行此请求。

NOT_FOUND

404

服务器无法根据客户端的请求找到资源(网页)。

BAD_METHOD

405

客户端请求中的方法被禁止。

NOT_ACCEPTABLE

406

服务器无法根据客户端请求的内容特性完成请求。

PROXY_AUTH

407

请求要求代理的身份认证。

CLIENT_TIMEOUT

408

请求时间过长,超时。

CONFLICT

409

服务器完成客户端的PUT请求是可能返回此代码,服务器处理请求时发生了冲突。

GONE

410

客户端请求的资源已经不存在。

LENGTH_REQUIRED

411

服务器无法处理客户端发送的不带Content-Length的请求信息。

PRECON_FAILED

412

客户端请求信息的先决条件错误。

ENTITY_TOO_LARGE

413

由于请求的实体过大,服务器无法处理,因此拒绝请求。

REQ_TOO_LONG

414

请求的URI过长(URI通常为网址),服务器无法处理。

UNSUPPORTED_TYPE

415

服务器无法处理请求的格式。

INTERNAL_ERROR

500

服务器内部错误,无法完成请求。

NOT_IMPLEMENTED

501

服务器不支持请求的功能,无法完成请求。

BAD_GATEWAY

502

充当网关或代理的服务器,从远端服务器接收到了一个无效的请求。

UNAVAILABLE

503

由于超载或系统维护,服务器暂时的无法处理客户端的请求。

GATEWAY_TIMEOUT

504

充当网关或代理的服务器,未及时从远端服务器获取请求。

VERSION

505

服务器请求的HTTP协议的版本。

代码实现

1、申请网络权限

在config.json文件里面注册网络权限,该权限允许程序打开网络套接字,进行网络连接。

"reqPermissions": [
{
"name": "ohos.permission.INTERNET"
}
]

2、导入http模块

import http from '@ohos.net.http';

3、创建HttpRequest对象

这里调用createHttp()创建一个HttpRequest对象后,要注意每一个httpRequest对应一个http请求任务,不可复用,也就是说每发起一次网络请求,都要创建一个新的HttpRequest对象,当执行完该次请求之后,就会自动销毁该对象。

let httpRequest = http.createHttp();

4、编写request接口

httpRequest.request(
"https://py.myie9.com/cangtoutest/"+this.poemHead,
{
header: {
'Content-Type': 'text/plain'
},
readTimeout: 10000,
connectTimeout: 10000
}, (err, data) => {
if (!err) {
console.info("xxx--- "+JSON.stringify(data))
this.aiResult = data.result;
} else {
console.info('xxx--- error:' + JSON.stringify(err));
}
})

至此就完成了一次简单的http请求啦。

后面还可以对请求进行封装,暴露出需要变更的几个参数即可,比如method,Content-Type等等,后面再找时间写一篇http请求封装的博客。

5、藏头诗部分完整代码

js代码:

import http from '@ohos.net.http';
import router from '@system.router';
// 每一个httpRequest对应一个http请求任务,不可复用
let httpRequest = http.createHttp();

export default {
data: {
poemHead:"123",
aiResult:"请在上方输入符合要求的字段"
},
onInit() {
},
back(){
router.back()
},
hideHeadPoem() {
httpRequest = http.createHttp();
httpRequest.request(
"https://py.myie9.com/cangtoutest/"+this.poemHead,
{
header: {
'Content-Type': 'text/plain'
},
readTimeout: 10000,
connectTimeout: 10000
}, (err, data) => {
if (!err) {
console.info("xxx--- "+JSON.stringify(data))
this.aiResult = data.result;
} else {
console.info('xxx--- error:' + JSON.stringify(err));
}
})
},
check1(e){
console.log("xxx---"+JSON.stringify(e.value))
this.poemHead = e.value.poemHead
this.hideHeadPoem();
}
}

css代码:

.container {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
left: 0px;
top: 0px;
width: 100%;
height: 100%;
}
.title {
font-size: 60px;
text-align: center;
width: 100%;
height: 40%;
margin: 10px;
}
.display{
justify-content: center;
align-items: center;
width: 80%;
height: 35%;
border-radius: 20px;
background-color: #fff5f1f1;
opacity: 0.8;
box-shadow: 10px 10px 5px #888888;
}
.subButton{
width: 250px;
margin-left: 25%;
background-color:#ffa5552f;
margin-top: 5%;
}
.subButton2{
width: 250px;
height: 70px;
margin-left: 25%;
background-color:#ffa5552f;
margin-top: 2%;
}

hml代码:

<div class="container">
<form class="container" onsubmit='check1'>
<input style="width:80%;height:10%;margin-top: 15%;" type="text" placeholder="请输入要生成藏头诗的句子" name='poemHead'>input>
<div class="display" style="margin-top: 15%;">
<text style="margin: 40px;font-size: 38px;">
{{aiResult}}
text>
div>
<input class="subButton" type='submit'>生成藏头诗input>
<button class="subButton2" onclick="back">返回button>
form>
<image src="../../common/123.png" style="z-index: -1; position: fixed;width: 100%;height: 100%;">image>
div>

完整的demo代码请看附件:

https://ost.51cto.com/resource/2180。

​想了解更多关于开源的内容,请访问:​

​51CTO 开源基础软件社区​

​https://ost.51cto.com​​。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
clawdbot ai使用教程 保姆级clawdbot部署安装手册
clawdbot ai使用教程 保姆级clawdbot部署安装手册

Clawdbot是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

18

2026.01.29

clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址
clawdbot龙虾机器人官网入口 clawdbot ai官方网站地址

clawdbot龙虾机器人官网入口:https://clawd.bot/,clawdbot ai是一个“有灵魂”的AI助手,可以帮用户清空收件箱、发送电子邮件、管理日历、办理航班值机等等,并且可以接入用户常用的任何聊天APP,所有的操作均可通过WhatsApp、Telegram等平台完成,用户只需通过对话,就能操控设备自动执行各类任务。

12

2026.01.29

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

8

2026.01.29

俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

566

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

205

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

340

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

11

2026.01.28

php中文乱码如何解决
php中文乱码如何解决

本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

16

2026.01.28

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

11

2026.01.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
【web前端】Node.js快速入门
【web前端】Node.js快速入门

共16课时 | 2万人学习

Go语言实战之 GraphQL
Go语言实战之 GraphQL

共10课时 | 0.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号