• Post Reply Bookmark Topic Watch Topic
  • New Topic
programming forums Java Mobile Certification Databases Caching Books Engineering Micro Controllers OS Languages Paradigms IDEs Build Tools Frameworks Application Servers Open Source This Site Careers Other Pie Elite all forums
this forum made possible by our volunteer staff, including ...
Marshals:
  • Campbell Ritchie
  • Jeanne Boyarsky
  • Ron McLeod
  • Paul Clapham
  • Liutauras Vilda
Sheriffs:
  • paul wheaton
  • Rob Spoor
  • Devaka Cooray
Saloon Keepers:
  • Stephan van Hulst
  • Tim Holloway
  • Carey Brown
  • Frits Walraven
  • Tim Moores
Bartenders:
  • Mikalai Zaikin

problem in publishing web service

 
Greenhorn
Posts: 1
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
i am getting problems in publishing coffee break
service given in jawa web server development package
exercise samples

i ran "ant run-publish"
i got the below response:

javax.xml.registry.JAXRException:JAXR.UDDI.091:No
concept specified for this classification

at
sun.com.xml.registry.uddi.UDDIMAPPER.classification2CategoryBag(Unknown
Source)

at
sun.com.xml.registry.uddi.UDDIMAPPER.organisation2BuisinessEntity(Unknown
Source)

at
sun.com.xml.registry.uddi.UDDIMAPPER.organisations2BuisinessEntities(Unknown
Source)

at
sun.com.xml.registry.uddi.UDDIMAPPER.saveOrganisations(Unknown
Source)

at
sun.com.xml.registry.uddi.BuisinessLifeCycleManagerImpl.saveOrganisations(Unknown
Source)

at JAXRPublish.executePublish(Unknown Source)

at JAXRPublish.main(Unknown Source)

The code is :

import javax.xml.registry.*;
import javax.xml.registry.infomodel.*;
import java.net.*;
import java.security.*;
import java.util.*;

/**
* The JAXRPublish class consists of a main method, a
* makeConnection method, and an executePublish
method.
* It creates an organization and publishes it to a
registry.
*/
public class JAXRPublish {
Connection connection = null;

public JAXRPublish() {}

public static void main(String[] args) {
ResourceBundle bundle =
ResourceBundle.getBundle("JAXRExamples");

String queryURL =
bundle.getString("query.url");
String publishURL =
bundle.getString("publish.url");

// Edit to provide your own username and
password
// Defaults for Registry Server are
testuser/testuser
String username =
bundle.getString("registry.username");
String password =
bundle.getString("registry.password");

JAXRPublish jp = new JAXRPublish();

jp.makeConnection(queryURL, publishURL);

jp.executePublish(username, password);
}

/**
* Establishes a connection to a registry.
*
* @param queryUrlthe URL of the query registry
* @param publishUrlthe URL of the publish
registry
*/
public void makeConnection(String queryUrl,
String publishUrl) {

/*
* Specify proxy information in case you
* are going beyond your firewall.
*/
ResourceBundle bundle =
ResourceBundle.getBundle("JAXRExamples");
String httpProxyHost =
bundle.getString("http.proxyHost");
String httpProxyPort =
bundle.getString("http.proxyPort");
String httpsProxyHost =
bundle.getString("https.proxyHost");
String httpsProxyPort =
bundle.getString("https.proxyPort");

/*
* Define connection configuration properties.
* To publish, you need both the query URL and
the
* publish URL.
*/
Properties props = new Properties();

props.setProperty("javax.xml.registry.queryManagerURL",
queryUrl);

props.setProperty("javax.xml.registry.lifeCycleManagerURL",
publishUrl);

props.setProperty("com.sun.xml.registry.http.proxyHost",
httpProxyHost);

props.setProperty("com.sun.xml.registry.http.proxyPort",
httpProxyPort);

props.setProperty("com.sun.xml.registry.https.proxyHost",
httpsProxyHost);

props.setProperty("com.sun.xml.registry.https.proxyPort",
httpsProxyPort);


try {
// Create the connection, passing it the
// configuration properties
ConnectionFactory factory =
ConnectionFactory.newInstance();
factory.setProperties(props);
connection = factory.createConnection();
System.out.println("Created connection to
registry");
} catch (Exception e) {
e.printStackTrace();
if (connection != null) {
try {
connection.close();
} catch (JAXRException je) {}
}
}
}

/**
* Creates an organization, its classification,
and its
* services, and saves it to the registry.
*
* @param username the username for the registry
* @param password the password for the registry
*/
public void executePublish(String username,
String password) {

RegistryService rs = null;
BusinessLifeCycleManager blcm = null;
BusinessQueryManager bqm = null;

try {
rs = connection.getRegistryService();
blcm = rs.getBusinessLifeCycleManager();
bqm = rs.getBusinessQueryManager();
System.out.println("Got registry service,
query " +
"manager, and life cycle manager");

// Get authorization from the registry
PasswordAuthentication passwdAuth =
new PasswordAuthentication(username,
password.toCharArray());

Set creds = new HashSet();
creds.add(passwdAuth);
connection.setCredentials(creds);
System.out.println("Established security
credentials");

ResourceBundle bundle =

ResourceBundle.getBundle("JAXRExamples");

// Create organization name and
description
Organization org =

blcm.createOrganization(bundle.getString("org.name"));
//System.out.println(bundle.getString("org.name"));
InternationalString s =

blcm.createInternationalString(bundle.getString("org.description"));
org.setDescription(s);

// Create primary contact, set name
User primaryContact = blcm.createUser();
PersonName pName =

blcm.createPersonName(bundle.getString("person.name"));
primaryContact.setPersonName(pName);

// Set primary contact phone number
TelephoneNumber tNum =
blcm.createTelephoneNumber();

tNum.setNumber(bundle.getString("phone.number"));
Collection phoneNums = new ArrayList();
phoneNums.add(tNum);

primaryContact.setTelephoneNumbers(phoneNums);

// Set primary contact email address
EmailAddress emailAddress =

blcm.createEmailAddress(bundle.getString("email.address"));
Collection emailAddresses = new
ArrayList();
emailAddresses.add(emailAddress);

primaryContact.setEmailAddresses(emailAddresses);

// Set primary contact for organization
org.setPrimaryContact(primaryContact);

// Set classification scheme to NAICS
ClassificationScheme cScheme =

bqm.findClassificationSchemeByName(null,

bundle.getString("classification.scheme"));

// Create and add classification
Classification classification =
blcm.createClassification(cScheme,

bundle.getString("classification.name"),

bundle.getString("classification.value"));

Collection classifications = new
ArrayList();
classifications.add(classification);
org.addClassifications(classifications);

// Create services and service
Collection services = new ArrayList();
Service service =

blcm.createService(bundle.getString("service.name"));
InternationalString is =

blcm.createInternationalString(bundle.getString("service.description"));

service.setDescription(is);

// Create service bindings
Collection serviceBindings = new
ArrayList();
ServiceBinding binding =
blcm.createServiceBinding();
is =

blcm.createInternationalString(bundle.getString("svcbinding.description"));

binding.setDescription(is);
// allow us to publish a fictitious URL
without an error
binding.setValidateURI(false);

binding.setAccessURI(bundle.getString("svcbinding.accessURI"));

serviceBindings.add(binding);

// Add service bindings to service

service.addServiceBindings(serviceBindings);


// Add service to services, then add
services to organization
services.add(service);
org.addServices(services);


// Add organization and submit to registry
// Retrieve key if successful
Collection orgs = new ArrayList();
orgs.add(org);

BulkResponse response =
blcm.saveOrganizations(orgs);


Collection exceptions =
response.getExceptions();
if (exceptions == null) {
System.out.println("Organization
saved");

Collection keys =
response.getCollection();
Iterator keyIter = keys.iterator();
if (keyIter.hasNext()) {
javax.xml.registry.infomodel.Key
orgKey =

(javax.xml.registry.infomodel.Key) keyIter.next();
String id = orgKey.getId();
System.out.println("Organization
key is " + id);
}
} else {
Iterator excIter =
exceptions.iterator();
Exception exception = null;
while (excIter.hasNext()) {
exception = (Exception)
excIter.next();
System.err.println("Exception on
save: " +
exception.toString());
}
}
} catch (Exception e) {
e.printStackTrace();
} finally {
// At end, close connection to registry
if (connection != null) {
try {
connection.close();
} catch (JAXRException je) {}
}
}
}
}


Please solve my problem.
 
Trailboss
Posts: 23778
IntelliJ IDE Firefox Browser Java
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Please provide a smaller sample of the same problem.
 
ranger
Posts: 17347
11
Mac IntelliJ IDE Spring
  • Mark post as helpful
  • send pies
    Number of slices to send:
    Optional 'thank-you' note:
  • Quote
  • Report post to moderator
Also, when posting Code there is a code tag that will keep all your formatting like tabs.

Look under the Add Reply button and you will see buttons like URL, BOLD.

In the second column the third button says "CODE", click on this button and it will place Code tags in your reply. Then you can paste or type your code in there with Tabs and they will remain.

This makes it much easier for all of us to read the code and help you out.

Thanks

Mark
 
Do not set lab on fire. Or this tiny ad:
a bit of art, as a gift, that will fit in a stocking
https://gardener-gift.com
reply
    Bookmark Topic Watch Topic
  • New Topic