[英]Primefaces autocomplete ClassCastException
我正在使用Spring 3,Hibernate 4和JSF 2.0,我正在嘗試使用primefaces自動完成。
我在DAO類中有以下內容來從Oracle函數中獲取值
@Override
public List<EmployeeDetail> getEmployeeDetails(String employeeNumber) {
List query = (List)entityManager.createNamedQuery("getEmp")
.setParameter("empNumber", employeeNumber)
.getSingleResult();
return query;
}
轉換器類
public EmployeeNameConverter(
List<EmployeeDetail> employeeDB, EmployeeDetailService instance,
String employeeNumber) {
if (employeeDetailService == null) {
employeeDetailService = instance;
}
if (param == null) {
param = employeeNumber;
}
this.employeeDB = employeeDB;
}
@Override
public Object getAsObject(FacesContext arg0, UIComponent arg1,
String submittedValue) {
if (submittedValue.trim().equals("")) {
return null;
} else {
try {
// int number = Integer.parseInt(submittedValue);
employeeDB = getEmployeeDetailService().getEmployeeDetails(param);
for (EmployeeDetail emp : employeeDB) {
if (emp.getEmployeeNumber() == submittedValue) {
return emp;
}
}
} catch (NumberFormatException exception) {
throw new ConverterException(new FacesMessage(
FacesMessage.SEVERITY_ERROR, "Conversion Error",
"Not a valid employee"));
}
}
在我的Managedbean中
我有完整的方法,我將employeeDetailService傳遞給我的轉換器類。
public List<EmployeeDetail> complete(String query) {
List<EmployeeDetail> suggestions;
suggestions = new ArrayList<EmployeeDetail>();
try {
employee = (List<EmployeeDetail>) new EmployeeNameConverter(
employeeList, employeeDetailService, query);
for (EmployeeDetail p : employee) {
if (p.getEmployeeNumber().startsWith(query))
suggestions.add(p);
}
} catch (Exception e) {
System.out.println("exc " + e.getMessage());
e.printStackTrace();
}
return suggestions;
}
JSF代碼
<p:autoComplete value="#{empMB.selectedEmployee}"
id="basicPojo" minQueryLength="6"
completeMethod="#{empMB.complete}" var="p"
itemLabel="#{p.employeeNumber}"
itemValue="#{p}" converter="#{p.employee}"
forceSelection="true" />
當我輸入字符時,我會遇到異常
EmployeeNameConverter cannot be cast to java.util.List
java.lang.ClassCastException: net.test.util.EmployeeNameConverter cannot be cast to java.util.List
我該如何解決這個問題? 這是正確的方法,還是有人可以提出更好的方法來實現同樣的目標?
更新1
@Override
public List<EmployeeDetail> getEmployeeDetails(String employeeNumber) {
List query = (List)entityManager.createNamedQuery("getEmp")
.setParameter("empNumber", employeeNumber)
.getSingleResult();
return query;
}
例外
net.test.entity.EmployeeDetail cannot be cast to java.util.List
java.lang.ClassCastException: net.test.entity.EmployeeDetail cannot be cast to java.util.List
at net.test.dao.EmployeeDetailDAOImpl.getEmployeeDetails(EmployeeDetailDAOImpl.java:36)
和例外行是
List query = (List)entityManager.createNamedQuery("getEmp")
.setParameter("empNumber", employeeNumber)
.getSingleResult();
這里有兩個主要問題
您正在嘗試手動實例化和管理JSF轉換器實例。 不要這樣做。 轉換器是一種僅供JSF上下文使用的構造。 開發人員不應該為轉換器類調用new
或者提供構造函數參數。 根據此示例實現一個簡單的轉換器,並在<p:autoComplete/>
根據您的評論,您手動管理轉換器的原因是能夠訪問您的DAO層。 作為一種解決方法,您可以將@ManagedBean
添加到轉換器中,JSF將其視為托管bean 和轉換器。 作為托管bean,您現在可以將DAO資源注入其中。 這不是最佳做法,而只是一種解決方法。 轉換器的這種限制將在JSF2.2中刪除:)。
在操作轉換器時,您嘗試將其視為常規POJO並嘗試將其轉換為幾種不兼容的類型,因此
employee = (List<EmployeeDetail>) new EmployeeNameConverter( employeeList, employeeDetailService, query); //EmployeeNameConverter !instanceof EmployeeDetail
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.