Генерация Контекста Поверхностей вручную

Если вы выполняете итерацию по списку с помощью цикла while, то вы должны иметь действие, выполняющее строку кода внутри цикла while.

Также похоже, что ваш цикл будет обрезаться раньше, когда i = 2 = len (cflist) на второй итерации (не забывайте, что python использует индексирование на основе 0 ) и потому что обратный вызов находится внутри цикла while.

Это должно работать:

def npv(cfList, r):
    f = 0
    i = 1

    pv = 0

    while f <= len(cfList):
        pv += (cfList[f] / ((1 + r) ** i))
        f += 1
        i += 1
    return pv

5
задан BalusC 26 January 2010 в 15:54
поделиться

1 ответ

Я не уверен, что Вы подразумеваете под "сайтом" в этом контексте.

Несколько примечаний:

  • Управляемые компоненты никогда не будут не быть доступными вне веб-приложения (ВОЙНА), в которой они определяются.
  • Экземпляры объектов FacesContext в конечном счете созданы и расположены FacesServlet.service, таким образом, запросы должны пройти через этот сервлет. Попытка создать контекст при других обстоятельствах могла бы привести к неопределенному поведению.

Принимая во внимание это, Вы могли создать последовательность запроса как это:

FacesServlet (mapping: /faces/*)
 -> /faces/jsfPage.jsp (a JSP with JSF controls)
    -> DispatchBean (calls ExternalContext.dispatch("/AnotherServlet")
       -> AnotherServlet

jsfPage.jsp содержит:

<f:view>
    <h:outputText value="#{dispatchBean.dispatch}" />
</f:view>

Свойство "отправки" решает к бобовому методу "getDispatch":

public String getDispatch() {
    FacesContext context = FacesContext.getCurrentInstance();
    try {
        context.getExternalContext().dispatch("/FacesClientServlet");
    } catch (IOException e) {
        throw new FacesException(e);
    }
    return null;
}

Который отправляет этому сервлету:

public class FacesClientServlet extends javax.servlet.http.HttpServlet
        implements javax.servlet.Servlet {

    static final long serialVersionUID = 1L;

    @Override
    protected void doGet(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException {

        FacesContext context = FacesContext.getCurrentInstance();
        ELContext elContext = context.getELContext();
        ExpressionFactory expressionFactory = context.getApplication()
                .getExpressionFactory();
        ValueExpression expression = expressionFactory.createValueExpression(
                elContext, "#{myBean.text}", Object.class);
        Object value = expression.getValue(elContext);

        ResponseWriter writer = context.getResponseWriter();
        writer.write("" + value);

    }

}

Который испускает значение от управляемого компонента "myBean":

public class MyBean {

    private final String text = "Hello, World!";

    public String getText() {
        return text;
    }

}

Это является все очень замысловатым, и я охотно не сделал бы ни одного из него.


Альтернатива, которая может идти с ее собственными последствиями, должна создать Ваш собственный контекст как это:

public class ContextServlet extends javax.servlet.http.HttpServlet implements
        javax.servlet.Servlet {
    static final long serialVersionUID = 1L;

    private FacesContextFactory facesContextFactory;
    private Lifecycle lifecycle;

    @Override
    public void init(ServletConfig config) throws ServletException {
        super.init(config);

        LifecycleFactory lifecycleFactory = (LifecycleFactory) FactoryFinder
                .getFactory(FactoryFinder.LIFECYCLE_FACTORY);
        facesContextFactory = (FacesContextFactory) FactoryFinder
                .getFactory(FactoryFinder.FACES_CONTEXT_FACTORY);
        lifecycle = lifecycleFactory
                .getLifecycle(LifecycleFactory.DEFAULT_LIFECYCLE);
    }

    @Override
    protected void doGet(HttpServletRequest request,
            HttpServletResponse response) throws ServletException, IOException {

        FacesContext context = facesContextFactory.getFacesContext(
                getServletContext(), request, response, lifecycle);
        try {
            ELContext elContext = context.getELContext();
            ExpressionFactory expressionFactory = context.getApplication()
                    .getExpressionFactory();
            ValueExpression expression = expressionFactory
                    .createValueExpression(elContext, "#{myBean.text}",
                            Object.class);
            Object value = expression.getValue(elContext);

            PrintWriter pw = response.getWriter();
            try {
                pw.write("" + value);
            } finally {
                pw.close();
            }
        } finally {
            context.release();
        }
    }

}

Снова, я избежал бы этого подхода, если это возможно.

4
ответ дан 15 December 2019 в 01:12
поделиться
Другие вопросы по тегам:

Похожие вопросы: