1、目录 第一章 SAP创建WS 2 1.1 概要技术说明 2 1.2 创建RFC函数 2 1.3 创建WS 3 1.4 外部系统访问配置 8 第二章 SAP调用WS 12 2.1 概要技术说明 12 2.2 创建服务代理对象 12 2.3 创建端口 16 2.3.1 创建默认端口 16 2.3.2 配置默认端口 17 2.4 程序实现调用 19 2.4.1 代码实现 19 第三章 数据交换格式 20 3.1 数据交换格式 20 第一章 SAP创建WS 1.1 概要技术说明 Web Service 简介:构建互联网分布式系统的基本部件。Web Servi
2、ces 正成为企业应用集成(Enterprise Application Integration)的有效平台。你可以使用互联网中提供的Web Service构建应用程序,而不必考虑这些Web Service是怎样运行的。 Web Service通过标准通信协议,在互联网上发布程序模块(以服务的方式),目前大部分是用SOAP来做通信协议。 本文档为一个SAP ECC(以下简称ECC)系统如何生成Web Service(以下简称WS)供外部系统调用的示例。ECC系统生成WS的大致流程为:首先在SAP中创建一个属性为RFC的函数,然后对该函数进行封装,最后通过事务代码——SOAMANAGER进行
3、配置,即可得到供外部系统进行调用WS的URL。详细技术说明见1.2—1.4。 系统环境:SAP ECC 6.0, BASIS 700 SP15; WS通讯协议:SOAP 1.1(此ECC的版本暂不支持SOAP1.2)。 1.2 创建RFC函数 使用TCODE:se37或SE80,首先在函数组(函数组自行创建)中创建一个函数,在弹出的界面输入相关参数,将Processing Type选为RFC类型即可。具体如下: 该函数的输入、输入参数均为String类型。 1.3 创建WS 创建WS有两种途径,一种是通过SE80,另一种是通过SE37,前一种提供了多种选择类型(WS、Prox
4、y Object 等),后者只能创建WS。本文档使用后一种方法,通过如下路径:Utilities->More Utilities->Create Web Service->Form the Function Module。 系统弹出Web Service创建向导,输入服务名称、描述: Name Mapping和XML文件中生成的函数名对应的变量命名有关,一般不选。 Profile为安全文件设置,即外部系统访问该服务时ECC系统设置的安全级别。Deploy Service可不选。 输入开发包和传输请求
5、 完成: 基本信息如下: 1.4 外部系统访问配置 若是生成的WS供SAP系统调用,则此步骤可省略,非SAP系统访问则必须配置。通过事务代码:SOAMANAGER对Web Service(ZXTPT_DXP)进行配置。具体过程如下: 点击Web Service Administration进行配置,进入后选择自己创建的WS,然后点击Apply Selection: 点击 Configurations,再点击Edit按钮,如下: 在上图中输入用户名和密码即可,然后点击Save按钮配置完成。再点击下图中的Overview按钮,然后打开:Open WSDL d
6、ocument for selected binding标签,即可获得URL。 URL在IE的地址栏中获得。 第二章 SAP调用WS 2.1 概要技术说明 ECC系统调用外部WS是企业信息系统整合集成时经常遇见到的情况,本章为一个ECC系统调用外部WS来实现和企业门户的数据交换例子。ECC系统调用外部WS的大致流程为:首先在SAP中创建一个代理对象,然后为对象创建端口,并将配置端口激活,最后通过事务代码——SOAMANAGER进行配置,即可在程序中调用WS中提供的方法,以实现系统间的数据传输。详细技术说明见2.2—2.4。 系统环境:SAP ECC 6.0, BASIS 70
7、0 SP15; WS通讯协议:SOAP 1.1(此ECC的版本暂不支持SOAP1.2)。 2.2 创建服务代理对象 使用TCODE:se80,选择建立,在弹出的界面输入相关参数即可。具体流程如下: 选择服务消费者: 选择URL/HTTP类型: 输入你需调用的URL: 输入开发包、前缀号和请求号: 完成: 最后生成了前缀名为ZXTPT的Proxy Object,它包含了很多种方法,此处只调用方法dxpaccess_service。 2.3 创建端口 2.3.1 创建默认端口 通过事务代码:LPCONFIG为Proxy Object 创建一个默
8、认端口。具体过程如下: 输入类名称和端口名称,若是默认调用的端口,打上对号: 编辑端口,输入名称、URL和应用设置等: 检查无误后,点击激活按钮激活此端口即可。 2.3.2 配置默认端口 通过事务代码:SOAMANAGER对Proxy Object 进行配置。具体过程如下: 点击Web Service Administration进行配置,进入后选择自己创建的代理类,然后点击Apply Selection: 点击 Create Logical Prot会弹出如下窗口,分别输入相关参数即可: 最后点击 Apply Setting,然后点击Save按钮即
9、可激活此配置。 完成上述两个步骤后,即可在程序中调用此代理类。 2.4 程序实现调用 2.4.1 代码实现 关键代码如下: data : lo_proxy type ref to zxtptco_report_parser, lo_input type zxtptdxpaccess_service, lo_output type zxtptdxpaccess_service_respons, lo_sys_exception type ref to cx_ai_system_fault. try. * create an
10、 instance of proxy class create object lo_proxy exporting logical_port_name = 'LP01'. * call the corresponding method call method lo_proxy->dxpaccess_service exporting input = lo_input importing output = lo_output. catch cx_ai_sy
11、stem_fault into lo_sys_exception. * error handling. write : lo_sys_exception->errortext. endtry. 第三章 数据交换格式 3.1 数据交换格式 在ECC系统和数据交换平台(以下简称DXP)交换数据时,按DXP平台接口规范要求,采用的是将XML格式的数据封装到字符串中的形式来实现数据传输。外部调用ECC 的WS时返回参数的XML Schema 如下: ECC调用外部WS的输入参数的XML Schema如下: 具体字段解释如下: 附录资料:web前端面试
12、题 1. W3C标准有哪些? W3C推行的主要规范有HTML,CSS,XML,XHTML和DOM(Document Object Model)。 2. 谈谈Js的内存泄露问题。 3. 谈谈对Html 5的了解。 4. 谈谈对CSS 3的了解。 5. 用js实现随即选取10--100之间的10个数字,存入一个数组,并排序。 var iArray = []; funtion getRandom(istart, iend){ var iChoice = istart - iend +1; return Math.floor(Math.rando
13、m() * iChoice + istart; } for(var i=0; i<10; i++){ iArray.push(getRandom(10,100)); } iArray.sort(); 6. 把两个数组合并,并删除第二个元素。 var array1 = ['a','b','c']; var bArray = ['d','e','f']; var cArray = array1.concat(bArray); cArray.splice(1,1); 7. Js面向对象的几种方式。 8. 请谈谈原型方式构造对象的特点。 9. 在Css中那个属
14、性会影响dom读取文档流的顺序。 答: float属性。 10. 请介绍几种用div实现两列布局的方案(兼容),另外要考虑文档流的加载。 11. 谈谈css在浏览器中的兼容问题,详细谈谈IE6的一些bug,以及解决方案。 12. 谈谈你对闭包的理解。以及如何实现js方法的重写。 [HTML && CSS] 1.Doctype? 严格模式与混杂模式-如何触发这两种模式,区分它们有何意义? 首先我讲讲如何触发两种模式: 加入xml头部声明可以触发IE浏览器的Quirks mode,触发之后,浏览器解析方式就和IE5.5一样,拥有IE5.5一样的bug和其他问题,行
15、为(Javascript)也是如此。 IE6的触发 在XHTML的DOCTYPE前加入XML声明 IE7的触发 在XML声明和XHTML的DOCTYPE之间加入HTML注释
16、g="utf-8"?> IE6和IE7都可以触发的 在HTML4.01的DOCTYPE文档头部加入HTML注释
17、"http://www.w3.org/TR/html4/strict.dtd"> 其次是这样的意义 各个浏览器的混杂模式,基本就是各个浏览器的私有模式,不相互兼容。所以,除非是为了兼容的问题,比如你不想修改很久很久以前做的IE ONLY的网页,否则刻意触发混杂模式没有任何意义。 2:行内元素有哪些?块级元素有哪些?CSS的盒模型? 一.行内元素和块级元素有哪些? 块级元素
information on authorlong quotation