Google App Engine - początek

0

Witam serdecznie.

Chcę umieścić stronę internetową w Google App Engine jednak mam z tym problem. Napiszę po kolei co robię:

Postępuję tak jak piszą: https://console.developers.google.com/start/appengine

Mam ściągnięte Google App Engine SDK for Java
mam zainstalowanego Apache Maven
69530f0bf7.png
ściągnąłem Java sample code.

Uruchamiam teraz Netbeans 8.0.2.

Dodałem server Google
7df87bcbd6.png

Dodałem Java sample code do projektów:
f15409b3a3.png

I gdy uruchamiam projekt wyskakuje mi:
4612bd934d.png

Dodatkowo gdy chce wykonać "Build" projekt to mam takie co:
5eb0140657.png

Jak mam rozwiązać ten problem(y) ?

Dodatkowo dodam, że w przyszłości chce tam wysyłać aplikacje webowe z wykorzystaniem JSF wraz z PrimeFaces oraz bazą danych MySQL

EDIT:

Jest mi bez znaczenia z jakiego hostingu będę korzystał, najlepiej żeby bez reklam był - nic więcej (no i oczywiście JavaEE obsługiwał ).
Jeśli znacie lepsze lub łatwiejsze w obsłudze to podajcie (najlepiej wraz z instrukcją jeśli wymaga to specjalnych umiejętności :D)

0

Nie możesz użyć jakiegoś normalnego IDE np. Eclipse?

0

Ja od około 3 tygodni walczę z GAE, trochę mi się udało nauczyć. Moje doświadczenia:

  1. Polecam eclipse, jest sporo tutoriali i obecnie jednym kliknięciem wgrywam cały kod na chmurę. - https://developers.google.com/eclipse/docs/appengine
  2. GAE jak i GCE ( z którego też korzystam) sa świetnie opisane na swoich stronach - https://cloud.google.com/appengine/docs/java/gettingstarted/setup

Jeżeli będziesz miał problemy z eclipse to chętnie pomogę

0

Na szczęście miałem już zainstalowanego wcześniej eclipse (bo kiedyś na nim pisałem) i spróbowałem przez niego. Wzorowałem się na tym

No i się udało :) Zrobiłem wszystko jak mówił i moja apka działa :)

Spróbuję jeszcze wystać jakieś większe projekty - ciekawe czy się uda :D

EDIT:

Mam zrobione projekt w NetBeans + JSF z primeFaces. Jak mam go przenieść co Eclipsa w celu późniejszego wysłania go tam ?

0

A nie używasz mavena czy innego toola? Jak nie to po prostu tworzysz projekt z plików źródłowych: http://stackoverflow.com/questions/21535023/how-to-get-your-netbeans-project-into-eclipse

0

Potrzebuje pomocy !
Jak mam stworzyć apke z JSF i następnie ją wysłać ? Próbuję i próbuję korzystając z tutoriali i nic :/

Please visit https://developers.google.com/appengine/downloads for the latest SDK.
********************************************************
wrz 20, 2015 3:05:05 PM com.google.appengine.tools.development.SystemPropertiesManager setSystemProperties
INFO: Overwriting system property key 'java.util.logging.config.file', value 'D:\Programy\NetBeans\appengine-java-sdk-1.9.26\config\sdk\logging.properties' with value 'WEB-INF/logging.properties' from 'D:\Programy\Eclipse\1Projekty\GoogleAppJSF\war\WEB-INF\appengine-web.xml'
wrz 20, 2015 3:05:05 PM com.google.apphosting.utils.jetty.JettyLogger info
INFO: Logging to JettyLogger(null) via com.google.apphosting.utils.jetty.JettyLogger
wrz 20, 2015 3:05:05 PM com.google.apphosting.utils.jetty.JettyLogger info
INFO: jetty-6.1.x
wrz 20, 2015 3:05:06 PM com.google.apphosting.utils.jetty.JettyLogger warn
WARNING: EXCEPTION 
java.lang.ClassNotFoundException: javax.faces.webapp.FacesServlet
	at java.net.URLClassLoader.findClass(URLClassLoader.java:381)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:424)
	at com.google.appengine.tools.development.IsolatedAppClassLoader.loadClass(IsolatedAppClassLoader.java:199)
	at java.lang.ClassLoader.loadClass(ClassLoader.java:357)
	at org.mortbay.util.Loader.loadClass(Loader.java:91)
	at org.mortbay.util.Loader.loadClass(Loader.java:71)
	at org.mortbay.jetty.servlet.Holder.doStart(Holder.java:73)
	at org.mortbay.jetty.servlet.ServletHolder.doStart(ServletHolder.java:242)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.servlet.ServletHandler.initialize(ServletHandler.java:685)
	at org.mortbay.jetty.servlet.Context.startContext(Context.java:140)
	at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1250)
	at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:517)
	at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:467)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
	at org.mortbay.jetty.Server.doStart(Server.java:224)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at com.google.appengine.tools.development.JettyContainerService.startContainer(JettyContainerService.java:265)
	at com.google.appengine.tools.development.AbstractContainerService.startup(AbstractContainerService.java:288)
	at com.google.appengine.tools.development.AutomaticInstanceHolder.startUp(AutomaticInstanceHolder.java:26)
	at com.google.appengine.tools.development.AbstractModule.startup(AbstractModule.java:87)
	at com.google.appengine.tools.development.Modules.startup(Modules.java:105)
	at com.google.appengine.tools.development.DevAppServerImpl.doStart(DevAppServerImpl.java:258)
	at com.google.appengine.tools.development.DevAppServerImpl.access$000(DevAppServerImpl.java:47)
	at com.google.appengine.tools.development.DevAppServerImpl$1.run(DevAppServerImpl.java:213)
	at com.google.appengine.tools.development.DevAppServerImpl$1.run(DevAppServerImpl.java:211)
	at java.security.AccessController.doPrivileged(Native Method)
	at com.google.appengine.tools.development.DevAppServerImpl.start(DevAppServerImpl.java:211)
	at com.google.appengine.tools.development.DevAppServerMain$StartAction.apply(DevAppServerMain.java:270)
	at com.google.appengine.tools.util.Parser$ParseResult.applyArgs(Parser.java:48)
	at com.google.appengine.tools.development.DevAppServerMain.run(DevAppServerMain.java:218)
	at com.google.appengine.tools.development.DevAppServerMain.main(DevAppServerMain.java:209)

wrz 20, 2015 3:05:06 PM com.google.appengine.tools.development.ApiProxyLocalImpl log
SEVERE: javax.servlet.ServletContext log: unavailable
javax.servlet.UnavailableException: javax.faces.webapp.FacesServlet
	at org.mortbay.jetty.servlet.Holder.doStart(Holder.java:79)
	at org.mortbay.jetty.servlet.ServletHolder.doStart(ServletHolder.java:242)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.servlet.ServletHandler.initialize(ServletHandler.java:685)
	at org.mortbay.jetty.servlet.Context.startContext(Context.java:140)
	at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1250)
	at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:517)
	at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:467)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
	at org.mortbay.jetty.Server.doStart(Server.java:224)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at com.google.appengine.tools.development.JettyContainerService.startContainer(JettyContainerService.java:265)
	at com.google.appengine.tools.development.AbstractContainerService.startup(AbstractContainerService.java:288)
	at com.google.appengine.tools.development.AutomaticInstanceHolder.startUp(AutomaticInstanceHolder.java:26)
	at com.google.appengine.tools.development.AbstractModule.startup(AbstractModule.java:87)
	at com.google.appengine.tools.development.Modules.startup(Modules.java:105)
	at com.google.appengine.tools.development.DevAppServerImpl.doStart(DevAppServerImpl.java:258)
	at com.google.appengine.tools.development.DevAppServerImpl.access$000(DevAppServerImpl.java:47)
	at com.google.appengine.tools.development.DevAppServerImpl$1.run(DevAppServerImpl.java:213)
	at com.google.appengine.tools.development.DevAppServerImpl$1.run(DevAppServerImpl.java:211)
	at java.security.AccessController.doPrivileged(Native Method)
	at com.google.appengine.tools.development.DevAppServerImpl.start(DevAppServerImpl.java:211)
	at com.google.appengine.tools.development.DevAppServerMain$StartAction.apply(DevAppServerMain.java:270)
	at com.google.appengine.tools.util.Parser$ParseResult.applyArgs(Parser.java:48)
	at com.google.appengine.tools.development.DevAppServerMain.run(DevAppServerMain.java:218)
	at com.google.appengine.tools.development.DevAppServerMain.main(DevAppServerMain.java:209)

wrz 20, 2015 3:05:06 PM com.google.apphosting.utils.jetty.JettyLogger warn
WARNING: failed Faces Servlet: java.lang.NullPointerException
wrz 20, 2015 3:05:06 PM com.google.apphosting.utils.jetty.JettyLogger warn
WARNING: Failed startup of context com.google.appengine.tools.development.DevAppEngineWebAppContext@7161d8d1{/,D:\Programy\Eclipse\1Projekty\GoogleAppJSF\war}
java.lang.NullPointerException
	at java.lang.Class.isAssignableFrom(Native Method)
	at org.mortbay.jetty.servlet.ServletHolder.doStart(ServletHolder.java:256)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.servlet.ServletHandler.initialize(ServletHandler.java:685)
	at org.mortbay.jetty.servlet.Context.startContext(Context.java:140)
	at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1250)
	at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:517)
	at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:467)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130)
	at org.mortbay.jetty.Server.doStart(Server.java:224)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at com.google.appengine.tools.development.JettyContainerService.startContainer(JettyContainerService.java:265)
	at com.google.appengine.tools.development.AbstractContainerService.startup(AbstractContainerService.java:288)
	at com.google.appengine.tools.development.AutomaticInstanceHolder.startUp(AutomaticInstanceHolder.java:26)
	at com.google.appengine.tools.development.AbstractModule.startup(AbstractModule.java:87)
	at com.google.appengine.tools.development.Modules.startup(Modules.java:105)
	at com.google.appengine.tools.development.DevAppServerImpl.doStart(DevAppServerImpl.java:258)
	at com.google.appengine.tools.development.DevAppServerImpl.access$000(DevAppServerImpl.java:47)
	at com.google.appengine.tools.development.DevAppServerImpl$1.run(DevAppServerImpl.java:213)
	at com.google.appengine.tools.development.DevAppServerImpl$1.run(DevAppServerImpl.java:211)
	at java.security.AccessController.doPrivileged(Native Method)
	at com.google.appengine.tools.development.DevAppServerImpl.start(DevAppServerImpl.java:211)
	at com.google.appengine.tools.development.DevAppServerMain$StartAction.apply(DevAppServerMain.java:270)
	at com.google.appengine.tools.util.Parser$ParseResult.applyArgs(Parser.java:48)
	at com.google.appengine.tools.development.DevAppServerMain.run(DevAppServerMain.java:218)
	at com.google.appengine.tools.development.DevAppServerMain.main(DevAppServerMain.java:209)

wrz 20, 2015 3:05:06 PM com.google.apphosting.utils.jetty.JettyLogger info
INFO: Started [email protected]:8888
wrz 20, 2015 3:05:06 PM com.google.appengine.tools.development.AbstractModule startup
INFO: Module instance default is running at http://localhost:8888/
wrz 20, 2015 3:05:06 PM com.google.appengine.tools.development.AbstractModule startup
INFO: The admin console is running at http://localhost:8888/_ah/admin
wrz 20, 2015 3:05:06 PM com.google.appengine.tools.development.DevAppServerImpl doStart
INFO: Dev App Server is now running

Nie wiem co jeszcze dołączyć to wyślę tylko jak wygląda mój projekt:
5cf6b1c171.png

0

Q&A na SO typu: http://stackoverflow.com/questions/24173540/liferay-6-2-classnotfoundexception-javax-faces-webapp-facesservlet-when-pacl-i sugerują by usunąć problematyczną klasę z web.xml. Nie wiem czy ma to sens w twoim przypadku, ale możesz spróbować.

0

Korzystam z tego tutoriala:
http://www.mkyong.com/google-app-engine/google-app-engine-jsf-2-example/

I mam problemy jak zwykle :D
Wszystko przez klasę WebConfiguration.

Bez klas tej klasy wyskakuje mi błąd:

SEVERE: Critical error during deployment: 
java.lang.NoClassDefFoundError: javax.naming.InitialContext is a restricted class. Please see the Google  App Engine developer's guide for more details.
	at com.google.appengine.tools.development.agent.runtime.Runtime.reject(Runtime.java:52)
	at com.sun.faces.renderkit.ByteArrayGuard.setupKeyAndMac(Unknown Source)
	at com.sun.faces.renderkit.ByteArrayGuard.<init>(Unknown Source)
	at com.sun.faces.renderkit.ClientSideStateHelper.init(Unknown Source)
	at com.sun.faces.renderkit.ClientSideStateHelper.<init>(Unknown Source)
	at com.sun.faces.renderkit.ResponseStateManagerImpl.<init>(Unknown Source)
	at com.sun.faces.renderkit.RenderKitImpl.<init>(Unknown Source)
	at com.sun.faces.renderkit.RenderKitFactoryImpl.<init>(Unknown Source)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
	at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
	at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
	at java.lang.reflect.Constructor.newInstance(Constructor.java:422)
	at com.google.appengine.tools.development.agent.runtime.Runtime.newInstance_(Runtime.java:142)
	at com.google.appengine.tools.development.agent.runtime.Runtime.newInstance(Runtime.java:163)
	at javax.faces.FactoryFinderInstance.getImplGivenPreviousImpl(Unknown Source)
	at javax.faces.FactoryFinderInstance.getImplementationInstance(Unknown Source)
	at javax.faces.FactoryFinderInstance.getFactory(Unknown Source)
	at javax.faces.FactoryFinder.getFactory(Unknown Source)
	at com.sun.faces.config.processor.FactoryConfigProcessor.verifyFactoriesExist(Unknown Source)
	at com.sun.faces.config.processor.FactoryConfigProcessor.process(Unknown Source)
	at com.sun.faces.config.ConfigManager.initialize(Unknown Source)
	at com.sun.faces.config.ConfigureListener.contextInitialized(Unknown Source)
	at org.mortbay.jetty.handler.ContextHandler.startContext(ContextHandler.java:548)
	at org.mortbay.jetty.servlet.Context.startContext(Context.java:136)
	at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1250)
	at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:517)
i tak dalej...

Natomiast gdy wstawię tą klasę tak jak jest napisane w poradniku to wywali mi coś takiego:

WARNING: Error starting handlers
java.lang.NoSuchFieldError: EnableTransitionTimeNoOpFlash
	at com.sun.faces.config.InitFacesContext$ServletContextAdapter.<init>(Unknown Source)
	at com.sun.faces.config.InitFacesContext.<init>(Unknown Source)
	at com.sun.faces.config.ConfigureListener.contextInitialized(Unknown Source)
	at org.mortbay.jetty.handler.ContextHandler.startContext(ContextHandler.java:548)
	at org.mortbay.jetty.servlet.Context.startContext(Context.java:136)
	at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1250)
	at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:517)
	at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:467)
	at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50)
	at org.mortbay.jetty.handler.HandlerWrapper.doStart(Han
i tak dalej i dalej...

Patrzyłem na wszelakie fora i nic... Może coś źle zrozumiałem - nie wiem.
Będę wdzięczny za każdą wskazówkę :)

b9658bf561.png

1 użytkowników online, w tym zalogowanych: 0, gości: 1