191

POSTリクエストをサーブレットに送信しようとしています。リクエストは次のようにjQuery経由で送信されます。

var productCategory = new Object();
productCategory.idProductCategory = 1;
productCategory.description = "Descrizione2";
newCategory(productCategory);

newCategoryは

function newCategory(productCategory)
{
  $.postJSON("ajax/newproductcategory", productCategory, function(
      idProductCategory)
  {
    console.debug("Inserted: " + idProductCategory);
  });
}

そしてpostJSONは

$.postJSON = function(url, data, callback) {
    return jQuery.ajax({
    'type': 'POST',
    'url': url,
    'contentType': 'application/json',
    'data': JSON.stringify(data),
    'dataType': 'json',
    'success': callback
    });
};

Firebugを使用すると、JSONが正しく送信されることがわかります。

{"idProductCategory":1,"description":"Descrizione2"}

しかし、私は415のサポートされていないメディアタイプを取得します。SpringMVCコントローラーには署名があります

    @RequestMapping(value = "/ajax/newproductcategory", method = RequestMethod.POST)
public @ResponseBody
Integer newProductCategory(HttpServletRequest request,
        @RequestBody ProductCategory productCategory)

数日前は機能していましたが、現在は機能していません。必要に応じて、さらにコードを表示します。ありがとう

4

15 に答える 15

266

これは以前にSpring@ResponseBodyで発生したことがありますが、これはリクエストとともに送信されたacceptヘッダーがなかったためです。Acceptヘッダーは、jQueryで設定するのが面倒な場合がありますが、これは私にとってはうまくいきました

$.postJSON = function(url, data, callback) {
    return jQuery.ajax({
    headers: { 
        'Accept': 'application/json',
        'Content-Type': 'application/json' 
    },
    'type': 'POST',
    'url': url,
    'data': JSON.stringify(data),
    'dataType': 'json',
    'success': callback
    });
};

Content-Typeヘッダーは、リクエストでクライアントから送信されるデータの形式を決定するために@RequestBodyによって使用されます。アクセプトヘッダーは@ResponseBodyによって使用され、応答でクライアントにデータを送り返す形式を決定します。そのため、両方のヘッダーが必要です。

于 2012-07-18T20:24:33.670 に答える
31

application/json問題を解決したときにコンテンツタイプをリクエストに追加する

于 2017-03-02T10:47:10.023 に答える
18

同様の問題が発生しましたが、@RequestBodyで注釈が付けられたDTOのデフォルトコンストラクターの提供を怠っていたことが問題であることがわかりました。

于 2013-04-03T06:45:34.010 に答える
15

私は同様の問題に直面しました、そしてこれは私がそれを修正した方法です、

この問題は、JSONからJavaへの変換プロセスが原因であり、変換を正しく行うには、適切なランタイムジャクソンライブラリが必要です。

次のjarを追加します(依存関係を介して、またはダウンロードしてクラスパスに追加します。

<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.13</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.5.3</version>
</dependency>

これで問題が解決するはずです。

完全なコード:

function() {
  $.ajax({
    type: "POST",
    url: "saveUserDetails.do",
    data: JSON.stringify({
      name: "Gerry",
      ity: "Sydney"
    }),
    headers: {
      'Accept': 'application/json',
      'Content-Type': 'application/json'
    },
    success: function(data) {
      if (data.status == 'OK')
        alert('Person has been added');
      else
        alert('Failed adding person: ' + data.status + ', ' + data.errorMessage);
}

コントローラの署名は次のようになります。

@RequestMapping(value = "/saveUserDetails.do", method = RequestMethod.POST)
public @ResponseBody Person addPerson( @RequestBody final  Person person) {

お役に立てれば

于 2016-02-21T06:58:50.217 に答える
12

私はまったく同じ問題に遭遇したと思います。JSON、JavaScript、サーバーと数え切れないほどの戦いをした後、犯人を見つけました。私の場合、DTOにDateオブジェクトがあり、このDateオブジェクトは文字列に変換されたので、ビューに表示できます。フォーマット:HH:mm。

JSON情報が返送されたときに、このDate Stringオブジェクトを完全なDateオブジェクトに変換し直す必要があったため、DTOで設定するメソッドも必要です。大きなことですが、パラメーターのタイプ(文字列と日付)が異なっていても、DTOに同じ名前(オーバーロード)の2つのメソッドを含めることはできません。これにより、415 UnsupportedMediatypeエラーも発生するためです。

これが私のコントローラー方式でした

  @RequestMapping(value = "/alarmdownload/update", produces = "application/json", method = RequestMethod.POST)
  public @ResponseBody
  StatusResponse update(@RequestBody AlarmDownloadDTO[] rowList) {
    System.out.println("hola");
    return new StatusResponse();
  }

これは私のDTOの例でした(コードの短縮のためにid get /setおよびpreAlarmgetメソッドは含まれていません):

@JsonIgnoreProperties(ignoreUnknown = true)
public class AlarmDownloadDTO implements Serializable {

  private static final SimpleDateFormat formatHHmm = new SimpleDateFormat("HH:mm");

  private String id;
  private Date preAlarm;

  public void setPreAlarm(Date date) { 
    this.preAlarm == date;
  }
  public void setPreAlarm(String date) {    
    try {
      this.preAlarm = formatHHmm.parse(date);
    } catch (ParseException e) {
      this.preAlarm = null;
    } catch (NullPointerException e){
      this.preAlarm = null;
    }
  }
}

すべてを機能させるには、Date型パラメーターを使用してメソッドを削除する必要があります。このエラーは非常に苛立たしいものです。これにより、誰かのデバッグ時間を節約できることを願っています。

于 2013-05-18T23:34:57.150 に答える
8

SpringBootをSpringMVCと統合したときに、この問題に直面しました。これらの依存関係を追加するだけで解決しました。

<dependency>
<groupId>org.codehaus.jackson</groupId>
<artifactId>jackson-mapper-asl</artifactId>
<version>1.9.13</version>
</dependency>
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.5.3</version>
</dependency>
于 2016-06-03T05:54:33.800 に答える
5

小さな補足-Webアプリケーションの開発中にこの同じエラーに遭遇しました。Firefox Posterを使用してサービスをいじって見つけた間違いは、Jsonのフィールドと値の両方を二重引用符で囲む必要があるということでした。例えば..

[ {"idProductCategory" : "1" , "description":"Descrizione1"}, 
  {"idProductCategory" : "2" , "description":"Descrizione2"} ]

私たちの場合、javascriptを介してjsonに入力しました。これは、一重引用符/二重引用符の処理に関しては少し混乱する可能性があります。

'Accept'ヘッダーや'Content-Type'ヘッダーなど、この投稿や他の投稿で以前に言われたことも当てはまります。

お役に立てば幸いです。

于 2013-01-16T10:37:00.550 に答える
3

私はそれを機能させる方法をなんとかやり遂げました。私が間違っている場合に備えて教えてください。@JSONSerializeシリアル化/逆シリアル化する方法は1つだけでした。これ(および)に関するすべてのアノテーションを削除し@JSONDeserialize、SerializersとDeserializersをCustomObjectMapperクラスに登録しました。この動作を説明する記事は見つかりませんでしたが、この方法で解決しました。お役に立てば幸いです。

于 2012-07-26T16:19:08.207 に答える
1

私も同じ問題を抱えていました。問題を解決するには、次の手順を実行する必要がありました。

1.次の依存関係があることを確認してください。

    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-core</artifactId>
        <version>${jackson-version}</version> // 2.4.3
    </dependency>
    <dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>${jackson-version}</version> // 2.4.3
    </dependency>

2.次のフィルターを作成します。

    public class CORSFilter extends OncePerRequestFilter {

        @Override
        protected void doFilterInternal(HttpServletRequest request,
                                        HttpServletResponse response, FilterChain filterChain)
                throws ServletException, IOException {

            String origin = request.getHeader("origin");
            origin = (origin == null || origin.equals("")) ? "null" : origin;
            response.addHeader("Access-Control-Allow-Origin", origin);
            response.addHeader("Access-Control-Allow-Methods", "POST, GET, PUT, UPDATE, DELETE, OPTIONS");
            response.addHeader("Access-Control-Allow-Credentials", "true");
            response.addHeader("Access-Control-Allow-Headers",
                    "Authorization, origin, content-type, accept, x-requested-with");

            filterChain.doFilter(request, response);
        }
    }

3.web.xmlのリクエストに上記のフィルターを適用します

    <filter>
        <filter-name>corsFilter</filter-name>
        <filter-class>com.your.package.CORSFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>corsFilter</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

これが誰かに役立つことを願っています。

于 2016-03-16T04:11:24.853 に答える
1

スプリングブート+スプリングmvn

問題あり

@PostMapping("/addDonation")
public String addDonation(@RequestBody DonatorDTO donatorDTO) {

ソリューション付き

@RequestMapping(value = "/addDonation", method = RequestMethod.POST)
@ResponseBody
public GenericResponse addDonation(final DonatorDTO donatorDTO, final HttpServletRequest request){
于 2018-12-04T10:46:14.070 に答える
0

私のpomにjackson-jsonデータバインディングを追加することで、この問題を解決しました。

<dependency>
        <groupId>com.fasterxml.jackson.core</groupId>
        <artifactId>jackson-databind</artifactId>
        <version>2.6.3</version>
</dependency>
于 2018-01-24T10:43:27.687 に答える
0

モデルクラスにjsonプロパティアノテーションを追加し、デフォルトのコンストラクターも追加します

@JsonProperty("user_name")
private String userName;

@JsonProperty("first_name")
private String firstName;

@JsonProperty("last_name")
private String lastName;
于 2019-09-06T07:51:21.940 に答える
0

私も同じ問題を抱えていました。追加する

<mvc:annotation-driven />
<mvc:default-servlet-handler />

spring-xmlにそれを解決しました

于 2019-12-10T15:29:20.650 に答える
0

AcceptヘッダーとContent-Typeヘッダーを設定し、それらがコントローラーメソッドのconsumes /produces設定と一致することを確認することに加えて、JSON構造を調べて、マーシャリングとアンマーシャリングに問題がないことを確認することもできます。私の場合、コンテンツタイプは問題ありませんでしたが、JSONリクエストをリクエスト/レスポンスモデルにマッピングする際に問題が発生しました。通常、コントローラーは415エラーではなく400エラーを返すはずですが、私の場合、エラーコードは415でした。ObjectMapperを使用してJSONをリクエストモデルオブジェクトに読み込むテストクラスを追加して、問題をデバッグしました。ObjectMapperはリクエストに応じてチョークし、モデルクラス定義を修正するのに役立つ有用なエラーを表示しました。

于 2021-05-24T15:12:54.090 に答える
-1

1.a. applicationContext-mvc.xmlに以下を追加します

xmlns:mvc = "http://www.springframework.org/schema/mvc" xsi:schemaLocation = " http://www.springframework.org/schema/mvc http://www.springframework.org/schema/mvc

  1. ジャクソンライブラリを追加
于 2016-01-01T05:27:31.143 に答える