Как использовать пользовательскую область с GlassFish 3.1? - PullRequest
2 голосов
/ 21 июня 2011

Я хотел бы использовать пользовательскую область со glassfish 3.1

Я взял два файла из этой темы, чтобы попробовать. Пользовательская область безопасности Glassfish не работает (невозможно найти LoginModule)

CustomRealm.java

package com.company.security.realm;
import com.sun.appserv.security.AppservRealm;
import com.sun.enterprise.security.auth.realm.BadRealmException;
import com.sun.enterprise.security.auth.realm.InvalidOperationException;
import com.sun.enterprise.security.auth.realm.NoSuchRealmException;
import com.sun.enterprise.security.auth.realm.NoSuchUserException;
import java.util.Enumeration;
import java.util.Properties;
import java.util.Vector;

public class CustomRealm extends AppservRealm
{
Vector<String> groups = new Vector<String>();

private String jaasCtxName;

private String startWith;

@Override
public void init(Properties properties)
throws BadRealmException, NoSuchRealmException {
    jaasCtxName = properties.getProperty("jaas-context", "customRealm");
    startWith = properties.getProperty("startWith", "z");
    groups.add("dummy");
}

@Override
public String getAuthType()
{
    return "Custom Realm";
}

public String[] authenticate(String username, char[] password) 
{
    // if (isValidLogin(username, password))
    return (String[]) groups.toArray();
}

@Override
public Enumeration getGroupNames(String username) 
throws InvalidOperationException, NoSuchUserException 
{
    return groups.elements();
}

@Override 
public String getJAASContext()
{
    return jaasCtxName;
}

public String getStartWith()
{
    return startWith;
}
}

И пользовательский модуль входа

package com.company.security.realm;

import com.sun.appserv.security.AppservPasswordLoginModule;
import com.sun.enterprise.security.auth.login.common.LoginException;
import java.util.Set;
import org.glassfish.security.common.PrincipalImpl;

public class CustomLoginModule extends AppservPasswordLoginModule
{    
    @Override
protected void authenticateUser() throws LoginException
{
    _logger.info("CustomRealm : authenticateUser for " +  _username);
    final CustomRealm realm = (CustomRealm)_currentRealm;

    if ( (_username == null) || (_username.length() == 0) || !_username.startsWith(realm.getStartWith())) 
        throw new LoginException("Invalid credentials");

    String[] grpList = realm.authenticate(_username, getPasswordChar()); 
    if (grpList == null) { 
        throw new LoginException("User not in groups");
    }

    _logger.info("CustomRealm : authenticateUser for " +  _username);

    Set principals = _subject.getPrincipals();
    principals.add(new PrincipalImpl(_username));

    this.commitUserAuthentication(grpList);

}
}

Я также добавил модуль в файл conf

customRealm {
com.company.security.realm.CustomLoginModule required;
};

И я копирую свой 2 .class в glassfish3 / glassfish / domains / domain1 / lib / classes /, а также glassfish3 / glassfish / lib

Каждый раз, когда я хочу создать новое царство, у меня появляется одна и та же ошибка.

 ./asadmin --port 4949 create-auth-realm --classname com.company.security.realm.CustomRealm --property jaas-context=customRealm:startWith=a customRealm     

remote failure: Creation of Authrealm customRealm failed.  com.sun.enterprise.security.auth.realm.BadRealmException: java.lang.ClassNotFoundException: com.company.security.realm.CustomRealm not found by org.glassfish.security [101]

com.sun.enterprise.security.auth.realm.BadRealmException: java.lang.ClassNotFoundException: com.company.security.realm.CustomRealm not found by org.glassfish.security [101]
Command create-auth-realm failed.

Я думаю, что я действительно не понимаю, как правильно добавить два моих файла в glassfish.

Эти два файла созданы и скомпилированы из затмения.Я создаю java-проект для входа в систему suctom.

Кто-то может помочь?

Спасибо заранее, loic

1 Ответ

0 голосов
/ 23 июля 2011

Вы упаковали его как модуль OSGi (см. Ответ в посте, на который вы ссылались)?Если это так, не копируйте файл jar в $ GF_HOME / lib или что-либо еще, вместо этого разверните его как модуль OSGi:

asadmin deploy --type osgi /path/to/CustomRealm.jar

Затем добавьте настройки login.confЧтобы быть в безопасности, я бы перезапустил GF (asadmin restart-domain), затем вы можете создать область с помощью команды, которая у вас есть.

...