2011-01-04 4 views
1

Я работаю над домашним заданием и застреваю. Задача состоит в обслуживании объектов с использованием службы по умолчанию. Но когда я пытаюсь использовать ссылку, происходят странные вещи. Некоторая часть corba печатает трассировку стека, но исключение не генерируется. Проблема возникает, когда сервер получает ссылку и должен вызывать на ней какой-то метод. Ссылка затем сокращается и не содержит идентификатора объекта (что означает, что реализация моего слуга не может сделать ничего разумного).Неисправные ссылки на объект CORBA

Это реализация слуге, где появляется проблема:.

public class ModelFileImpl extends ModelFilePOA{ 
    @Override 
    public String getName() { 
     try { 
      return new String(_poa().reference_to_id(_this_object())); 
     } catch (Throwable e) {} 
     assert false; 
     return null; 
    } 
} 

Если я _this_object() ToString() внутри блока попытаться положить его в dior -i я получаю это:

------IOR components----- 
TypeId : IDL:termproject/idl/ModelFile:1.0 
TAG_INTERNET_IOP Profiles: 
    Profile Id:  0 
    IIOP Version:  1.2 
    Host:   127.0.0.1 
    Port:   45954 
    Object key (URL): %AF%AB%CB%00%00%00%00%20Q%BA%F4%FF%00%00%00%01%00%00%00%00%00%00%00%01%0000%00%08RootPOA%00%00%00%00%08%00%00%00%02%00%00%00%00%14 
    Object key (hex): 0xAF AB CB 00 00 00 00 20 51 BA F4 FF 00 00 00 01 00 00 00 00 00 00 00 01 00 00 00 08 52 6F 6F 74 50 4F 41 00 00 00 00 08 00 00 00 02 00 00 00 00 14 
    -- Found 2 Tagged Components-- 
    #0: TAG_CODE_SETS 
     ForChar native code set Id: ISO8859_1 
     Char Conversion Code Sets: UTF8 
, Unknown TCS: 10020 
     ForWChar native code set Id: UTF16 
     WChar Conversion Code Sets: Unknown TCS: 10100 
    Unknown tag : 38 

однако часть сервера, что делает ссылку и клиент увидеть ссылку как

------IOR components----- 
TypeId : IDL:termproject/idl/ModelFile:1.0 
TAG_INTERNET_IOP Profiles: 
    Profile Id:  0 
    IIOP Version:  1.2 
    Host:   127.0.0.1 
    Port:   45954 
    Object key (URL): %AF%AB%CB%00%00%00%00%20Q%BA%F4%FF%00%00%00%01%00%00%00%00%00%00%00%02%00%00%00%08RootPOA%00%00%00%00%09modelPoa%00%00%00%00%00%00%00%10testModel1.MyIDL%14 
    Object key (hex): 0xAF AB CB 00 00 00 00 20 51 BA F4 FF 00 00 00 01 00 00 00 00 00 00 00 02 00 00 00 08 52 6F 6F 74 50 4F 41 00 00 00 00 09 6D 6F 64 65 6C 50 6F 61 00 00 00 00 00 00 00 10 74 65 73 74 4D 6F 64 65 6C 31 2E 4D 79 49 44 4C 14 
    -- Found 2 Tagged Components-- 
    #0: TAG_CODE_SETS 
     ForChar native code set Id: ISO8859_1 
     Char Conversion Code Sets: UTF8 
, Unknown TCS: 10020 
     ForWChar native code set Id: UTF16 
     WChar Conversion Code Sets: Unknown TCS: 10100 
    Unknown tag : 38 

(«modelPoa» (имя poa, работающего с клиентами по умолчанию) и «testModel1.MyIDL» (идентификатор объекта) в ключе объекта отсутствует в первом)

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

Это, как я создавать ссылки:

ret[i] = ModelFileHelper.narrow(modelFilePoa.create_reference_with_id(files[i].getBytes(), ModelFileHelper.id())); 

И это, как я настроить сервер:

// init ORB 
ORB orb = ORB.init(args, null); 

// init POA 
POA poa = POAHelper.narrow(orb.resolve_initial_references("RootPOA")); 

// create the POA for the models. 
Policy[] policies = { 
    poa.create_request_processing_policy(RequestProcessingPolicyValue.USE_DEFAULT_SERVANT), 
    poa.create_servant_retention_policy(ServantRetentionPolicyValue.NON_RETAIN), 
    poa.create_id_assignment_policy(IdAssignmentPolicyValue.USER_ID) 
}; 

POA modelPoa = poa.create_POA("modelPoa", poa.the_POAManager(), policies); 
modelPoa.the_POAManager().activate(); 

modelPoa.set_servant(new ModelFileImpl()); 

modelPoa.the_POAManager().activate(); 

ModelStoreImpl impl = new ModelStoreImpl(modelPoa); 
// create the object reference 
org.omg.CORBA.Object obj = poa.servant_to_reference(impl); 

// ... store the IOR file ... 

orb.run(); 

Я был бы очень благодарен за любые указатели (или ссылки: -))

EDIT: После дня, проведенного отладки кода corba, я обнаружил, что проблема возникает, когда orb.peekInvocationInfo() throws EmptyStackException в методе _this_object() В комментариях сказано что-то о контексте вызова, но google не сообщает мне, что это такое.

ответ

0

Хорошо, так что я нашел обходной путь: В файле ModelFilePoa.java генерируется из файла IDL я переключил вызов моей реализации методы и создание ответа

String tmp = getName(); 
_out = handler.createReply(); 
_out.write_string(tmp); 

вместо

_out = handler.createReply(); 
_out.write_string(getName(); 

Таким образом, информация о вызове остается в стеке во время моих методов и _this_object() работает должным образом. Ужасно, но работает :-)

 Смежные вопросы

  • Нет связанных вопросов^_^