{"id":1575,"date":"2010-04-27T10:27:00","date_gmt":"2010-04-27T15:27:00","guid":{"rendered":"http:\/\/jianmingli.com\/wp\/?p=1575"},"modified":"2010-04-27T11:44:11","modified_gmt":"2010-04-27T16:44:11","slug":"wsimport-disable-wrapper-style","status":"publish","type":"post","link":"https:\/\/jianmingli.com\/wp\/?p=1575","title":{"rendered":"wsimport: Disable Wrapper Style"},"content":{"rendered":"<span id=\"Default_Behavior\"><h3>Default Behavior<\/h3><\/span>\n<p>In JAX-WS reference implementation, &#8216;wsimport&#8217; defaults to wrapper doc\/lit style when generating Java classes from WSDL. In doing so, the generated &#8216;PortType&#8217; interface class sometimes uses &#8216;javax.xml.ws.Holder<String>&#8216; class as input parameters extensively. For example,<\/p>\n<pre lang=\"java\">\r\npublic void startOperation(\r\n    XMLGregorianCalendar eventTime,\r\n    OpConfigs opConfigs,\r\n    Location location, \r\n    Holder<String> status, \r\n    Holder<String> description) {\r\n    \/\/ TODO Auto-generated method stub\r\n    return null;\r\n  }\r\n}<\/pre>\n<span id=\"Disable_Wrapper_Style\"><h3>Disable Wrapper Style<\/h3><\/span>\n<p>You can use a custom binding file to disable the default wrapper style as follows if you need to.<br \/>\n* Create a custom binding file, e.g. CustomBinding.xml.<\/p>\n<pre lang=\"xml\">\r\n<bindings\r\n    xmlns:wsdl=\"http:\/\/schemas.xmlsoap.org\/wsdl\/\"\r\n    wsdlLocation=\"OperationService.wsdl\"\r\n    xmlns=\"http:\/\/java.sun.com\/xml\/ns\/jaxws\">\r\n        <!-- Disable default wrapper style -->\r\n        <enableWrapperStyle>false<\/enableWrapperStyle>\r\n<\/bindings><\/pre>\n<p>* Including &#8216;binding&#8217; element in &#8216;wsimport&#8217; Ant task.<\/p>\n<pre lang=\"xml\">\r\n<wsimport\r\n  debug=\"true\"\r\n  verbose=\"${verbose}\"\r\n  keep=\"true\"\r\n  destdir=\"${generated.dir}\"\r\n  package=\"${src.pkg.name}.server\"\r\n  wsdl=\"${wsdl.file}\">\r\n  <binding dir=\"${basedir}\/etc\" \r\n    includes=\"CustomBinding.xml\"\/>\r\n<\/wsimport>\r\n<\/pre>\n<p>After setting &#8216;enableWrapperStyle&#8217; to false, the same generated operation name in PortType class becomes:<\/p>\n<pre lang=\"java\">\r\npublic Response startOperation(TStartOperation parameters) {\r\n  \/\/ TODO Auto-generated method stub\r\n  return null;\r\n}\r\n<\/pre>\n<span id=\"For_Simpler_and_Better_Typed_Binding\"><h3>For Simpler and Better Typed Binding<\/h3><\/span>\n<p>* Create a new JAXB binding file, e.g. simple.xjb:<\/p>\n<pre lang=\"xml\">\r\n<?xml version=\"1.0\" encoding=\"UTF-8\"?>\r\n<!--\r\n  This enables the simple binding mode in JAXB.\r\n  See http:\/\/weblogs.java.net\/blog\/kohsuke\/archive\/2006\/03\/simple_and_bett.html\r\n-->\r\n<jaxb:bindings\r\n  xmlns:jaxb=\"http:\/\/java.sun.com\/xml\/ns\/jaxb\" jaxb:version=\"2.0\"\r\n  xmlns:xjc= \"http:\/\/java.sun.com\/xml\/ns\/jaxb\/xjc\" jaxb:extensionBindingPrefixes=\"xjc\">\r\n  \r\n  <jaxb:globalBindings>\r\n    <xjc:simple \/>\r\n  <\/jaxb:globalBindings>\r\n<\/jaxb:bindings>\r\n<\/pre>\n<p>* Specify in wsimport Ant task:<\/p>\n<pre lang=\"xml\">\r\n<wsimport\r\n  debug=\"true\"\r\n  verbose=\"${verbose}\"\r\n  keep=\"true\"\r\n  destdir=\"${generated.dir}\"\r\n  package=\"${src.pkg.name}.server\"\r\n  wsdl=\"${wsdl.file}\">\r\n  <binding dir=\"${basedir}\/etc\" \r\n    includes=\"CustomBinding.xml,simple.xjb\"\/>\r\n<\/wsimport>\r\n<\/pre>\n<p>* The operation now looks like this:<\/p>\n<pre lang=\"java\">\r\npublic Response startOperation(StartOperation parameters) {\r\n  \/\/ TODO Auto-generated method stub\r\n  return null;\r\n}\r\n<\/pre>\n<p>Parameter name &#8216;StartOperation&#8217; is more readable now among benefits.<\/p>\n<span id=\"References\"><h2>References<\/h2><\/span>\n<p>* jaxws-ri\/docs\/customizations.html<br \/>\n* <a href=\"http:\/\/java.sun.com\/webservices\/docs\/2.0\/jaxws\/customizations.html#2.2_Wrapper_Style\">Wrapper Style<\/a><br \/>\n* <a href=\"https:\/\/jax-ws.dev.java.net\/guide\/Customizing_XML_Schema_binding.html\">Customizing XML Schema binding<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Default Behavior In JAX-WS reference implementation, &#8216;wsimport&#8217; defaults to wrapper doc\/lit style when generating Java classes from WSDL. In doing so, the generated &#8216;PortType&#8217; interface class sometimes uses &#8216;javax.xml.ws.Holder&#8216; class as input parameters extensively. For example, public void startOperation( XMLGregorianCalendar &hellip; <a href=\"https:\/\/jianmingli.com\/wp\/?p=1575\">Continue reading <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_exactmetrics_skip_tracking":false,"_exactmetrics_sitenote_active":false,"_exactmetrics_sitenote_note":"","_exactmetrics_sitenote_category":0,"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[41],"tags":[],"class_list":["post-1575","post","type-post","status-publish","format-standard","hentry","category-jax-ws"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"jetpack_shortlink":"https:\/\/wp.me\/p8cRUO-pp","_links":{"self":[{"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=\/wp\/v2\/posts\/1575","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1575"}],"version-history":[{"count":6,"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=\/wp\/v2\/posts\/1575\/revisions"}],"predecessor-version":[{"id":1581,"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=\/wp\/v2\/posts\/1575\/revisions\/1581"}],"wp:attachment":[{"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1575"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1575"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/jianmingli.com\/wp\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1575"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}