- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将一些 JSON 数据发布到 RESTful spring Controller 。但得到“400 Bad Request”作为响应状态。
给出我为此使用的关键配置文件中的以下代码:
pom.xml 依赖项:
enter code here <properties>
<org.springframework-version>4.1.4.RELEASE</org.springframework-version>
</properties>
<!-- Spring -->
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>${org.springframework-version}</version>
<exclusions>
<!-- Exclude Commons Logging in favor of SLF4j -->
<exclusion>
<groupId>commons-logging</groupId>
<artifactId>commons-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-webmvc</artifactId>
<version>${org.springframework-version}</version>
</dependency>
<!-- Servlet -->
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>servlet-api</artifactId>
<version>2.5</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet.jsp</groupId>
<artifactId>jsp-api</artifactId>
<version>2.1</version>
<scope>provided</scope>
</dependency>
<dependency>
<groupId>javax.servlet</groupId>
<artifactId>jstl</artifactId>
<version>1.2</version>
</dependency>
<!-- json -->
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-core</artifactId>
<version>2.4.1</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.4.1.1</version>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-core-asl</artifactId>
<version>1.9.13</version>
</dependency>
<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.13</version>
</dependency>
调度程序-servlet.xml:
<beans:bean
class="org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerAdapter">
<beans:property name="messageConverters">
<beans:list>
<beans:ref bean="jsonConverter" />
<!-- <ref bean="marshallingConverter" /> <ref bean="atomConverter" /> -->
</beans:list>
</beans:property>
</beans:bean>
<beans:bean id="jsonConverter"
class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
<beans:property name="supportedMediaTypes" value="application/json" />
</beans:bean>
Controller 类:
@Controller
@RequestMapping("/api/beacons")
public class APIController {
private static final Logger logger = LoggerFactory.getLogger(APIController.class);
@Autowired
BeaconService beaconService;
@RequestMapping(method = RequestMethod.GET, produces = "application/json")
@ResponseBody
public List<BeaconVO> listAllBeacons() {
logger.info("/api/beacon GET");
List beacons = beaconService.findList(new BeaconVO());
return beacons;
}
@RequestMapping(method = RequestMethod.POST, consumes = "application/json")
// @ResponseStatus(HttpStatus.NO_CONTENT)
@ResponseBody
public BeaconVO saveBeacon(@RequestBody BeaconVO beaconVO) {
logger.info("/api/beacon POST");
beaconService.register(beaconVO);
return beaconVO;
}
请求详细信息:
URL:http: // localhost:8080/test/api/beacons
Method:
POST
Headers:Accept:application/
json
Payload:
{
"no": 1 ,
"uuid": "123"
}
BeaconVO:
public class BeaconVO {
private int no;
private String uuid;
public int getNo() {
return no;
}
public void setNo(int no) {
this.no = no;
}
public String getUuid() {
return uuid;
}
public void setUuid(String uuid) {
this.uuid = uuid;
}
}
客户端代码(android)
public class MainActivity extends Activity {
private static final String URL = "http://192.168.1.24:8080/test/api/beacons";
Button btnGet, btnPost;
TextView tv;
JSONObject json;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
btnGet = (Button) findViewById(R.id.btnGet);
btnPost = (Button) findViewById(R.id.btnPost);
tv = (TextView) findViewById(R.id.tv);
btnGet.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
new Thread(new Runnable() {
@Override
public void run() {
// TODO Auto-generated method stub
try {
String jsonData = getJSONData(URL, "GET");
if (jsonData == null || jsonData.isEmpty()) {
return;
}
JSONArray jsonArray = new JSONArray(jsonData);
json = jsonArray.getJSONObject(0);
StringBuilder sb = new StringBuilder();
sb.append("no / UUID\n");
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject jsonObject = (JSONObject) jsonArray.get(i);
sb.append(jsonObject.getString("no") + " / " + jsonObject.getString("uuid"));
sb.append("\n");
}
setText(json.toString(), false);
} catch (JSONException e) {
// TODO Auto-generated catch block
e.printStackTrace();
setText(e.toString(), true);
}
}
}).start();
}
});
btnPost.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
new Thread(new Runnable() {
@Override
public void run() {
// setJSONData(URL, "POST", json.toString());
POST(URL, json.toString());
}
}).start();
}
});
}
public void POST(String strUrl, String jsonData) {
try {
URL url = new URL(strUrl);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setConnectTimeout(5000);// 5 secs
connection.setReadTimeout(5000);// 5 secs
connection.setRequestMethod("POST");
connection.setDoOutput(true);
connection.setRequestProperty("Content-Type", "application/json");
InputStream is = null;
int status = connection.getResponseCode();
if (status >= HttpURLConnection.HTTP_BAD_REQUEST) {
is = connection.getErrorStream();
} else {
is = connection.getInputStream();
}
if (connection.getResponseCode() != 200) {
throw new RuntimeException("Failed : HTTP error code : " + connection.getResponseCode());
}
OutputStreamWriter out = new OutputStreamWriter(connection.getOutputStream());
out.write(jsonData);
out.flush();
out.close();
BufferedReader br = new BufferedReader(new InputStreamReader(is));
String line = null;
while ((line = br.readLine()) != null) {
System.out.println(line);
}
connection.disconnect();
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
setText(e.toString(), true);
}
}
private String getJSONData(String url, String method) {
try {
InputStream is = getInputStream(url, method);
BufferedReader br = new BufferedReader(new InputStreamReader(is));
StringBuilder sb = new StringBuilder();
int bufferSize = 1024 * 1024;
char[] readBuf = new char[bufferSize];
int resultSize = 0;
while ((resultSize = br.read(readBuf)) != -1) {
if (resultSize == bufferSize) {
sb.append(readBuf);
} else {
for (int i = 0; i < resultSize; i++) {
sb.append(readBuf[i]);
}
}
}
final String jsonData = sb.toString();
setText(jsonData, false);
is.close();
return jsonData;
} catch (Exception e) {
e.printStackTrace();
setText(e.toString(), true);
return null;
}
}
private InputStream getInputStream(String strUrl, String method) {
InputStream is;
try {
log("getInputStream(" + strUrl + ", " + method + ")");
URL url = new URL(strUrl);
HttpURLConnection connection = (HttpURLConnection) url.openConnection();
connection.setRequestMethod(method);
connection.setRequestProperty("Accept", "application/json");
int status = connection.getResponseCode();
if (status >= HttpURLConnection.HTTP_BAD_REQUEST) {
is = connection.getErrorStream();
} else {
is = connection.getInputStream();
}
if (connection.getResponseCode() != 200) {
throw new RuntimeException("Failed : HTTP error code : " + connection.getResponseCode());
}
} catch (Exception e) {
e.printStackTrace();
setText(e.toString(), true);
return null;
}
return is;
}
StringBuilder sb = new StringBuilder();
private void setText(final String msg, final boolean isError) {
runOnUiThread(new Runnable() {
@Override
public void run() {
if (isError) {
sb.append(msg);
sb.append("\n");
tv.setText("\n-------------------\n"+sb.toString());
} else {
tv.setText(msg);
}
}
});
}
}
请帮助我。
最佳答案
有效负载主体可能无法设置(映射)到 BeaconVO 对象。
关于java - 400 错误请求 - 将 JSON 数据发布到 RESTful Controller 时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42339415/
我们正在使用 VSTS 构建和发布通过 Xamarin 创建的 iOS 和 Android 应用程序。通过 VSTS 将 Android 应用发布到商店相对简单。有人可以指导我或提供一些如何通过 VS
我一直在研究 Spring Social Facebook 的 publish(objectId, connectionName, data) API ,但不确定此 API 的用法(遗憾的是,由于缺少
我正在使用 django viewflow 创建一个发布流程: 用户创建对象 它进入审核流程,其状态为待处理(公众不可见) 经过审核和批准后,就会发布并公开可见。 如果用户编辑同一实体,则会再次进入审
我正在尝试进行 API 调用,并且 API 需要格式为 XML: Security GetSessionInfo 999999999999 0 2 {
我已经查看了所有 StackOverflow,但没有找到适合我的案例的解决方案我有 405 HttpStatusCode 调用 API/Regions/Create 操作这是我的 baseContro
如果我切换到新版本的SpringBoot,我在启动应用程序时会得到上面的错误信息。这是为什么? 最美好的祝愿史蒂文 pom.xml 4.0.0 de.xyz.microservice spring
我有一个场景,页面导航是从一个域到另一个域完成的。例如,导航是从 http://www.foo.com到 http://www.bar.com在 JavaScript 中单击按钮 重定向时,我需要将用
这半年来一直深耕包头,这个城市比较不错,但是推进项目的难度确实挺大的。与开发产品相比,后者更省心。但是光研发产品,没有项目
我正在阅读有关 Github 版本 的信息,它似乎很适合您的项目。因为我们需要决定将哪些功能用于生产,哪些不用于。 我无法理解的部分是,master 和 release 分支如何在其中发挥作用。 Sh
我将一些代码推送到远程存储库,然后在 GitHub 上创建了第一个版本,并将其命名为 'v0.0.1'。 GitHub 现在显示我现在有一个版本,并且还在“标签”中显示我有一个标签 “v0.0.1”。
如果我有一个具有以下文件/文件夹结构的 GitHub 存储库 github.com/@product/template: /build /fileA /fileB /src /genera
我有一个 Maven 多模块项目。 当代码开发完成后,我们想在 Jenkins 中编写一个分支构建作业,它分支代码,增加主干中的 pom 版本,并删除 -SNAPSHOT 来自分支中的 pom 版本。
我有一个非常大的集合(约 40000 个文档,包含约 20-25 个字段,包括包含一组约 500 个项目的数组字段)和约 2000 个订阅者(他们现在只是机器人)。 因此,当用户订阅整个集合(不包括服
如果我正在使用消息队列构建一个包含数十个发布者/订阅者的系统,那么我似乎有一些网络配置选项: 我可以拥有一个所有机器都使用的集群代理 - 每台机器都没有本地队列 我可以在每台机器上本地安装代理,并使用
我正在使用 Flash Develop,并且创建了一个 ActionScript 3.0 项目。它启动并读取一个 xml 文件,其中包含图像的 url。我已将 url 保留在与 swf 相同的文件夹中
如果我在一个句子中使用 alloc 和 retain 声明一个 NSArray 那么我应该释放 NSArray 对象两次(即[arrayObject release] 2次)? 最佳答案 如果您在同一
我正在尝试在 Node 中实现发布/订阅模式,但不使用 Redis。功能应该是相同的;您可以发布到 channel ,订阅 channel 并收听数据(如果您已订阅);以下是 Redis 功能: pu
编辑:这个问题、一些答案和一些评论,包含很多错误信息。见 how Meteor collections, publications and subscriptions work准确理解发布和订阅同一服
我正在开发一款 DirectX 游戏,我发现在发布版本中我的平均帧速率为 170fps,但是在调试版本中我的帧速率约为 20fps。 我想知道发布和调试版本之间的巨大差异是否正常,特别是因为在调试中我
是否有办法回滚 Windows Azure 网站和 SQL 部署/发布? 我发布了一个网站,现在它导致了很多错误,我想回到之前的状态并进一步处理代码。 这可能吗? 最佳答案 如果您使用 Git 或 T
我是一名优秀的程序员,十分优秀!