1

最近、Roo/Gwt プロジェクトを Google App Engine にデプロイしました。

私は数時間を費やしましたが、認証システムを追加する方法を段階的に示しているチュートリアルを見つけることができませんでした (Federated Login Api を使用)。

役立つコードを提供するこの非常に優れた記事を見つけました。

import java.io.IOException;
import java.io.PrintWriter;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;

import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import com.google.appengine.api.users.User;
import com.google.appengine.api.users.UserService;
import com.google.appengine.api.users.UserServiceFactory;

@SuppressWarnings("serial")
public class OpenIdDemoServlet extends HttpServlet {

    private static final Map<String, String> openIdProviders;
    static {
        openIdProviders = new HashMap<String, String>();
        openIdProviders.put("Google", "google.com/accounts/o8/id");
        openIdProviders.put("Yahoo", "yahoo.com");
        openIdProviders.put("MySpace", "myspace.com");
        openIdProviders.put("AOL", "aol.com");
        openIdProviders.put("MyOpenId.com", "myopenid.com");
    }

    @Override
    public void doGet(HttpServletRequest req, HttpServletResponse resp)
            throws IOException {
        UserService userService = UserServiceFactory.getUserService();
        User user = userService.getCurrentUser(); // or req.getUserPrincipal()
        Set<String> attributes = new HashSet();

        resp.setContentType("text/html");
        PrintWriter out = resp.getWriter();

        if (user != null) {
            out.println("Hello <i>" + user.getNickname() + "</i>!");
            out.println("[<a href=\""
                    + userService.createLogoutURL(req.getRequestURI())
                    + "\">sign out</a>]");
        } else {
            out.println("Hello world! Sign in at: ");
            for (String providerName : openIdProviders.keySet()) {
                String providerUrl = openIdProviders.get(providerName);
                String loginUrl = userService.createLoginURL(req
                        .getRequestURI(), null, providerUrl, attributes);
                out.println("[<a href=\"" + loginUrl + "\">" + providerName + "</a>] ");
            }
        }
    }
}

この認証モジュールをセットアップするにはどうすればよいですか? 「main.java」ファイルがないため、このコードをどこに配置すればよいですか?

どうもありがとうございました、

よろしく

4

1 に答える 1

1

これは、GWT 2.1/Roo 1.1.0 に実装するために進行中です。詳細については、こちらをご覧くださいhttps://jira.springsource.org/browse/ROO-1003

待ちきれない場合は、http://blog.springsource.com/2010/08/02/spring-security-in-google-app-engine/ にある Google App Engine の Spring Security の記事を確認して くださいただし、Roo でサポートされています (したがって、生成されたコードを変更すると、Roo を使い続けることは難しくなりますが、それでも可能です)。

于 2010-08-05T18:41:09.933 に答える