这个类线程是否安全:com.orionserver.http.OrionHttpJspPage

时间:2013-11-18 14:47:41

标签: oracle jsp servlets concurrency oc4j

我们使用JDeveloper 10.1.3.4开发Web应用程序。我们在Linux上运行的OC4J上部署应用程序。我们直接在jsp页面中放入java代码。在jsp页面中,我们有一般的java代码,例如

<% String invoice_id = ""; %> 

这里变量invoice_id是jsp中的实例变量。我们还有标签,如和处理数据库事务。我们有一个名为paymentApproved.jsp的jsp。这个jsp由第三方网关调用。换句话说,jsp是从我们的应用程序外部调用的。我的问题是,在这种情况下,这个jsp paymentApproved.jsp线程是否安全?我检查了翻译过的jsp页面,该类扩展了 com.orionserver.http.OrionHttpJspPage ,逻辑就在这个方法中:

public void _jspService(HttpServletRequest request, HttpServletResponse response) throws java.io.IOException, ServletException

具体来说,我不确定在这样一个jsp中定义的实例变量是否是线程安全的,而多个请求进来调用该页面?或者无论如何要测试它? (我知道将java代码放入jsp中是一个坏主意。但这是我老板的项目,而不是我的。)谢谢

Jsp代码:

<%@ include file="mainHeader.jsp"%>
<%
  String inv_id = "";
%>

<jbo:ApplicationModule id="AM_Payment" definition="test.AM_Payment" releasemode="Stateless" />
<jbo:DataSource id="dsinv" appid="AM_Payment" viewobject="InvoiceView1"/>

<%

  SimpleDateFormat dtformat = new SimpleDateFormat("yyyy-MM-dd");
  SimpleDateFormat tmformat = new SimpleDateFormat("HH:mm:ss");
  String invoicedateStr = dtformat.format(new java.util.Date());
  oracle.jbo.domain.Date invoicedate = new oracle.jbo.domain.Date(invoicedateStr);
  String invoicetime = tmformat.format(new java.util.Date());

  inv_id = invoicedateStr+invoicetime;

%GT;     

<BR><BR>
<table>
  <tr><td>Invoice id:&nbsp;&nbsp; <%=inv_id%></td></tr>
</table>
<hr>
<% 

    long startTime = System.nanoTime();
    int[] dummy = new int[10];
      for (int i=0; i<999999999; i++) {
        for (int j=0; j<10; j++) {
          dummy[j] = i;
        }
      } 
    long endTime = System.nanoTime();
    long duration = endTime - startTime;
    double seconds = (double)Math.round( (duration/1000000000.0d) *100.0d)/100.0d;    
    String sec = Double.toString(seconds);    
%>
<table>
<tr><td>Invoice id:&nbsp;&nbsp; <%=inv_id%></td></tr>
<tr><td>&nbsp;&nbsp;</td></tr>

<tr><td>Process time:&nbsp;&nbsp; <%=sec%>&nbsp;&nbsp;seconds</td></tr>

</table>
<hr>

<jbo:ReleasePageResources releasemode="Stateless"/>
</body>
</html> 

1 个答案:

答案 0 :(得分:0)

<% String invoice_id = ""; %>
  

这里变量invoice_id是jsp中的实例变量。

不,不是。它是JSP服务方法的局部变量。

  

这个jsp paymentApproved.jsp线程安全吗?

如果没有看到这个JSP的单个字符,我们怎么说?

将Java代码放在JSP中是一个非常糟糕的主意。多年来不应使用Scriptlet。使用JSP作为纯视图组件,其唯一作用是从用Java编写的控制器中存储在te请求中的bean生成HTML标记。