リバース ajax について学びたいのですが、ICEPush というガジェットを見つけたので、それが良い出発点になると思いました。非常に単純なアプリケーションの実装に問題があります。このチュートリアルに従っていますが、Tomcat の代わりに Glassfish 3.1 を使用し、Eclipse の代わりに NetBeans 7.1 を使用しています。
チュートリアルにあるとおりに実行しました。コードを参照してください。これは、Ajax プッシュの対象となるページです。
<html xmlns="http://www.w3.org/1999/xhtml"
xmlns:h="http://java.sun.com/jsf/html"
xmlns:f="http://java.sun.com/jsf/core">
<h:head>
<title>Easy Ajax Push - Color</title>
</h:head>
<h:body>
<h:dataTable value="#{messageBean.textList}" var="current">
<h:column>
<h:outputText value="#{current.text}"
style="color: #{current.color};"/>
</h:column>
</h:dataTable>
<hr width="100%"/>
<h:form>
<h:panelGrid columns="4">
Choose a Color:
<h:commandButton value="Red"
action="#{colorBean.chooseColor}"
style="color: white; background-color: red;">
<f:setPropertyActionListener target="#{colorBean.color}" value="red"/>
</h:commandButton>
<h:commandButton value="Blue"
action="#{colorBean.chooseColor}"
style="color: white; background-color: blue;">
<f:setPropertyActionListener target="#{colorBean.color}" value="blue"/>
</h:commandButton>
<h:commandButton value="Green"
action="#{colorBean.chooseColor}"
style="color: white; background-color: green;">
<f:setPropertyActionListener target="#{colorBean.color}" value="green"/>
</h:commandButton>
</h:panelGrid>
</h:form>
</h:body>
</html>
必要なマネージドBean は次の 2 つです。
@ManagedBean(name="colorBean")
@ViewScoped
public class ColorBean implements Serializable {
private static final String PUSH_GROUP = "colorPage";
@ManagedProperty(value="#{messageBean}")
private MessageBean messageBean;
private String color = "black";
private String sessionId;
public ColorBean() {
PushRenderer.addCurrentSession(PUSH_GROUP);
FacesContext fcontext = FacesContext.getCurrentInstance();
HttpSession session = (HttpSession)fcontext.getExternalContext().getSession(false);
sessionId = session.getId();
}
public void setMessageBean(MessageBean messageBean) {
this.messageBean = messageBean;
}
public String getColor() {
return color;
}
public void setColor(String color) {
this.color = color;
}
public String chooseColor() {
messageBean.addToList(sessionId, color);
PushRenderer.render(PUSH_GROUP);
return null;
}
}
MessageBean.java
@ManagedBean(name="messageBean")
@ApplicationScoped
public class MessageBean implements Serializable {
private static final int MAX_SIZE = 25;
private List<TextModel> textList = new ArrayList<TextModel>(0);
public MessageBean() {
}
public List<TextModel> getTextList() {
return textList;
}
public void setTextList(List<TextModel> textList) {
this.textList = textList;
}
public void addToList(String sessionId, String color) {
textList.add(makeTextModel(sessionId, color));
if (textList.size() > MAX_SIZE) {
textList.clear();
}
}
private TextModel makeTextModel(String sessionId, String color) {
return new TextModel("User with session ID of " + sessionId + " selected color \"" + color + "\".",
color);
}
}
また、表示されるテキストを表す単純な pojo もあります。 TextModel.java
public class TextModel implements Serializable {
private String text;
private String color;
public TextModel() {
}
public TextModel(String text, String color) {
this.text = text;
this.color = color;
}
public String getText() {
return text;
}
public void setText(String text) {
this.text = text;
}
public String getColor() {
return color;
}
public void setColor(String color) {
this.color = color;
}
public String toString() {
return text;
}
}
私は IceFaces バージョン 3.0.1 を使用しています。これが私のweb.xmlの外観です。
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
<context-param>
<param-name>javax.faces.PROJECT_STAGE</param-name>
<param-value>Development</param-value>
</context-param>
<context-param>
<param-name>javax.faces.STATE_SAVING_METHOD</param-name>
<param-value>server</param-value>
</context-param>
<context-param>
<param-name>javax.faces.FACELETS_SKIP_COMMENTS</param-name>
<param-value>true</param-value>
</context-param>
<context-param>
<param-name>org.icefaces.mandatoryResourceConfiguration</param-name>
<param-value/>
</context-param>
<context-param>
<param-name>org.icefaces.ace.theme</param-name>
<param-value>sam</param-value>
</context-param>
<context-param>
<param-name>javax.faces.VALIDATE_EMPTY_FIELDS</param-name>
<param-value>false</param-value>
</context-param>
<context-param>
<param-name>com.icesoft.faces.gmapKey</param-name>
<param-value>ABQIAAAADlu0ZiSTam64EKaCQr9eTRTOTuQNzJNXRlYRLknj4cQ89tFfpxTEqxQnVWL4k55OPICgF5_SOZE06A</param-value>
</context-param>
<servlet>
<servlet-name>Faces Servlet</servlet-name>
<servlet-class>javax.faces.webapp.FacesServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet>
<servlet-name>Resource Servlet</servlet-name>
<servlet-class>com.icesoft.faces.webapp.CompatResourceServlet</servlet-class>
<load-on-startup>1</load-on-startup>
</servlet>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>/faces/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>*.jsf</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>Faces Servlet</servlet-name>
<url-pattern>/icefaces/*</url-pattern>
</servlet-mapping>
<servlet-mapping>
<servlet-name>Resource Servlet</servlet-name>
<url-pattern>/xmlhttp/*</url-pattern>
</servlet-mapping>
<session-config>
<session-timeout>
30
</session-timeout>
</session-config>
<welcome-file-list>
<welcome-file>faces/index.xhtml</welcome-file>
</welcome-file-list>
</web-app>
このコードは私に3つの問題を与えます:
1-アプリを実行して3つのボタンのいくつかをクリックすると、スコープに互換性がないため、1つの管理対象Beanを別の管理対象Beanで呼び出すことができないという例外が発生します。
警告: キューに入れられた例外 javax.faces.FacesException: マネージド Bean colorBean を作成できません。次の問題が見つかりました。 - 式 #{messageBean} リクエストによって参照されるオブジェクトのスコープが、参照するマネージド Bean (colorBean) のビューのスコープよりも短い
2 - コンソールには常に次のようなメッセージが表示されます。
警告: PWC4011: 要求パラメーターが既に読み取られているか、または ServletRequest.getReader() が既に呼び出されているため、コンテキスト /ReverseAjaxExample から要求文字エンコーディングを UTF-8 に設定できません
3 - マネージド Bean で @ApplicationScope を @ViewScope に、@ViewScope を @ApplicationScope に変更すると、最初の問題はなくなり、アプリケーションの動作を確認できますが、逆の ajax は機能しません。他のブラウザーでは表示されないためです。変更。PWC4011
また、コンソールに常に警告が表示されます
リバース Ajax を使用したことはありませんが、理論的な観点からは理解しています。この単純なアプリを修正する手を貸していただければ、本当にありがたいです。