HTTP 405应用程序在Apache Tomcat上引发的错误

时间:2017-02-13 21:05:13

标签: java html tomcat

我有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错误。

任何可能的解决方案?

谢谢!

1 个答案:

答案 0 :(得分:0)

正如SachinSarawgi所提到的那样 - 您能否至少向我们提供您使用的两种方法(根据整体版权政策和/或应用程序源代码的机密性等,不允许您提供其完整版本)?

EDIT。您好像忘记在第一个方法的代码中添加campaignQueryDto.setReportType(reportType);行。修复它应该会有所帮助。