此处将为大家介绍关于解决将业务流程发布为WebService后无法访问的问题的详细内容,并且为您解答有关业务流程端到端的相关问题,此外,我们还将为您介绍关于ADF11g-031:将Applicatio
此处将为大家介绍关于解决将业务流程发布为WebService后无法访问的问题的详细内容,并且为您解答有关业务流程端到端的相关问题,此外,我们还将为您介绍关于ADF11g-031:将Application Module中的方法发布为webservice、ADF11g:将Application Module中的方法发布为webservice、AM使用指南之四:把AM中的方法发布为WebService、axis2实现webservice之使用services.xml文件发布WebService的有用信息。
本文目录一览:- 解决将业务流程发布为WebService后无法访问的问题(业务流程端到端)
- ADF11g-031:将Application Module中的方法发布为webservice
- ADF11g:将Application Module中的方法发布为webservice
- AM使用指南之四:把AM中的方法发布为WebService
- axis2实现webservice之使用services.xml文件发布WebService
解决将业务流程发布为WebService后无法访问的问题(业务流程端到端)
ADF11g-031:将Application Module中的方法发布为webservice
由于步骤比较简单,这里直接写图文步骤
1.编写AM代码
public class AppModuleImpl extends ApplicationModuleImpl { /** * This is the default constructor (do not remove). */ public AppModuleImpl() { } public String sayHello(String name) { return "Hello," + name; } }
2.创建webservice
打开AM,在Service Interface面板中,点击右上方的添加按钮,在弹出的对话框中选择
3.创建部署文件
双击Model项目,在Deployment面板,新建部署文件
此步骤的同时,application自动创建可部署的ear文件
4.部署测试
输入URLhttp://shown:7101/AMServcie-Model-context-root/AppModuleService
ADF11g:将Application Module中的方法发布为webservice
转自:http://blog.csdn.net/ygj26/article/details/8668832
由于步骤比较简单,这里直接写图文步骤
1.编写AM代码
public class AppModuleImpl extends ApplicationModuleImpl {
/**
* This is the default constructor (do not remove).
*/
public AppModuleImpl() {
}
public String sayHello(String name) {
return "Hello," + name;
}
}
2.创建webservice
打开AM,在Service Interface面板中,点击右上方的添加按钮,在弹出的对话框中选择
3.创建部署文件
双击Model项目,在Deployment面板,新建部署文件
此步骤的同时,application自动创建可部署的ear文件
4.部署测试
输入URLhttp://shown:7101/AMServcie-Model-context-root/AppModuleService
AM使用指南之四:把AM中的方法发布为WebService
实际应用中,我们经常需要在AM中添加自己的方法,这些方法可以以Data Control的方式暴露出来,供ADF Faces使用。
但那些使用了非ADF技术开发的应用如何使用AM中的方法呢?
这里介绍最简便的一种方法:把AM中的方法暴露成WebService。
重要步骤说明:
1. 创建应用时选择General Application,为Project1增加ADF BC Components。
2. Create Entities from Table: 选择Employee表。
3. 生成 AM Impl类。
增加如下方法:
/* 更新员工的工资 */
public void updateSalary(Number employeeId,Number salary) {
Key key = new Key(new Object[] { employeeId });
Row row = this.getEmployeesView1().getRow(key);
row.setAttribute("Salary",salary);
try {
this.getDBTransaction().commit();
} catch (Exception ex) {
ex.printstacktrace();
}
/* 获取员工的工作的总时间(多少个月) */
public Number emplWorkLoad(Number employeeId) {
this.getJobHistoryView1().setNamedWhereClauseParam("bv_employeeId",employeeId);
this.getJobHistoryView1().executeQuery();
if (this.getJobHistoryView1().first() != null) {
return (Number)this.getJobHistoryView1().first().getAttribute("WorkLoad");
return null;
4. 手工创建JobHistory VO,选择Read-Only through sql query。
别忘了在AM的Data Model中,手工加入JobHistoryView。
5. 修改AM的Java和Service Interface选项。
在Client Interface中加入updateSalary和emplWorkLoad方法,这两个方法将会在Data Control中显示出来。
在Service Interface中加入updateSalary和emplWorkLoad方法,这两个方法将会被发布为WebService。
6. 修改AM的Configuration选项。
因为要发布到独立的WLS上,所以默认的Configuration要选择AppModuleService,以及JDBC DataSource形式的数据库连接。
要事先在WLS Console中配置该DataSouce。
7. 访问EM,找到发布的应用,测试两个方法。
http://localhost:7001/Application7-Project1-context-root/AppModuleService?wsdl。
Project下载: AM_WebService.7z 。
参考文献:
1. http://andrejusb.blogspot.com/2009/08/web-service-interface-for-adf-bc.html。
http://maping930883.blogspot.com/2012/06/adf154amamwebservice.html
axis2实现webservice之使用services.xml文件发布WebService
还是对教程的延伸,本来是周五要写的,但是耽搁了一下,就拖到周一了。
用Axis2实现Web Service,虽然可以将POJO类放在axis2\WEB-INF\pojo目录中直接发布成Web Service,这样做不需要进行任何配置,但这些POJO类不能在任何包中。这似乎有些不方便,为此,Axis2也允许将带包的POJO类发布成Web Service。
先实现一个POJO类,代码如下:
这个类有两个方法,这两个方法都需要发布成Web Service方法。这种方式和直接放在pojo目录中的POJO类不同。要想将MyService类发布成Web Service,需要一个services.xml文件,这个文件需要放在meta-inf目录中,该文件的内容如下:
其中<service>元素用于发布Web Service,一个<service>元素只能发布一个WebService类,name属性表示WebService名,如下面的URL可以获得这个WebService的WSDL内容:
http://localhost:8080/axis2/services/myService?wsdl (这个得等到.aar文件出来之后)
其中name属性名就是上面URL中"?"和"/"之间的部分。
<description>元素表示当前Web Service的描述,<parameter>元素用于设置WebService的参数,在这里用于设置WebService对应的类名。在这里最值得注意的是<messageReceivers>元素,该元素用于设置处理WebService方法的处理器。例如,getGreeting方法有一个返回值,因此,需要使用可处理输入输出的RPcmessageReceiver类,而update方法没有返回值,因此,需要使用只能处理输入的RPCInOnlyMessageReceiver类。
使用这种方式发布WebService,必须打包成.aar文件,..aar文件实际上就是改变了扩展名的.jar文件。在现在建立了两个文件(这两个文件夹任意):MyService.java和services.xml。将MyService.java编译,生成MyService.class。services.xml和MyService.class文件的位置如下:
D:\ws\service\MyService.class
D:\ws\meta-inf\services.xml
在windows控制台中进入ws目录,并输入如下的命令生成.aar文件(实际上,.jar文件也可以发布webservice,但axis2官方文档中建议使用.aar文件发布webservice):
jar cvf ws.aar . jar cvf AxisTest.aar .
如下是我测试的过程
原来发现不管要.aar,之后还需要一个“.”,即.arr.,但是最坑爹的就是这里了,加了“.”之后还是不对啊,最后的问题居然是这个后面的点要空一格,不能紧挨着.arr
如下成功之后的文件夹情况
最后将ws.aar文件复制到<Tomcat安装目录>\webapps\axis2\WEB-INF\services目录中,启动Tomcat后,就可以调用这个WebService了。
已经显示webservice发布成功了,接下来就是编写客户端进行调运了,跟前面一样,也需要wsdl2java命令去生成stub类,过程我就不多说了,之前的博客里有
如下是调用客户端的代码
运行结果
由于“帅哥”是在服务器端打印的,所以客户端是看不到的。
在打包arr文件的时候,发现有一个build.xml文件,这个是ant脚本中的知识,在本题中暂时不涉及,以后再介绍。
如果想发布多个WebService,可以使用<serviceGroup>元素,如再建立一个MyService1类,代码如下:
在services.xml文件中可以使用如下的配置代码来配置MyService和MyService1类:
今天关于解决将业务流程发布为WebService后无法访问的问题和业务流程端到端的分享就到这里,希望大家有所收获,若想了解更多关于ADF11g-031:将Application Module中的方法发布为webservice、ADF11g:将Application Module中的方法发布为webservice、AM使用指南之四:把AM中的方法发布为WebService、axis2实现webservice之使用services.xml文件发布WebService等相关知识,可以在本站进行查询。
本文标签: