【Web后端】java发起HTTP请求

引入依赖

<dependency>
    <groupId>org.apache.httpcomponents</groupId>
    <artifactId>httpclient</artifactId>
    <version>4.5.2</version>
</dependency>

导入jar包

import com.alibaba.fastjson.JSONObject;
import org.apache.http.HttpEntity;
import org.apache.http.HttpResponse;
import org.apache.http.HttpStatus;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.client.methods.HttpGet;
import org.apache.http.client.methods.HttpPost;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClientBuilder;
import org.apache.http.message.BasicHeader;
import org.apache.http.protocol.HTTP;
import org.apache.http.util.EntityUtils;

发起HTTP请求

get方法

String url = "url";
//创建HttpClient对象
CloseableHttpClient httpClient = HttpClientBuilder.create().build();
HttpGet httpGet = new HttpGet(url);
try {
    HttpResponse response = httpClient.execute(httpGet);
    //HttpStatus.SC_OK = 200
    if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {
        JSONObject obj = JSONObject.parseObject(res);
        System.out.println(obj);
    }
} catch (IOException e) {
    e.printStackTrace();
}

post方法

JSONObjcet result = new JSONObject();

// 创建HttpPost对象,设置URL地址
HttpPost httpPost=new HttpPost(URL);

// 封装参数
JSONObject param = new JSONObject();
param.put("name","tom");

//装填参数
StringEntity entity = new StringEntity(param.toString(), "utf-8");
entity .setContentEncoding(new BasicHeader(HTTP.CONTENT_TYPE,"application/json"));

//设置参数到请求对象中
httpPost.setEntity(entity);

//设置报头
httpPost.setHeader("Content-type", "application/json");

try{
    //执行请求操作,并拿到结果(同步阻塞)
    CloseableHttpResponse response = httpClient.execute(httpPost);
    //获取结果实体
    HttpEntity entity = response.getEntity();
    if (entity != null) {
        //按指定编码转换结果实体为String类型
        String res = EntityUtils.toString(entity, "UTF-8");
        result= JSONObject.parseObject(res);
    }
    //释放链接
    response.close();
}catch (IOException e) {
    e.printStackTrace();
}

return result;

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,那么接下来我将介绍如何使用 Java 实现后端接口,返回子级菜单的选项。 1. 首先,你需要搭建 Java Web 项目。可以使用一些常见的框架,比如 Spring、Spring Boot、Struts 等。这里以 Spring Boot 为例,介绍如何实现子级菜单选项的接口。 2. 在 Spring Boot 项目中,可以使用 @RestController 注解来定义一个基于 RESTful 风格的接口。例如: ```java @RestController public class ChildOptionsController { @GetMapping("/get-child-options") public List<ChildOption> getChildOptions(@RequestParam("parent_id") String parentId) { // 根据 parentId 查询子级菜单选项,并返回结果 List<ChildOption> childOptions = new ArrayList<>(); if ("1".equals(parentId)) { childOptions.add(new ChildOption("11", "选项11")); childOptions.add(new ChildOption("12", "选项12")); childOptions.add(new ChildOption("13", "选项13")); } else if ("2".equals(parentId)) { childOptions.add(new ChildOption("21", "选项21")); childOptions.add(new ChildOption("22", "选项22")); childOptions.add(new ChildOption("23", "选项23")); } else if ("3".equals(parentId)) { childOptions.add(new ChildOption("31", "选项31")); childOptions.add(new ChildOption("32", "选项32")); childOptions.add(new ChildOption("33", "选项33")); } return childOptions; } static class ChildOption { private String id; private String name; public ChildOption(String id, String name) { this.id = id; this.name = name; } public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } } } ``` 在上述代码中,我们使用 @GetMapping 注解来定义 GET 请求的接口,接口路径为 /get-child-options。该接口接收一个名为 parent_id 的参数,用于获取相应的子级菜单选项。根据不同的 parent_id 值,我们可以返回不同的子级菜单选项。 3. 接下来,你需要在前端代码中使用 AJAX 技术,请求后端接口,获取子级菜单选项。代码示例如下: ```javascript document.getElementById('parent').onchange = function () { var parentId = this.value; if (parentId) { var xhr = new XMLHttpRequest(); xhr.open('GET', '/get-child-options?parent_id=' + parentId); xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200) { var childOptions = JSON.parse(xhr.responseText); var childSelect = document.getElementById('child'); childSelect.innerHTML = ''; childSelect.options.add(new Option('请选择', '')); for (var i = 0; i < childOptions.length; i++) { childSelect.options.add(new Option(childOptions[i].name, childOptions[i].id)); } } }; xhr.send(); } else { var childSelect = document.getElementById('child'); childSelect.innerHTML = ''; childSelect.options.add(new Option('请选择', '')); } }; ``` 与之前的示例代码相同,我们使用 XMLHttpRequest 对象发起 GET 请求请求后端接口 /get-child-options,并将 parent_id 参数传递给后端。当接收到后端返回的响应时,我们将其解析成 JavaScript 对象,并更新子级菜单的选项。 至此,我们已经介绍了如何使用 Java 实现后端接口,返回子级菜单的选项。需要注意的是,这只是一个简单的示例代码,你需要根据实际需求进行相应的修改和优化。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Cimoon_

一分也是爱,用钱砸我

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

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

打赏作者

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

抵扣说明:

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

余额充值