我有2个类似的网络表单,可以将数据发布到我的java应用程序中。 两个单独的函数处理此POST请求,但它们完全相同。 但是,一种形式POST成功,而另一种形式没有,并抛出HTTP 405错误。
包含HTML表单代码:
<form action="BiApi/a/b" method="post" id="formquery" name= "makeQuery">
<!----Text Boxes---->
<input type="submit" value="Query" onclick="if(this.value=='Query'){ this.value='Wait processing query...'; this.style.color='#000';}"/>
</form>
处理请求的Java函数
@POST
@Path("/b")
@Produces({"text/csv"})
public String b(
@FormParam("reportType") int reportType,
@FormParam("preStart") String preStart,
@FormParam("preEnd") String preEnd
){
try {
CampaignQueryDto campaignQueryDto = new CampaignQueryDto();
campaignQueryDto.setReportType(reportType);
campaignQueryDto.setPreEnd(preEnd);
campaignQueryDto.setPreStart(preStart);
if (campaignQueryDto.isAuthorized()) {
return csvForDto(campaignDao.xyz(campaignQueryDto));
} else {
throw new UnauthorizedException();
}
} catch (SQLException ex) {
throw new WebApplicationException(404);
}
}
/*..Method 2 ..*/
@POST
@Path("/bUK")
@Produces({"text/csv"})
public String bUK(
@FormParam("reportType") int reportType,
@FormParam("preStart") String preStart,
@FormParam("preEnd") String preEnd){
try {
CampaignQueryDto campaignQueryDto = new CampaignQueryDto();
campaignQueryDto.setReportType(reportType);
campaignQueryDto.setPreEnd(preEnd);
campaignQueryDto.setPreStart(preStart);
if (campaignQueryDto.isAuthorized()) {
return csvForDto(campaignDao.xyzUK(campaignQueryDto));
} else {
throw new UnauthorizedException();
}
} catch (SQLException ex) {
throw new WebApplicationException(404);
}
}
我的web.xml
<web-app id="WebApp_ID" version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>abc</display-name>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<servlet>
<servlet-name>jersey-serlvet</servlet-name>
<servlet-class>com.sun.jersey.spi.spring.container.servlet.SpringServlet</servlet-class>
<init-param>
<param-name>com.sun.jersey.config.property.packages</param-name>
<param-value>com.argusinformation.rest</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>jersey-serlvet</servlet-name>
<url-pattern>/BiApi/*</url-pattern>
</servlet-mapping>
2个表单代码的唯一区别是Java函数的名称。即如果一个是b,那么另一个是bUK。
一个人返回结果,而另一个人在提交表格后发出405错误。
任何可能的解决方案?
谢谢!
答案 0 :(得分:0)
正如SachinSarawgi所提到的那样 - 您能否至少向我们提供您使用的两种方法(根据整体版权政策和/或应用程序源代码的机密性等,不允许您提供其完整版本)?
EDIT。您好像忘记在第一个方法的代码中添加campaignQueryDto.setReportType(reportType);
行。修复它应该会有所帮助。