java发起HTTP 请求的多种方式,常用的类为 cn.hutool.http.HttpUtil
但方式有限,需加工,可根据实际情况进行选择
参数多为json格式字符串,先讲几个对象或者转json字符串的方式
1.对象转json串
String data = JSONObject.toJSONString(bo);
2.拼接json字符串
String data = JSONObject.toJSONString(new HashMap<Object, Object>(1) {{ put("param1", new String[]{"123123"});
put("param2",1231);
put("param3","dss");
put("param4","asdad");
}});
String data = JSONObject.toJSONString(new HashMap<Object, Object>(3) {{
put("name", "zhang****");
put("user_id", "1101238723826918");
put("cards", new JSONObject(new HashMap<String, Object>(2) {{
put("type", "ID");
put("id", "32428269134582");
}}
).toJSONString());
}});
开始请求,以cn.hutool.http.*为例
1.post请求,参数1为请求路径,参数2默认为json格式字符串
String result = HttpUtil.post("url","data");2.get请求,参数为url,可选多参数,设置参数或超时时间等
String result = HttpUtil.get("url");
3.添加请求头headers的的post请求
Map<String,String> headerMap = new HashMap<>();
headerMap.put("Content-Type","application/json");
...............
String result=HttpRequest.post("url").addHeaders(headerMap).body(data).execute().body();
4.delete put请求为封装的工具类,如下
package ;
import com.aliyun.oss.common.comm.HttpDeleteWithBody;
import org.apache.commons.lang3.StringUtils;
import org.apache.http.HttpEntity;
import org.apache.http.client.methods.CloseableHttpResponse;
import org.apache.http.entity.StringEntity;
import org.apache.http.impl.client.CloseableHttpClient;
import org.apache.http.impl.client.HttpClients;
import org.apache.http.util.EntityUtils;
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.charset.Charset;
import java.util.Base64;
/**
* @author
* @title: HttpClientUtil 处理cn.hutool.http.HttpUtil post get外的其他请求方式 delete put 等
* @description: TODO
* @date
*/
public class HttpClientUtil {
/**
* 功能描述: delete
*
* @Param: [data, url]
* @Return: java.lang.String
*/
public static String doDelete(String url, String data) throws IOException {
CloseableHttpClient client = null;
HttpDeleteWithBody httpDelete = null;
String result = null;
try {
client = HttpClients.createDefault();
httpDelete = new HttpDeleteWithBody(url);
httpDelete.addHeader("Content-type", "application/json; charset=utf-8");
httpDelete.setHeader("Accept", "application/json; charset=utf-8");
httpDelete.setEntity(new StringEntity(data));
CloseableHttpResponse response = client.execute(httpDelete);
HttpEntity entity = response.getEntity();
result = EntityUtils.toString(entity);
} catch (Exception e) {
} finally {
client.close();
}
return result;
}
public static String doPut(String urlPath, String data, String charSet, String[] header) {
String result = null;
URL url = null;
HttpURLConnection httpurlconnection = null;
try {
url = new URL(urlPath);
httpurlconnection = (HttpURLConnection) url.openConnection();
httpurlconnection.setDoInput(true);
httpurlconnection.setDoOutput(true);
httpurlconnection.setConnectTimeout(5000);// 设置连接主机超时(单位:毫秒)
httpurlconnection.setReadTimeout(5000);// 设置从主机读取数据超时(单位:毫秒)
if (header != null) {
for (int i = 0; i < header.length; i++) {
String[] content = header[i].split(":");
httpurlconnection.setRequestProperty(content[0], content[1]);
}
}
httpurlconnection.setRequestMethod("PUT");
httpurlconnection.setRequestProperty("Content-Type", "application/json;charset=utf-8");
// httpurlconnection.setRequestProperty("Content-Type", "application/x-www-form-urlencoded");
if (StringUtils.isNotBlank(data)) {
httpurlconnection.getOutputStream().write(data.getBytes("UTF-8"));
}
httpurlconnection.getOutputStream().flush();
httpurlconnection.getOutputStream().close();
int code = httpurlconnection.getResponseCode();
if (code == 200) {
DataInputStream in = new DataInputStream(httpurlconnection.getInputStream());
int len = in.available();
byte[] by = new byte[len];
in.readFully(by);
if (StringUtils.isNotBlank(charSet)) {
result = new String(by, Charset.forName(charSet));
} else {
result = new String(by);
}
in.close();
} else {
System.out.println("请求地址:" + urlPath + "返回状态异常,异常号为:" + code);
}
} catch (Exception e) {
System.out.println("访问url地址:" + urlPath + "发生异常");
} finally {
url = null;
if (httpurlconnection != null) {
httpurlconnection.disconnect();
}
}
return result;
}
}
我试图获取一个长度在1到10之间的字符串,并输出将字符串分解为大小为1、2或3的连续子字符串的所有可能方式。例如:输入:123456将整数分割成单个字符,然后继续查找组合。该代码将返回以下所有数组。[1,2,3,4,5,6][12,3,4,5,6][1,23,4,5,6][1,2,34,5,6][1,2,3,45,6][1,2,3,4,56][12,34,5,6][12,3,45,6][12,3,4,56][1,23,45,6][1,2,34,56][1,23,4,56][12,34,56][123,4,5,6][1,234,5,6][1,2,345,6][1,2,3,456][123
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
是的,我知道最好使用webmock,但我想知道如何在RSpec中模拟此方法:defmethod_to_testurl=URI.parseurireq=Net::HTTP::Post.newurl.pathres=Net::HTTP.start(url.host,url.port)do|http|http.requestreq,foo:1endresend这是RSpec:let(:uri){'http://example.com'}specify'HTTPcall'dohttp=mock:httpNet::HTTP.stub!(:start).and_yieldhttphttp.shou
在我的Controller中,我通过以下方式在我的index方法中支持HTML和JSON:respond_todo|format|format.htmlformat.json{renderjson:@user}end在浏览器中拉起它时,它会自然地以HTML呈现。但是,当我对/user资源进行内容类型为application/json的curl调用时(因为它是索引方法),我仍然将HTML作为响应。如何获取JSON作为响应?我还需要说明什么? 最佳答案 您应该将.json附加到请求的url,提供的格式在routes.rb的路径中定义。这
我真的很习惯使用Ruby编写以下代码:my_hash={}my_hash['test']=1Java中对应的数据结构是什么? 最佳答案 HashMapmap=newHashMap();map.put("test",1);我假设? 关于java-等价于Java中的RubyHash,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/22737685/
question的一些答案关于redirect_to让我想到了其他一些问题。基本上,我正在使用Rails2.1编写博客应用程序。我一直在尝试自己完成大部分工作(因为我对Rails有所了解),但在需要时会引用Internet上的教程和引用资料。我设法让一个简单的博客正常运行,然后我尝试添加评论。靠我自己,我设法让它进入了可以从script/console添加评论的阶段,但我无法让表单正常工作。我遵循的其中一个教程建议在帖子Controller中创建一个“评论”操作,以添加评论。我的问题是:这是“标准”方式吗?我的另一个问题的答案之一似乎暗示应该有一个CommentsController参
rails中是否有任何规定允许站点的所有AJAXPOST请求在没有authenticity_token的情况下通过?我有一个调用Controller方法的JqueryPOSTajax调用,但我没有在其中放置任何真实性代码,但调用成功。我的ApplicationController确实有'request_forgery_protection'并且我已经改变了config.action_controller.consider_all_requests_local在我的environments/development.rb中为false我还搜索了我的代码以确保我没有重载ajaxSend来发送
我正在尝试使用boilerpipe来自JRuby。我看过guide从JRuby调用Java,并成功地将它与另一个Java包一起使用,但无法弄清楚为什么同样的东西不能用于boilerpipe。我正在尝试基本上从JRuby中执行与此Java等效的操作:URLurl=newURL("http://www.example.com/some-location/index.html");Stringtext=ArticleExtractor.INSTANCE.getText(url);在JRuby中试过这个:require'java'url=java.net.URL.new("http://www
我目前正在使用以下方法获取页面的源代码:Net::HTTP.get(URI.parse(page.url))我还想获取HTTP状态,而无需发出第二个请求。有没有办法用另一种方法做到这一点?我一直在查看文档,但似乎找不到我要找的东西。 最佳答案 在我看来,除非您需要一些真正的低级访问或控制,否则最好使用Ruby的内置Open::URI模块:require'open-uri'io=open('http://www.example.org/')#=>#body=io.read[0,50]#=>"["200","OK"]io.base_ur
是否可以为特定(或所有)项目使用多个布局?例如,我有几个项目,我想对其应用两种不同的布局。一个是绿色的,一个是蓝色的(但是)。我想将它们编译到我的输出目录中的两个不同文件夹中(例如v1和v2)。我一直在玩弄规则和编译block,但我不知道这是怎么回事。因为,每个项目在编译过程中只编译一次,我不能告诉nanoc第一次用layout1编译,第二次用layout2编译。我试过这样的东西,但它导致输出文件损坏。compile'*'doifitem.binary?#don’tfilterbinaryitemselsefilter:erblayout'layout1'layout'layout2'