0

グラスフィッシュの前にリバースプロキシとしてApacheを使用し、メインの代わりに書き換えられたサブフォルダーにプロキシパスしようとすると、次の問題が発生します。

すべての ajax 呼び出しが機能しなくなり、500 Internal Server Error.

メインフォルダーにプロキシパスすると、問題は発生しません。

JSF - リライタルール:

http://ocpsoft.org/書き換えソリューションを使用して、Apache もプロキシする仮想 URL を作成します。

`/foo/{fooViewParamValue} -> /sites/foo/foo.xhtml`

アパッチ構成:

<VirtualHost *>
    ProxyRequests Off

    <proxy *>
        Order deny,allow
        # Deny from all 
        Allow from all
    </proxy>

    SetOutputFilter proxy-html 
    ProxyPreserveHost On

    # map resources
    ProxyPass            /res/ http://localhost:2080/res/
    ProxyPassReverse     /res/ http://localhost:2080/res/
    # map subfolder
    ProxyPass            / http://localhost:2080/foo/fooViewParamValue/
    ProxyPassReverse     / http://localhost:2080/foo/fooViewParamValue/
    # map main folder - test
    #ProxyPass            / http://localhost:2080/
    #ProxyPassReverse     / http://localhost:2080/


    # map processed html elements
    ProxyHTMLLinks  a       href
    ProxyHTMLLinks  area        href
    ProxyHTMLLinks  link        href
    ProxyHTMLLinks  img     src longdesc usemap
    ProxyHTMLLinks  object      classid codebase data usemap
    ProxyHTMLLinks  q       cite
    ProxyHTMLLinks  blockquote  cite
    ProxyHTMLLinks  ins     cite
    ProxyHTMLLinks  del     cite
    ProxyHTMLLinks  form        action
    ProxyHTMLLinks  input       src usemap
    ProxyHTMLLinks  head        profile
    ProxyHTMLLinks  base        href
    ProxyHTMLLinks  script      src for

    # map processed html events
    ProxyHTMLEvents onclick ondblclick onmousedown onmouseup \
            onmouseover onmousemove onmouseout onkeypress \
            onkeydown onkeyup onfocus onblur onload \
            onunload onsubmit onreset onselect onchange

    ProxyHTMLEnable On
    ProxyHTMLExtended On

    # main folder html 
    #ProxyHTMLURLMap  / /
    # subfolder html 
    ProxyHTMLURLMap  /foo/fooViewParamValue/ /
    ProxyHTMLURLMap  /foo/fooViewParamValue /
</VirtualHost>

観察:

フォーム アクション属性の内容を (firebug で) 削除するだけで十分な場合もありますが、無限ループで例外が発生する場合もあります。

<h:form>
    <p:commandButton/>
</h:form>
<!-- final html -->
<form action="/sites/foo/foo.xhtml">
    <button/>
</form>
<!-- removing action content sometimes works -->
    <form action="">
    <button/>
</form>

ログに記録される例外:

時には一度、時にはループで:

Warnung: StandardWrapperValve[Faces Servlet]: PWC1406: Servlet.service() for servlet Faces Servlet threw exception
java.lang.NullPointerException
at com.sun.faces.context.PartialViewContextImpl.createPartialResponseWriter(PartialViewContextImpl.java:439)
at com.sun.faces.context.PartialViewContextImpl.access$300(PartialViewContextImpl.java:72)
at com.sun.faces.context.PartialViewContextImpl$DelayedInitPartialResponseWriter.getWrapped(PartialViewContextImpl.java:573)
at javax.faces.context.PartialResponseWriter.startDocument(PartialResponseWriter.java:115)
at org.omnifaces.context.OmniPartialViewContext$OmniPartialResponseWriter.startDocument(OmniPartialViewContext.java:252)
at org.primefaces.context.PrimePartialResponseWriter.startDocument(PrimePartialResponseWriter.java:133)
at com.sun.faces.context.AjaxExceptionHandlerImpl.handlePartialResponseError(AjaxExceptionHandlerImpl.java:199)
at com.sun.faces.context.AjaxExceptionHandlerImpl.handle(AjaxExceptionHandlerImpl.java:124)
at com.sun.faces.lifecycle.Phase.doPhase(Phase.java:119)
at com.sun.faces.lifecycle.RestoreViewPhase.doPhase(RestoreViewPhase.java:116)
at com.sun.faces.lifecycle.LifecycleImpl.execute(LifecycleImpl.java:118)
at javax.faces.webapp.FacesServlet.service(FacesServlet.java:593)
at org.apache.catalina.core.StandardWrapper.service(StandardWrapper.java:1542)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:343)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:217)
at package.HttpHeaderFilter.doFilter(HttpHeaderFilter.java:48)
at org.omnifaces.filter.HttpFilter.doFilter(HttpFilter.java:75)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:217)
at org.ocpsoft.rewrite.servlet.RewriteFilter.doFilter(RewriteFilter.java:199)
at org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:256)
at org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:217)
at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:279)
at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:175)
at org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:655)
at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:595)
at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:161)
at org.apache.catalina.connector.CoyoteAdapter.doService(CoyoteAdapter.java:331)
at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:231)
at com.sun.enterprise.v3.services.impl.ContainerMapper$AdapterCallable.call(ContainerMapper.java:317)
at com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:195)
at com.sun.grizzly.http.ProcessorTask.invokeAdapter(ProcessorTask.java:849)
at com.sun.grizzly.http.ProcessorTask.doProcess(ProcessorTask.java:746)
at com.sun.grizzly.http.ProcessorTask.process(ProcessorTask.java:1045)
at com.sun.grizzly.http.DefaultProtocolFilter.execute(DefaultProtocolFilter.java:228)
at com.sun.grizzly.DefaultProtocolChain.executeProtocolFilter(DefaultProtocolChain.java:137)
at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:104)
at com.sun.grizzly.DefaultProtocolChain.execute(DefaultProtocolChain.java:90)
at com.sun.grizzly.http.HttpProtocolChain.execute(HttpProtocolChain.java:79)
at com.sun.grizzly.ProtocolChainContextTask.doCall(ProtocolChainContextTask.java:54)
at com.sun.grizzly.SelectionKeyContextTask.call(SelectionKeyContextTask.java:59)
at com.sun.grizzly.ContextTask.run(ContextTask.java:71)
at com.sun.grizzly.util.AbstractThreadPool$Worker.doWork(AbstractThreadPool.java:532)
at com.sun.grizzly.util.AbstractThreadPool$Worker.run(AbstractThreadPool.java:513)
at java.lang.Thread.run(Thread.java:722)

編集1:

//RewriteApache から物理サブフォルダーを削除してマップしましたが、問題はありませんでした。マッピングocp rewriteは問題なく使用しなくても動作しますので。書き換え自体が理由に違いありません。

編集2:

前任者PrettyFacesに戻ると、問題なく動作します。

4

1 に答える 1

0

フォーラム//Rewriteで私は答えを得ました:

フォームの URL がマップされていなかったため、プロキシの通過中に URL が無効になりました。

フォームのポストバック URL/sites/foo/foo.xhtmlはマップされていません。ビューパラメータなし。

  1. 書き換えルールを使用してフォームの URL をマップします。cb.addRule(Join.path("/foo/").to("/sites/foo/foo.xhtml")
  2. ProxyHTMLURLMap /foo/ /を apache プロキシ構成に追加します

プロキシで書き換えると、フォーム src になり/ます。
パターンから末尾のスラッシュを削除して空にすることもできます。

好奇心旺盛:pretty-facesこのルールがマップされていない場所でも奇妙に機能しました。

于 2013-08-30T23:15:31.330 に答える