2

HashMap 値をセッションに保存しようとしていて、JSP を使用して取得していますが、次のエラーが表示されます。

HTTP ステータス 500 - org.apache.struts2.dispatcher.SessionMap を java.util.HashMap にキャストできない

なぜそのエラーが発生するのですか?

package com.action;
import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.Statement;
import java.text.BreakIterator;
import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;

import com.action.GetCon;




public class JanuaryAction implements SessionAware{
private String name;
Map abc = new HashMap();


public Map getAbc() {
return abc;
}

public void setAbc(Map abc) {
this.abc = abc;
}


public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}

@Override
public void setSession(Map abc) {
this.abc = (HashMap) abc;

}
public String execute() throws Exception{

String time=getName();
 /*   System.out.println(time);*/
if(time.equals("January 2013")){

abc.put(time,"'2013-01-01' AND OrderDate <= '2013-01-31'" );
}
else if(time.equals("February 2013")){
abc.put(time,"'2013-02-01' AND OrderDate <='2013-02-31'" );
}
else if(time.equals("March 2013")){
abc.put(time,"'2013-03-01' AND OrderDate <='2013-03-31'" );
}
else if(time.equals("April 2013")){
abc.put(time,"'2013-04-01' AND OrderDate <='2013-04-31'" );
}
else if(time.equals("May 2013")){
abc.put(time,"'2013-05-01' AND OrderDate <='2013-05-31'" );
}
else if(time.equals("June 2013")){
abc.put(time,"'2013-06-01' AND OrderDate <='2013-06-05'" );
}
String newtime=(String)abc.get(time);
   /* System.out.println(newtime);*/

Connection con = GetCon.getCon();
Statement statement = con.createStatement();
ResultSet resultset = statement.executeQuery("SELECT MarketPlace,OrderDate, ROUND(SUM(Total),2),  COUNT(*) , ROUND(ROUND(SUM(Total),2)/ COUNT(*),2) FROM vend_printed WHERE OrderDate >=" +newtime+ " GROUP BY OrderDate,MarketPlace") ;
Object value = abc.remove(time);

while(resultset.next()){

String marketplace = resultset.getString(1);

String orderdate = resultset.getString(2);

Double datamount = resultset.getDouble(3);
Integer count= resultset.getInt(4);

Double result=resultset.getDouble(5);

abc.put(0, marketplace);
abc.put(1, orderdate);
abc.put(2, datamount);
abc.put(3, count);
abc.put(4, result);}

return "success";
}}

私の JSP では、ループの値を 1 つずつ表示したいと考えていました。だから私は今このコードを使用していますが、何も表示されていません。

<s:property value="#session.0" /><br><br><br>
<s:property value="#session.1" /><br><br><br>
<s:property value="#session.2" /><br><br><br>
<s:property value="#session.3" /><br><br><br>
<s:property value="#session.4" /><br><br><br>   
4

3 に答える 3

3

問題はここにあります:

@Override
public void setSession(Map abc) {
  //abc is actually a SessionMap, which is not a HashMap !
  this.abc = (HashMap) abc;
}

あなたはそれが間違っているabcと思うからです。HashMapそれは実際にはですSessionMap(それがエラーメッセージの内容です)。SessionMapは拡張しません。直接拡張するものを拡張しHashMapます。AbstractMapObject

参照: http://struts.apache.org/release/2.0.x/struts2-core/apidocs/org/apache/struts2/dispatcher/SessionMap.html

基本的に、 が になるimplements SessionAwareと想定する場合、これは絶対に保証されておらず、実際にはそうではありません。MapHashMap

属性定義を置き換えることをお勧めします:

HashMap abc = new HashMap();

と:

private Map abc; //Don't initialize it as it is done by the setter.
于 2013-06-21T15:35:59.680 に答える
1

これはSessionAware実装です、それを使用してください

private Map<String, Object> session;

@Override
public void setSession(Map<String, Object> session) {
 this.session = session;
}

execute値を使用して新しいコレクションを作成し、セッション マップに配置します。abc最初にクエリを作成するために使用したのと同じ変数を再利用しているコードの問題。別のものを作成し、List代わりにを使用しMapて、反復して JSP に表示するアイテムの順序を維持する必要があります。から入力する必要があるクラスを作成して使用し、ResultSetそれをリストに入力することをお勧めします。

public class Market {
  private String marketplace;  
  private String orderdate;  
  private Double datamount;
  private Integer count;  
  private Double result;

  public String getMarketplace() {
    return marketplace;
  }

  public void setMarketplace(String marketplace) {
    this.marketplace = marketplace;
  }

  public String getOrderdate() {
    return orderdate;
  }

  public void setOrderdate(String orderdate) {
    this.orderdate = orderdate;
  }

  public Double getDatamount() {
    return datamount;
  }

  public void setDatamount(Double datamount) {
    this.datamount = datamount;
  }

  public Integer getCount() {
    return count;
  }

  public void setCount(Integer count) {
    this.count = count;
  }

  public Double getResult() {
    return result;
  }

  public void setResult(Double result) {
    this.result = result;
  }

  public Market(String marketplace, String orderdate, Double datamount, Integer count, Double result) {
    this.marketplace = marketplace;
    this.orderdate = orderdate;
    this.datamount = datamount;
    this.count = count;
    this.result = result;
  }

}   

結果を保持するプロパティを作成する

@Element(value = Market.class)
private List<Market> markets = new ArrayList<>();

public List<Market> getMarkets() {
  return markets;
}

public void setMarkets(List<Market> markets) {
  this.markets = markets;
}

このブロックを使用する必要があるリストに入力するには、接続をどのように使用するかわかりません。そのため、閉じませんでした。

Connection con = GetCon.getCon();
Statement statement = con.createStatement();
try {
  ResultSet resultset = statement.executeQuery("SELECT MarketPlace,OrderDate, ROUND(SUM(Total),2),  COUNT(*) , ROUND(ROUND(SUM(Total),2)/ COUNT(*),2) FROM vend_printed WHERE OrderDate >=" +newtime+ " GROUP BY OrderDate,MarketPlace") ;
  while(resultset.next()){
  markets.add(new Market(
    resultset.getString(1),
    resultset.getString(2),
    resultset.getDouble(3),
    resultset.getInt(4),
    resultset.getDouble(5)
  ));
  }
} finally {
  try {
    statement.close();
  } catch (SQLException e) {}
}

}

ここで結果をセッションに保持します

session.put("markets", markets);

JSP ではiteratorタグを使用します。セッション オブジェクトを繰り返す必要はなく、アクションから取得するだけです。

<s:iterator value="markets">
  Marketplace: <s:property value="marketplace" /><br> 
  Orderdate: <s:property value="orderdate" /><br>  
  Datamount: <s:property value="datamount" /><br>
  Count: <s:property value="count" /><br>  
  Result: <s:property value="result" /><br>
  <hr>
</s:iterator>
于 2013-06-21T15:48:53.000 に答える