lipse插件尝试“本地”运行新的Web应用程序(从Eclipse内部,使用内置的Jetty容器)。我正在按照this GWT tutorial中的说明进行操作并遇到一些问题,大概是因为我的模块已经定义了。
我有一个具有以下目录结构的Web应用程序项目:
MyWebApp/
src/
com.mywebapp.client.modules
WebModule
AppModule
WebModule.gwt.xml
AppModule.gwt.xml
war/
WEB-INF/
lib/
web.xml
css/
web-module.css
app-module.css
hmtl/
web-module-host-page.html
app-module-host-page.html
我希望我的应用有两个模块:WebModule
这是“公共网站”,以及当用户转到http://mywebapp.com
时加载的模块,然后有AppModule
,仅在用户登录后下载,并包含网站的“私有应用”功能。
WebModule.java
:
public class WebModule implements EntryPoint {
Label label = new Label("Hello, GWT!");
@Override
public void onModuleLoad() {
RootPanel.get().add(label);
}
}
WebModule.gwt.xml
:
<?xml version="1.0" encoding="UTF-8"?>
<module rename-to="web-module">
<inherits name="com.google.gwt.user.User"/>
<inherits name="com.google.gwt.user.theme.standard.Standard"/>
<entry-point class="com.mywebapp.client.modules.WebModule"/>
<source path='client'/>
<source path='shared'/>
</module>
web.xml
:
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
version="2.5"
xsi:schemaLocation=
"http://java.sun.com/xml/ns/javaee
http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
<welcome-file-list>
<welcome-file>web-module-host-page.html</welcome-file>
</welcome-file-list>
<servlet>
<servlet-name>SystemServiceServlet</servlet-name>
<servlet-class>com.google.api.server.spi.SystemServiceServlet</servlet-class>
<init-param>
<param-name>services</param-name>
<param-value/>
</init-param>
</servlet>
<servlet-mapping>
<servlet-name>SystemServiceServlet</servlet-name>
<url-pattern>/_ah/spi/*</url-pattern>
</servlet-mapping>
</web-app>
web-module-host-page.html
:
<!doctype html>
<html>
<head>
<meta http-equiv="content-type" content="text/html; charset=UTF-8">
<link type="text/css" rel="stylesheet" href="css/web-module.css">
<title>Hello, GWT!</title>
<script type="text/javascript" language="javascript" src="mywebapp/mywebapp.nocache.js"></script>
</head>
<body>
<iframe src="javascript:''" id="__gwt_historyFrame" tabIndex='-1' style="position:absolute;width:0;height:0;border:0"></iframe>
<noscript>
Turn on javascript!
</noscript>
</body>
</html>
要尝试从Eclipse运行它(在开发模式下,以便我可以从指向localhost
url的浏览器运行/调试),我创建了一个新的运行配置,如下所示:
Run Configurations
Main tab
Main class: com.google.gwt.dev.DevMode
Server tab
"Run built-in server" is checked at Port 8888
GWT tab
Code server port: 9997
Available modules:
AppModule - com.mywebapp.client.modules.AppModule
WebModule - com.mywebapp.client.modules.WebModule
Arguments tab - see below
参数选项卡&gt;&gt;程序参数:
-remoteUI“$ {gwt_remote_ui_server_port}:$ {unique_id}”-startupUrl web-module-host-page.html -logLevel INFO -codeServerPort 9997 -port 8888 -server com.google.appengine.tools.development.gwt。 AppEngineLauncher -war / home / myuser / sandbox / workbench / eclipse / workspace / mywebapp / war com.mywebapp.client.modules.WebModule com.mywebapp.client.modules.AppModule
参数选项卡&gt;&gt; VM参数:
-Ddatastore.default_high_rep_job_policy_unapplied_job_pct = 50 -Xmx512m -javaagent:/home/myuser/sandbox/workbench/google/gae-sdk/1.7.1/appengine-java-sdk-1.7.1/lib/agent/appengine-agent的.jar
当我尝试运行此配置时,我得到以下控制台输出:
Loading modules
com.mywebapp.client.modules.WebModule
[ERROR] Invalid name 'web-module'
[ERROR] Failure while parsing XML
com.google.gwt.core.ext.UnableToCompleteException: (see previous log entries)
at com.google.gwt.dev.cfg.ModuleDefSchema$NullableNameAttrCvt.convertToArg(ModuleDefSchema.java:1048)
at com.google.gwt.dev.util.xml.HandlerArgs.convertToArg(HandlerArgs.java:64)
at com.google.gwt.dev.util.xml.HandlerMethod.invokeBegin(HandlerMethod.java:221)
at com.google.gwt.dev.util.xml.ReflectiveParser$Impl.startElement(ReflectiveParser.java:294)
at org.apache.xerces.parsers.AbstractSAXParser.startElement(Unknown Source)
at org.apache.xerces.impl.dtd.XMLDTDValidator.startElement(Unknown Source)
at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanStartElement(Unknown Source)
at org.apache.xerces.impl.XMLDocumentScannerImpl$ContentDispatcher.scanRootElementHook(Unknown Source)
at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown Source)
at org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown Source)
at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
at org.apache.xerces.parsers.XMLParser.parse(Unknown Source)
at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source)
at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown Source)
at com.google.gwt.dev.util.xml.ReflectiveParser$Impl.parse(ReflectiveParser.java:347)
at com.google.gwt.dev.util.xml.ReflectiveParser$Impl.access$200(ReflectiveParser.java:68)
at com.google.gwt.dev.util.xml.ReflectiveParser.parse(ReflectiveParser.java:418)
at com.google.gwt.dev.cfg.ModuleDefLoader.nestedLoad(ModuleDefLoader.java:296)
at com.google.gwt.dev.cfg.ModuleDefLoader$1.load(ModuleDefLoader.java:198)
at com.google.gwt.dev.cfg.ModuleDefLoader.doLoadModule(ModuleDefLoader.java:324)
at com.google.gwt.dev.cfg.ModuleDefLoader.loadFromClassPath(ModuleDefLoader.java:156)
at com.google.gwt.dev.DevModeBase.loadModule(DevModeBase.java:992)
at com.google.gwt.dev.DevMode.loadModule(DevMode.java:557)
at com.google.gwt.dev.DevMode.doStartup(DevMode.java:443)
at com.google.gwt.dev.DevModeBase.startUp(DevModeBase.java:1058)
at com.google.gwt.dev.DevModeBase.run(DevModeBase.java:811)
at com.google.gwt.dev.DevMode.main(DevMode.java:311)
[ERROR] Unexpected error while processing XML
com.google.gwt.core.ext.UnableToCompleteException: (see previous log entries)
at com.google.gwt.dev.util.xml.ReflectiveParser$Impl.parse(ReflectiveParser.java:371)
at com.google.gwt.dev.util.xml.ReflectiveParser$Impl.access$200(ReflectiveParser.java:68)
at com.google.gwt.dev.util.xml.ReflectiveParser.parse(ReflectiveParser.java:418)
at com.google.gwt.dev.cfg.ModuleDefLoader.nestedLoad(ModuleDefLoader.java:296)
at com.google.gwt.dev.cfg.ModuleDefLoader$1.load(ModuleDefLoader.java:198)
at com.google.gwt.dev.cfg.ModuleDefLoader.doLoadModule(ModuleDefLoader.java:324)
at com.google.gwt.dev.cfg.ModuleDefLoader.loadFromClassPath(ModuleDefLoader.java:156)
at com.google.gwt.dev.DevModeBase.loadModule(DevModeBase.java:992)
at com.google.gwt.dev.DevMode.loadModule(DevMode.java:557)
at com.google.gwt.dev.DevMode.doStartup(DevMode.java:443)
at com.google.gwt.dev.DevModeBase.startUp(DevModeBase.java:1058)
at com.google.gwt.dev.DevModeBase.run(DevModeBase.java:811)
at com.google.gwt.dev.DevMode.main(DevMode.java:311)
[ERROR] shell failed in doStartup method
任何GWT大师都可以找到我的配置错误(并解释原因!)?此处的异常/错误输出不是很具描述性。
答案 0 :(得分:4)
rename-to
中的名称必须是有效Java标识符的虚线链。 web-module
不是有效的Java标识符(其中的破折号)。
请尝试使用rename-to="webModule"
,rename-to="webmodule"
或rename-to="web.module"
,当然还要调整HTML主页中的<script>
标记(webModule/webModule.nocache.js
,{{分别为1}}或webmodule/webmodule.nocache.js
。
这与尝试运行多个模块或其他任何内容无关。