Google App Engine - początek

Google App Engine - początek
ObiałyOrzeł
ObiałyOrzeł
  • Rejestracja:około 10 lat
  • Ostatnio:prawie 3 lata
  • Postów:28
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)

edytowany 1x, ostatnio: ObiałyOrzeł
Haskell
  • Rejestracja:prawie 10 lat
  • Ostatnio:12 miesięcy
  • Postów:4700
0

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


Zaglądali do kufrów, zaglądali do waliz, nie zajrzeli do d**y - tam miałem socjalizm. Czesław Miłosz
Zobacz pozostałe 7 komentarzy
Haskell
Może od razu niech na kartce napisze...
Wizzie
@Haskell ty brutalu :*
ObiałyOrzeł
ObiałyOrzeł
Może zamiast się kłócić, który IDE jest lepszy to ktoś by pomógł rozwiązać mój problem ? hmm ?
Haskell
Męcz @spartanPAGE to on twierdzi, że GAE chodzi na Netbeans.
SH
@ObiałyOrzeł To, że można grabkami wykopać dół, nie znaczy, że tak należy to robić. A że mało osób, używa wideł do kopania dołów, ciężko znaleźć kogoś kto się na tym zna i potrafi udzielić porady, bo przecież większość chłopa powie ci tylko jak to zrobić szpadlem. Narzekanie na IDE nie jest tutaj bezpodstawne i nie tak łatwo pomóc, jak mało kto używa takie rozwiązania (nie bez powodu zresztą)
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ę

ObiałyOrzeł
ObiałyOrzeł
  • Rejestracja:około 10 lat
  • Ostatnio:prawie 3 lata
  • Postów:28
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 ?

edytowany 1x, ostatnio: ObiałyOrzeł
Wizzie
  • Rejestracja:prawie 11 lat
  • Ostatnio:prawie 8 lat
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

ObiałyOrzeł
ObiałyOrzeł
Mam mavena zainstalowanego ale nie potrafię z niego jeszcze korzystać :/ Zrobię w przyszłości to na pewno
ObiałyOrzeł
ObiałyOrzeł
  • Rejestracja:około 10 lat
  • Ostatnio:prawie 3 lata
  • Postów:28
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 :/

Kopiuj
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 SelectChannelConnector@127.0.0.1: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

Wibowit
  • Rejestracja:około 20 lat
  • Ostatnio:około 8 godzin
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ć.


"Programs must be written for people to read, and only incidentally for machines to execute." - Abelson & Sussman, SICP, preface to the first edition
"Ci, co najbardziej pragną planować życie społeczne, gdyby im na to pozwolić, staliby się w najwyższym stopniu niebezpieczni i nietolerancyjni wobec planów życiowych innych ludzi. Często, tchnącego dobrocią i oddanego jakiejś sprawie idealistę, dzieli od fanatyka tylko mały krok."
Demokracja jest fajna, dopóki wygrywa twoja ulubiona partia.
ObiałyOrzeł
ObiałyOrzeł
  • Rejestracja:około 10 lat
  • Ostatnio:prawie 3 lata
  • Postów:28
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:

Kopiuj
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:

Kopiuj
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

Zarejestruj się i dołącz do największej społeczności programistów w Polsce.

Otrzymaj wsparcie, dziel się wiedzą i rozwijaj swoje umiejętności z najlepszymi.