2017-11-09 13 views
1

저는 JavaScript에 익숙하지 않아 간단한 JavaScript 코드를 수행하려고 할 때 큰 문제가 있습니다. JS 코드를 Java 응용 프로그램으로 수행 할 수있는 JavaScript 구현 인 Rhino()입니다. 내 구체적인 경우 RhinoWSO2 ESB (Java에서 개발 된 ESB 도구)에 내장되어 있습니다.Date 개체를 Rhino에서 수행되는 JS 스크립트로 설정하려고 할 때 "잘못된 날짜"오류가 발생하는 이유는 무엇입니까?

내 JS 코드를 Java \ WSO2 ESB 응용 프로그램으로 수행 할 수 있지만 JavaScript를 만들려고하는데 문제가 발생했습니다. 날짜 개체입니다. 이 경우에는 작동하지 않습니다.

내가 좋아하는 뭔가가 내 JS 코드의 경우 : I는 브라우저에 perfom하지만 Java 콘솔에 코뿔소 나는 다음과 같은 오류 메시지를 얻을 수으로 그것을 수행하는 경우

var dateCurrentOriginalForecast = new Date('2017-11-09 06:00:00'); 

잘 작동 :

TID: [-1234] [] [2017-11-09 15:55:43,610] INFO {org.apache.synapse.mediators.bsf.ScriptMessageContext} - dateCurrentOriginalForecast: Invalid Date {org.apache.synapse.mediators.bsf.ScriptMessageContext} 
TID: [-1234] [] [2017-11-09 15:55:43,610] ERROR {org.apache.synapse.mediators.bsf.ScriptMediator} - The script engine returned an error executing the inlined js script function mediate {org.apache.synapse.mediators.bsf.ScriptMediator} 
com.sun.phobos.script.util.ExtendedScriptException: org.mozilla.javascript.EcmaError: RangeError: Date is invalid. (<Unknown Source>#139) in <Unknown Source> at line number 139 
     at com.sun.phobos.script.javascript.RhinoCompiledScript.eval(RhinoCompiledScript.java:68) 
     at javax.script.CompiledScript.eval(CompiledScript.java:92) 
     at org.apache.synapse.mediators.bsf.ScriptMediator.mediateForInlineScript(ScriptMediator.java:345) 
     at org.apache.synapse.mediators.bsf.ScriptMediator.invokeScript(ScriptMediator.java:265) 
     at org.apache.synapse.mediators.bsf.ScriptMediator.mediate(ScriptMediator.java:233) 
     at org.apache.synapse.mediators.AbstractListMediator.mediate(AbstractListMediator.java:97) 
     at org.apache.synapse.mediators.base.SequenceMediator.mediate(SequenceMediator.java:260) 
     at org.apache.synapse.core.axis2.Axis2SynapseEnvironment.mediateFromContinuationStateStack(Axis2SynapseEnvironment.java:775) 
     at org.apache.synapse.core.axis2.Axis2SynapseEnvironment.injectMessage(Axis2SynapseEnvironment.java:282) 
     at org.apache.synapse.core.axis2.SynapseCallbackReceiver.handleMessage(SynapseCallbackReceiver.java:554) 
     at org.apache.synapse.core.axis2.SynapseCallbackReceiver.receive(SynapseCallbackReceiver.java:188) 
     at org.apache.axis2.engine.AxisEngine.receive(AxisEngine.java:180) 
     at org.apache.synapse.transport.passthru.ClientWorker.run(ClientWorker.java:262) 
     at org.apache.axis2.transport.base.threads.NativeWorkerPool$1.run(NativeWorkerPool.java:172) 
     at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142) 
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617) 
     at java.lang.Thread.run(Thread.java:745) 
Caused by: org.mozilla.javascript.EcmaError: RangeError: Date is invalid. (<Unknown Source>#139) 
     at org.mozilla.javascript.ScriptRuntime.constructError(ScriptRuntime.java:3687) 
     at org.mozilla.javascript.ScriptRuntime.constructError(ScriptRuntime.java:3665) 
     at org.mozilla.javascript.NativeDate.toISOString(NativeDate.java:398) 
     at org.mozilla.javascript.NativeDate.execIdCall(NativeDate.java:384) 
     at org.mozilla.javascript.IdFunctionObject.call(IdFunctionObject.java:97) 
     at org.mozilla.javascript.optimizer.OptRuntime.callProp0(OptRuntime.java:85) 
     at org.mozilla.javascript.gen._Unknown_Source__1177._c_script_0(<Unknown Source>:139) 
     at org.mozilla.javascript.gen._Unknown_Source__1177.call(<Unknown Source>) 
     at org.mozilla.javascript.ContextFactory.doTopCall(ContextFactory.java:394) 
     at org.mozilla.javascript.ScriptRuntime.doTopCall(ScriptRuntime.java:3091) 
     at org.mozilla.javascript.gen._Unknown_Source__1177.call(<Unknown Source>) 
     at org.mozilla.javascript.gen._Unknown_Source__1177.exec(<Unknown Source>) 
     at com.sun.phobos.script.javascript.RhinoCompiledScript.eval(RhinoCompiledScript.java:55) 
     ... 16 more 

나는 또한 같은 다른 형식을 시도 있습니다

var dateCurrentOriginalForecast = new Date('2017-11-09 06:00:00'); 
var dateCurrentOriginalForecast = new Date('2017-11-09T06:00:00.000Z'); 
var dateCurrentOriginalForecast = new Date('2017-11-09T06:00:00'); 
var dateCurrentOriginalForecast = new Date('2017-11-09T06:00:00T'); 

하지만 여전히 동일한 오류가 발생합니다.

왜? 문제가 무엇입니까? 내가 뭘 놓치고 있니? Rhino에서 올바른 날짜 형식은 무엇입니까? 날짜 객체와 코뿔소와 관련 유사한

뭔가 여기에 있지만 해결책이되지 않습니다 : .... Javascript invalid date in iOS/Android 2.2

답변

2

이 Effectivly 그것은 이상한은

명시적인 날짜 부분 사용해보십시오 :

new Date(year, month, day [, hour, minute, second, millisecond ]) 

new Date('2017','11','09','06','00','00') 
1

Date의 구현이 다릅니다. 문자열의 Date.parseNaN을 반환하면 문자열이 유효한 날짜로 해석되지 않고 new Date(string)을 호출하면 date이지만 InvalidDate을 반환합니다.

문자열 날짜를 부분으로 나누고 따로 설정하거나 Date 요구 사항을 준수하는 문자열 날짜를 지정하십시오.

+0

그러나 왜 그들은 다른 버전의 Date 객체를 구현 했습니까? Java에서의 JavaScript 구현입니다.이 다른 버전의 이유가 있습니까? 이로 인해 많은 비 호환성이 발생합니다. – AndreaNobili

+1

@AndreaNobili IE js가 Chrome js와 다른 이유는 무엇입니까 :) – bluehipy