Почему я не вижу свое приложение Java / SalesForce / Google? - PullRequest
0 голосов
/ 22 января 2011

В настоящее время я работаю над учебником SalesForce.com под названием Force.com для Google App Engine для Java: Начало работы

Я установил плагин Google Eclipse, загрузилбиблиотеки и вошли в «Hello World App» (как видно на странице учебника):

package com.force;
import java.io.IOException;
import java.io.PrintWriter;

import javax.servlet.http.*;
import java.util.logging.*;

import com.sforce.ws.*;
import com.sforce.soap.partner.*;
import com.sforce.soap.partner.sobject.SObject;


@SuppressWarnings("serial")
public class HelloWorldServlet extends HttpServlet {
    private static final Logger log = Logger.getLogger(HelloWorldServlet.class.getName());

    private String username = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
    private String password = "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx";
    private PartnerConnection connection;

    public void doGet(HttpServletRequest req, HttpServletResponse resp) throws IOException {
        resp.setContentType("text/html");
        resp.getWriter().println("Hello, world. this is a test2");

        PrintWriter t = resp.getWriter();
        getConnection( t, req);
        if ( connection == null ) { return; }

        QueryResult result = null;

        try {

            result = connection.query(  "select id, name, phone from Account order by LastModifiedDate desc limit 10 ");

        } catch (ConnectionException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        for (SObject account : result.getRecords()) {
             t.println("<li>"+ (String)account.getField("Name") + "</li>");
        }
    }

    void getConnection(PrintWriter out, HttpServletRequest req)  { 

        try { 
            // build up a ConnectorConfig from a sid
            String sessionid = req.getParameter("sid");
            String serverurl = req.getParameter("srv");

            if ( connection == null ) { 

               out.println("<p>new connection needed</p>");
               // login to the Force.com Platform
               ConnectorConfig config = new ConnectorConfig();
               if ( sessionid != null && serverurl != null) {
                   config.setServiceEndpoint(serverurl);
                   config.setSessionId(sessionid);
                   config.setManualLogin(false);
                   out.println("using session from query string");
               }   else { 
                   config.setUsername(username);
                   config.setPassword(password);
               }
               connection = Connector.newConnection(config);
               out.println( connection.getConfig().getSessionId() );
               out.println( connection.getConfig().getServiceEndpoint() );
           } else { 
               out.println("<p> reuse existing connection"); 
               out.println( connection.getConfig().getSessionId() );
           }
           log.warning("Connection SID " +connection.getConfig().getSessionId());

        } catch ( ConnectionException ce) {
            log.warning("ConnectionException " +ce.getMessage());

            out.println( ce.getMessage() + " s " + ce.getClass() );

        }

    }
}

Когда я запускаю приложение как «Веб-приложение», я получаю в консоли следующее:

Initializing AppEngine server
Logging to JettyLogger(null) via com.google.apphosting.utils.jetty.JettyLogger
Successfully processed D:\education\java\HelloWorldOriginal\war\WEB-INF/appengine-web.xml
Successfully processed D:\education\java\HelloWorldOriginal\war\WEB-INF/web.xml
The server is running at http://localhost:8888/
Warning: default mime table not found: C:\devtool\Java\jre6\lib\content-types.properties

Когда я пытаюсь посетить http://localhost:8080/, я вижу:

Oops! Google Chrome could not connect to localhost:8080
Did you mean: localhost-­8080.­com
Additional suggestions:
Try reloading: localhost:­8080
Search on Google:

Google Chrome Help - Why am I seeing this page?
©2011 Google - Google Home

Но когда я посещаю http://localhost:8888/, я получаю:

Web Application Starter Project

Please enter your name:
    Send

(Что также не является желаемым или ожидаемым результатом.)

Что это за пропуски content-type.properties и как я могу это исправить?Или это просто симптом более серьезной проблемы?

1 Ответ

1 голос
/ 24 января 2011

Вы проверили, что ваш web.xml направляет запросы на / в соответствующий класс обработчиков? Недостаточно просто написать класс - нужно убедиться, что входящие запросы направлены на него.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...