如何得到was服务器上的所有应用服务器的SOAP端口号
一般都是先知道soap端口,才能通过jmx监控was的程序,当然你可以通过配置文件得到这个端口号。最快的办法,登录WAS console,选择server-》application server-》server1(default),从这里边找到port一项,然后展开就可看到所有你需要的端口,默认SOAP是8880
这要看你这个项目对WebSphere服务器的依赖性如何,如果依赖性很强,比如用到了里面的一些jar,或者是module的话,那你就不能在tomcat下的运行。如果很弱的话,只是用到了环境与容器,那还是可以进行移植的。
IHS是计算机上定量处理色彩时通常采用RGB表色系统。IHS彩色坐标系统对颜色属性易于识别和量化,色彩的调整(数学变换)方便、灵活,因而往往进行RGB系统一IHS系统的彩色空间变换。
所谓IHS彩色变换,是指将标准RGB图像有效地分离为代表变间信息的明度(I)和代表波谱信息的色调(H)、饱和度(S)。
IHS(Intensity,Hue, Saturation)分别表示亮度或强度(I)、色调(H)和饱和度(S),它们是从人眼中认识颜色的三个特征。亮度是指人眼对光源或物体明亮程度的感觉,一般来说与物体的反射率成正比。色调,也称色别,是指彩色的类别,是彩色彼此相互区分的特征。饱和度是指彩色的纯洁性,一般来说颜色越鲜艳饱和度也越大。
扩展资料
为实现RGB到IHS的变换,要建立RGB空间和IHS空间的关系模型。常见的转换主要有球体彩色变换、圆柱体彩色变换、三角形彩色变换和单六角锥彩色变换4种。
IHS算法是图像融合技术中发展很早,现已成熟的一种空间变换算法。通过试验结果分析,球体变换和三角变换是比较理想的IHS变换形式。从计算量上又淘汰了球体变换,三角变换成为最理想的形式。三角变换的IHS算法可以很好的保留源图像的光谱信息和空间分辨率,运算量也较小,且易于实现。
-IHS
一台服务器能部署1个was,有些服务器支持可以多款办公软件。
一般的服务器因为兼容之类的问题是只能一台服务器一款办公软件,但是有些服务器支持一台服务器多款办公软件,如269私有云服务器,它就是一个整合了多款办公管理软件的智能一体化私有云服务器。
was_有道词典
was
英 [wɒz]
美 [wʌz]
be的第一和第三人称单数过去式
更多释义>>
[网络短语]
Was 有人,遭到,应用服务器(Websphere Application Server)
Life was 生活是
I was 我曾是,我曾经是,我才
has_有道词典
has
英 [hæz]
美 [hæz]
v 有,吃,得到,从事,允许,雇用,享有(have的第三人称单数);(亲属关系中)接受;拿;买到
更多释义>>
[网络短语]
Has 有着,有,人血清白蛋白
Has District 哈斯区,哈斯区
一 什么是REST
REST是REpresentational State Transfer的缩写 代表分布式超媒体系统(如World Wide Web)上的一种软件架构体系 并不仅仅是创建Web Service的一种方法 它最早由Roy Fielding于 年在其博士论文 Architectural Styles and the Design of Neork based Sofare Architectures 中提出 并定义了一些基本原则 简单的说 放到World Wide Web上 就是所有的应用程序对象和功能都可以抽象为一种资源(Resource) 并通过URI来定位并使用 因此 我们可以把符合REST原则的系统称为RESTful 也就是说 REST是一种架构风格 而不是一个标准 你永远不会看到W C发布一个叫REST的Specification
RESTful Web Service与基于SOAP和WSDL的Web Service有着很多的不同 它有着以下特点
·将Web Service作为一种资源 并通过URI来定位
·使用HTTP中的POST GET PUT和DELETE方法来代表对资源的CREATE READ UPDATE DELETE(CRUD)操作
·使用无状态通信
·传输XML或者SON
在JAX WS中提供了对开发和部署一个RESTful的Web Service的基本支持 即通过实现Provider接口使得Web Serivce可以对传输的XML消息进行完全的控制 因此我们可以在WAS CE中使用JAX WS开发一个RESTful的Web Service 对RESTful Web Service提供完整支持的JAX RS Specification将会加入Java EE 的大家庭中 当前的WAS CE V x是遵循Java EE 的企业级应用服务器 因此 若想使用JAX RS开发RESTful Web Service 请关注WAS CE的后续版本
二 开发环境设置
本文基于WAS CE的最新版本V 开发一个RESTful的Web Service 在开始编写代码之前 请确认如下的开发环境
·Sun JDK V
·Eclipse IDE for Java EE Developers Ganymede
·WASCE Eclipse Plug in (WEP) V
此外 WAS CE使用Axis 作为JAX WS引擎 但是由于其存在一个已知的关于HTTP Content Type Header的问题(在Axis 中才解决) 所以我们需要将JAX WS引擎切换成Apache CXF (WAS CE使用版本为V ) 不用担心 WAS CE的模块化架构 使这个过程十分简单 过程如下
启动WAS CE
打开Web //localhost: /console
进入Application > Plugins页面 点击Add Repository
由于WAS CE V 是基于Geronimo V 开发 所以我们也可以使用Geronimo的Server plug ins 在New Repository中输入
/ 然后点击Add Repository
选择刚刚添加的Repository 然后点击Show Plugins in selected repository
勾选上以下plug ins并且点击install按钮
在以上CXF相关的Plugin安装完成之后 我们需要更新WAS CE的配置文件 以使得WAS CE在启动时加载CXF以代替Axis (注意 在更改配置文件前先要停止WAS CE服务器)
停止WAS CE后 打开<WASCE_HOME>/var/config/config xml
去掉以下四个module的condition属性
<module name= nfigs/axis deployer/ /car condition= … />
<module name= nfigs/axis ejb deployer/ /car condition= … />
<module name= nfigs/cxf deployer/ /car condition= … />
<module name= nfigs/cxf ejb deployer/ /car condition= … />
增加load属性 axis 相关的为false cxf相关的为true
<module name= nfigs/axis deployer/ /car load= false />
<module name= nfigs/axis ejb deployer/ /car load= false />
<module name= nfigs/cxf deployer/ /car load= true />
<module name= nfigs/cxf ejb deployer/ /car load= true />
重新启动WAS CE服务器
三 开发一个简单的RESTful Web Service
在Eclipse中创建一个Dynamic Web Project作为Web Service的宿主
选择File >New >Dynamic Web Project
输入Project Name为HelloRestfulService
右击Java Resources src 新建一个class 其中package Name Interfaces如下设置
加入如下代码
package ibm wasce samples jaxws rest;import java io ByteArrayInputStream;import javax annotation Resource;import javax servlet ServletRequest;import javax xml parsers DocumentBuilder;import javax xml parsers DocumentBuilderFactory;import javax xml transform Source;import javax xml transform dom DOMSource;import javax xml transform stream StreamSource;import javax xml ws BindingType;import javax xml ws Provider;import javax xml ws WebServiceContext;import javax xml ws WebServiceProvider;import javax xml ws handler MessageContext;import javax xml ws HTTPBinding;import javax xml ws HTTPException;import w c dom Node;import w c dom NodeList;import xml sax InputSource;@WebServiceProvider@BindingType (value = HTTPBinding HTTP_BINDING )public class HelloWorld implements Provider<Source> { @Resource protected WebServiceContext wsContext ; public Source invoke(Source source) { try { String targetName = null ; if (source == null ) { //Get: Getting input from query string MessageContext mc = wsContext getMessageContext(); String query = (String) mc get(MessageContext QUERY_STRING ); System out println( Query String = + query); ServletRequest req = (ServletRequest) mc get(MessageContext SERVLET_REQUEST ); targetName = req getParameter( target ); } else { //POST: Getting input from input box Node n = null ; if (source instanceof DOMSource) { n = ((DOMSource) source) getNode(); } else if (source instanceof StreamSource) { StreamSource streamSource = (StreamSource) source; DocumentBuilder builder = DocumentBuilderFactory newInstance() newDocumentBuilder(); InputSource inputSource = null ; if (streamSource getInputStream() != null ) { inputSource = new InputSource(streamSource getInputStream()); } else if (streamSource getReader() != null ) { inputSource = new InputSource(streamSource getReader()); } n = builder parse(inputSource); } else { throw new RuntimeException( Unsupported source: + source); } NodeList children = n getChildNodes(); for ( int i = ; i < children getLength(); i++) { Node child = em(i); if (child getNodeName() equals( people )) { targetName = child getAttributes() getNamedItem( target ) getNodeValue(); break ; } } }
String body = <ns:return xmlns:ns=\ \ > + <ns:HelloWorldResponse> + this sayHello(targetName) + </ns:HelloWorldResponse> + </ns:return> ; return new StreamSource( new ByteArrayInputStream(body getBytes()));
} catch (Exception e) { e printStackTrace(); throw new HTTPException( ); } }
private String sayHello(String target){ return Hello + target; }}
让我们看一看代码中的几个关键点
a) @WebServiceProvider 表明这个Web Service实现了Provider接口 可以对XML消息进行完全的处理
b) Provider 是这类Web Service都要实现的接口 它只有一个方法需要实现 即
public abstractjava lang Object invoke(java lang Object arg )
c) Source 是交换信息的载体
当Source对象为空时 表示是一个GET Request 因为这种情况下 所有信息是被拼成一个URI的参数 并传到这个URI对应的Web Service
否则 是一个POST Request 其内容会包括在一个Source对象内
另外 Response的内容也要放到一个Source对象内
编写web xml
为了使我们前面编写的Web Service能够成功部署到WAS CE中 我们需要将如下内容加入到web xml中 <servlet> <servlet name>Hello</servlet name> <servlet class> ibm wasce samples jaxws rest HelloWorld</servlet class></servlet><servlet mapping> <servlet name>Hello</servlet name> <url pattern>/Hello</url pattern></servlet mapping>
注意 这里只是借用了<servlet>和<servlet mapping>标签来帮助暴露Web Service 并不是真是要求这个Web Service必须要实现HttpServlet接口
部署 运行并测试这个Web Service
右击这个HelloRestfulService工程 选择Run As > Run on Server 会将其部署到WAS CE中 当Status栏变为Synchronized时 在Console中会有类似如下信息显示
通过访问如下地址 测试使用GET方式调用RESTful Web Service返回的结果
//localhost /HelloRestfulService/Hello?target=Rex
四 开发一个简单的RESTful Web Service Client
创建一个Dynamic Web Project作为Client
选择File >New >Dynamic Web Project
输入Project Name为HelloRestfulClient
新建一个testget jsp 加入如下内容 <form method= POST action= HelloGetMethodRequester > Target Name: <input type= text name= target > <input type= submit value= Submit ></form>
这个JSP用来为HelloGetMethodRequester Servlet提供参数
创建HelloGetMethodRequester Servlet 加入如下内容
protected void doPost(HttpServletRequest request HttpServletResponse response) throws ServletException IOException { PrintWriter ut = response getWriter(); String target = request getParameter( target );
String queryRequest = //localhost: /HelloRestfulService/Hellotarget= + target; GetMethod method = new GetMethod(queryRequest); HttpClient client = new HttpClient(); int statusCode = client executeMethod(method); if (statusCode != ) { //HttpStatus SC_OK System err println( Method failed: + method getStatusLine()); }
try { DocumentBuilder builder= DocumentBuilderFactory newInstance() newDocumentBuilder(); Document queryResponse = builder parse(method getResponseBodyAsStream()); XPath xPath = XPathFactory newInstance() newXPath(); NodeList nodes = (NodeList) xPath evaluate( /return queryResponse XPathConstants NODESET ); for ( int i = ; i < nodes getLength(); i++) { // Get eachxpathexpression as a string String str = (String) xPath evaluate( HelloWorldResponse em(i) XPathConstants STRING ); out println( Service return: + str); } } catch (Exception e) { e printStackTrace(); }}
在这个Servlet中我们用到了mons codec jar和mons 两个包 因此我们需要将它们加入到Build Path中
这两个包在WAS CE的如下目录中可以找到
<WASCE_HOME>\repository\mons codec\mons codec\ \mons codec jar
<WASCE_HOME >\repository\mons client\mons client\ \mons
让我们看一看这段Servlet代码中的一些关键点
a) 首先创建了一个HttpClient对象 并运行了GetMethod 即使用GET请求如下URI
//localhost /HelloRestfulService/Hello?target= + target
b) 如果成功返回 即statusCode为 则可以从method对象中得到返回的结果
method getResponseBodyAsStream()
c) 因为返回的结果为自定义的一段XML文档 所以我们可以使用XPath来处理并输出到页面上
编写部署计划geronimo web xml
为使这个Web Client能够成功部署到WAS CE中 我们还需要在geronimo web xml的<environment>中加入如下依赖 <dep:dependencies> <dep:dependency> <dep:groupId>mons codec</dep:groupId> <dep:artifactId>mons codec</dep:artifactId> <dep:version> </dep:version> <dep:type>jar</dep:type> </dep:dependency> <dep:dependency> <dep:groupId>mons client</dep:groupId> <dep:artifactId>mons client</dep:artifactId> <dep:version> </dep:version> <dep:type>jar</dep:type> </dep:dependency></dep:dependencies>
部署和运行
右击这个HelloRestfulClient工程 选择Run As > Run on Server 会将其部署到WAS CE中 当Status栏变为Synchronized时 表示部署成功
在浏览器中打开如下页面
输入 Rex 并点击Submit 可得到如下结果
五 总结
本文介绍了REST的基本概念 以及如何在WAS CE V 下开发一个RESTful Web Service和一个使用GET方式的Client 如果读者朋友有兴趣的话 也可以尝试扩展这个Client 如增加testpost jsp和HelloPostMethodRequester Servlet两个文件
testpost jsp包括一个文件上载框 用以上传一个XML文件
HelloPostMethodRequester Servlet用于将XML文件以POST方式传送给HelloWorld这个Service
事实上 我们的HelloWorld RESTful Web Service已经具备了处理接收一个XML文件的能力
六 资源链接
·WAS CE及Samples下载
·WAS CE Eclipse Plug in (aka WEP WAS CE s WTP Server Adapter)下载
·WAS CE文档
·WAS CE主页
lishixinzhi/Article/program/Java/ky/201311/28821
0条评论