- 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/
SQLite、Content provider 和 Shared Preference 之间的所有已知区别。 但我想知道什么时候需要根据情况使用 SQLite 或 Content Provider 或
警告:我正在使用一个我无法完全控制的后端,所以我正在努力解决 Backbone 中的一些注意事项,这些注意事项可能在其他地方更好地解决......不幸的是,我别无选择,只能在这里处理它们! 所以,我的
我一整天都在挣扎。我的预输入搜索表达式与远程 json 数据完美配合。但是当我尝试使用相同的 json 数据作为预取数据时,建议为空。点击第一个标志后,我收到预定义消息“无法找到任何内容...”,结果
我正在制作一个模拟 NHL 选秀彩票的程序,其中屏幕右侧应该有一个 JTextField,并且在左侧绘制弹跳的选秀球。我创建了一个名为 Ball 的类,它实现了 Runnable,并在我的主 Draf
这个问题已经有答案了: How can I calculate a time span in Java and format the output? (18 个回答) 已关闭 9 年前。 这是我的代码
我有一个 ASP.NET Web API 应用程序在我的本地 IIS 实例上运行。 Web 应用程序配置有 CORS。我调用的 Web API 方法类似于: [POST("/API/{foo}/{ba
我将用户输入的时间和日期作为: DatePicker dp = (DatePicker) findViewById(R.id.datePicker); TimePicker tp = (TimePic
放宽“邻居”的标准是否足够,或者是否有其他标准行动可以采取? 最佳答案 如果所有相邻解决方案都是 Tabu,则听起来您的 Tabu 列表的大小太长或您的释放策略太严格。一个好的 Tabu 列表长度是
我正在阅读来自 cppreference 的代码示例: #include #include #include #include template void print_queue(T& q)
我快疯了,我试图理解工具提示的行为,但没有成功。 1. 第一个问题是当我尝试通过插件(按钮 1)在点击事件中使用它时 -> 如果您转到 Fiddle,您会在“内容”内看到该函数' 每次点击都会调用该属
我在功能组件中有以下代码: const [ folder, setFolder ] = useState([]); const folderData = useContext(FolderContex
我在使用预签名网址和 AFNetworking 3.0 从 S3 获取图像时遇到问题。我可以使用 NSMutableURLRequest 和 NSURLSession 获取图像,但是当我使用 AFHT
我正在使用 Oracle ojdbc 12 和 Java 8 处理 Oracle UCP 管理器的问题。当 UCP 池启动失败时,我希望关闭它创建的连接。 当池初始化期间遇到 ORA-02391:超过
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 9 年前。 Improve
引用这个plunker: https://plnkr.co/edit/GWsbdDWVvBYNMqyxzlLY?p=preview 我在 styles.css 文件和 src/app.ts 文件中指定
为什么我的条形这么细?我尝试将宽度设置为 1,它们变得非常厚。我不知道还能尝试什么。默认厚度为 0.8,这是应该的样子吗? import matplotlib.pyplot as plt import
当我编写时,查询按预期执行: SELECT id, day2.count - day1.count AS diff FROM day1 NATURAL JOIN day2; 但我真正想要的是右连接。当
我有以下时间数据: 0 08/01/16 13:07:46,335437 1 18/02/16 08:40:40,565575 2 14/01/16 22:2
一些背景知识 -我的 NodeJS 服务器在端口 3001 上运行,我的 React 应用程序在端口 3000 上运行。我在 React 应用程序 package.json 中设置了一个代理来代理对端
我面临着一个愚蠢的问题。我试图在我的 Angular 应用程序中延迟加载我的图像,我已经尝试过这个2: 但是他们都设置了 src attr 而不是 data-src,我在这里遗漏了什么吗?保留 d
我是一名优秀的程序员,十分优秀!