通过Web服务外置XML,将Web服务用作数据源,Web服务传递的内容是XML,将由Web服务返回的XML文档,以便可以将它加载到客户机上的XML分析器。

博客介绍了以Web服务形式实现的中间层,通过GetCustomers方法检索数据库数据,并以标准SOAP提供给客户机。给出了中间层和表示层的具体实现代码,包括使用Web服务行为组件处理Web服务、用XSLT样式表转换XML文档以查找并显示顾客详细资料。

一个以Web服务形式实现的中间层,提供一个GetCustomers方法检索数据库中的数据,而且通过HTTP以标准的SOAP提供给客户机。

1.具体实现(代码仅供参考)
 中间层 customer-data.asmx 实现Web服务

 <%@WebService Language="C#" Class="Customer"%>
 using System;
 using System.Data;
 using System.Web.Services; //导入Web服务命名空间
 using System.Configuration;

 [WebService(Description="Customer Service",Namespace="http://127.0.0.1/webservices/4923/customer")]

 public class CustomerOrders
 {
 [WebMethod] public DataSet GetCustomers(String strCustID, String strCustName) //使用[WebMethod]特性表明GetCustomers方法通过Web服务可用,没有声明[WebMethod]特性的公共函数对客户机通过Web服务是不可用的。
 {
 //根据客户ID或客户姓名检索数据并返回DataSet
 }
 }

 表示层:
 (1)使用Web服务行为组件(webservices.htc),将其用于IE中来处理Web服务。关于webservices.htc的介绍及下载可到 http://msdn.microsoft.com/workshop/author/webservice/webservice.asp


 View Customer - Select Customer



 (2)用javascript声明一个全局变量保存MSXML分析起实例,创建一个openWebService函数打开Web服务 一旦webservice.htc行为插入页面,就可以使用它来访问Web服务


 var objXMLData;
 function openWebService() {
 htcWService.useService("customer-data.asmxWSDL","CustData"); //使用行为的useService方法打开Web Service,通过加载服务器的WSDL文档做到用户能够通过WSDL追加到查询字符串来制定它,同时提供一个“友好名称”CustData,将在代码中使用它来引用Web服务
 var iCallID = htcWService.CustData.callService(dataLoaded, "GetCustomers", "", ""); //指定callService方法所需的参数:事件处理程序名,调用的方法名以及此方法的参数,为了得到所有的客户,使用了2个空字符串作为参数
 }

 function dataLoaded(objResult) {
 if(objResult.error) { //检查是否出错
 var strErrorCode = objResult.errorDetail.code;
 var strErrorMsg = objResult.errorDetail.string;
 var strErrorRaw = objResult.errorDetail.raw;
 }
 else { //如果没有出错,则将返回的数据转换成MSXML分析器的一个实例
 try {
 objXMLData = new ActiveXObject('MSXML2.FreeThreadedDOMDocument');
 }
 catch(e) {}
 if (objXMLData == null) {

 return;
 }
 objXMLData.onreadystatechange = changeFunction;
 objXMLData.validateOnParse = true;
 objXMLData.async = true;
 objXMLData.loadXML(objResult.raw.xml); //从Web服务加载SOAP文档
 }
 }

function changeFunction() {
 // 检查XML分析器的readyState值
 // 当值为4时,表明加载或者完成了或者在加载XML时出现了错误
 if (objXMLData.readyState == 4) {
 if (objXMLData.parseError.errorCode != 0)
 //加载XML时出现了错误
 else {
 //加载完成
 }
 }
 }


 (3)查找并显示顾客详细资料: 用户使用文本搜索框来搜索客户而不发生给服务器的回送,不管执行多少次搜索(为了提供更高更快的响应和用户接口)。


 function doSearch(strSortOrder) {
 //得到用户ID或用户姓名,strSortOrder是排序参数
 //转换XML文档 并把转化后的结果存入一变量
 var strResult = getStyledResult(strCustID, strCustName, strSortOrder);
 if (strResult.length > 0) {
 //呈现strResult
 }
 else {
 //没有符合的数据
 }
 }

        function getStyledResult(strCustID, strCustName, strSortOrder) {
          //使用XSLT样式表转换XML文档 
          //建立XPath字符串
          if (strCustID.length > 0)
              var strXPath = 'descendant::Customers[starts-with(child::CustomerID, $custid)]'
          else
              var strXPath = 'descendant::Customers[contains(child::CompanyName, $custname)]';

          //创建样式表代码
          var strStyle = '<?xml version="1.0" ?>/n'
          + '<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">/n'
          + ' <xsl:param name="custid" />/n'
          + ' <xsl:param name="custname" />/n'
          + ' <xsl:template match="/">/n'
          + '  <table id="tblCustomers" cellspacing="0" cellpadding="5"/n'
          + '         rules="cols" border="1" style="border-collapse:collapse;">/n'
          + '   <tr style="background-color:silver;">/n'
          + '    <td align="center">/n'
          + '      <a href="javascript:doSearch(/'CustomerID/')"><b>ID</b></a>/n'
          + '    </td>/n'
          + '    <td align="left">/n'
          + '      <a href="javascript:doSearch(/'CompanyName/')"><b>Customer Name</b></a>/n'
          + '    </td>/n'
          + '    <td align="left">/n'
          + '      <a href="javascript:doSearch(/'City/')"><b>City</b></a>/n'
          + '    </td>/n'
          + '    <td></td>/n'
          + '   </tr>/n'
          + '   <xsl:for-each select="' + strXPath + '">/n'
          + '    <xsl:sort select="' + strSortOrder + '" data-type="text" order="ascending" />/n'
          + '     <tr>/n'
          + '      <td align="center" style="background-color:#add8e6;">/n'
          + '       <xsl:value-of select="CustomerID" />/n'
          + '      </td>/n'
          + '      <td align="left">/n'
          + '       <a>/n'
          + '         <xsl:attribute name="href">/n'
          + '          view-orders.aspx?customerid=<xsl:value-of select="CustomerID" />/n'
          + '         </xsl:attribute>/n'
          + '         <xsl:value-of select="CompanyName" />/n'
          + '       </a>/n'
          + '      </td>/n'
          + '      <td align="left">/n'
          + '       <xsl:value-of select="City" />/n'
          + '      </td>/n'
          + '      <td align="left">/n'
          + '       <a>/n'
          + '         <xsl:attribute name="href">/n'
          + '          ../../update-orders/ie5/edit-orders.aspx?customerid=<xsl:value-of select="CustomerID" />/n'
          + '         </xsl:attribute>/n'
          + '         Edit Orders/n'
          + '       </a>/n'
          + '      </td>/n'
          + '     </tr>/n'
          + '   </xsl:for-each>/n'
          + '  </table>/n'
          + ' </xsl:template>/n'
          + '</xsl:stylesheet>';
 
          var objXMLStyle = new ActiveXObject('MSXML2.FreeThreadedDOMDocument');         
          objXMLStyle.loadXML(strStyle);         
          var objTemplate = new ActiveXObject('MSXML2.XSLTemplate'); //创建一个MSXML XSLTemplate实例,并指定它的stylesheet属性
          objTemplate.stylesheet = objXMLStyle;         
          var objProc = objTemplate.createProcessor();  //创建一个XSLProcessor对象    
          objProc.input = objXMLData;  //处理objXMLData文档 
          objProc.addParameter('custid', strCustID);  //指定参数
          objProc.addParameter('custname', strCustName);       
          if (objProc.transform() == true)  //判断是否转换成功
          var strResult = objProc.output
          else
             var strResult = '';
          return strResult;
          }

<think>好的,我现在需要帮助用户了解如何在IntelliJ IDEA中连接Web应用与数据库。首先,用户提到了配置数据源和Tomcat,这可能涉及两种不同的方法,一种是传统的Tomcat数据源配置,另一种是使用Spring Boot的自动配置。我需要根据提供的引用内容来整理步骤。 首先,查看用户提供的引用。引用[1]提到在Tomcat的Context中配置数据源,但在IDEA中没有直接配置server.xml的方法,需要通过其他步骤。引用[2]是关于SpringBoot连接数据库的配置,使用application.properties文件。引用[3]和[4]涉及IDEA连接数据库的基本操作和JDBC URL的格式,而引用[5]是一个使用SQL Server的例子。 用户的问题是如何在IDEA中连接Web应用和数据库,可能包括传统Java Web项目和Spring Boot项目。我需要分两部分回答:Tomcat数据源配置和Spring Boot配置。 对于Tomcat配置,根据引用[1],步骤应该是创建META-INF/context.xml文件,配置Resource元素,然后在web.xml中设置resource-ref。接着在代码中用JNDI查找数据源。这部分需要详细说明每个文件的配置位置和内容,确保用户能正确放置文件并编写XML配置。 对于Spring Boot配置,引用[2]中的内容可以直接应用,即在application.properties中设置driver、url、username和password。同时需要添加数据库驱动依赖,比如MySQL的connector-j。需要提到不同的数据库可能需要不同的驱动类名和URL格式,如引用[4]中的MySQL URL示例。 另外,用户可能需要知道如何通过IDEA的数据库工具直接连接数据库,如引用[3]和[4]提到的,使用Database面板添加数据源。这部分可以作为附加步骤,方便用户管理数据库连接。 需要注意的是,不同数据库(MySQL、SQL Server)的配置差异,比如驱动类名和URL格式。例如,SQL Server的驱动类可能是com.microsoft.sqlserver.jdbc.SQLServerDriver,而URL格式如jdbc:sqlserver://localhost:1433;databaseName=dbname,如引用[5]所示。 最后,生成相关问题需要考虑用户可能的后续疑问,比如依赖问题、连接池配置、多环境配置以及外置数据库连接等。确保问题覆盖常见的使用场景和潜在问题。</think>### IntelliJ IDEA 连接 Web 应用与数据库的配置方法 #### 一、传统 Java Web 项目配置(基于 Tomcat 数据源) 1. **创建 `META-INF/context.xml` 文件** 在项目的 `src/main/webapp/META-INF` 目录下创建 `context.xml`,添加以下内容(以 MySQL 为例): ```xml <Context> <Resource name="jdbc/mydb" type="javax.sql.DataSource" driverClassName="com.mysql.cj.jdbc.Driver" url="jdbc:mysql://localhost:3306/数据库名" username="root" password="root" maxTotal="20" maxIdle="10"/> </Context> ``` 引用说明:Tomcat 数据源通过 `Resource` 标签定义连接参数[^1]。 2. **配置 `web.xml` 声明资源引用** 在 `web.xml` 中添加 `<resource-ref>` 标签: ```xml <resource-ref> <description>MySQL DataSource</description> <res-ref-name>jdbc/mydb</res-ref-name> <res-type>javax.sql.DataSource</res-type> <res-auth>Container</res-auth> </resource-ref> ``` 3. **代码中通过 JNDI 获取连接** ```java Context ctx = new InitialContext(); DataSource ds = (DataSource) ctx.lookup("java:/comp/env/jdbc/mydb"); Connection conn = ds.getConnection(); ``` #### 二、Spring Boot 项目配置(推荐方式) 1. **修改 `application.properties` 文件** 添加数据库连接配置(示例为 MySQL): ```properties spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver spring.datasource.url=jdbc:mysql://localhost:3306/数据库名?useSSL=false&serverTimezone=UTC spring.datasource.username=root spring.datasource.password=root ``` 引用说明:Spring Boot 通过配置文件自动配置数据源[^2]。 2. **添加数据库驱动依赖** 在 `pom.xml` 中添加(以 MySQL 为例): ```xml <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> <version>8.0.28</version> </dependency> ``` #### 三、通过 IDEA 直接连接数据库(通用方法) 1. **打开 Database 工具窗口** 右侧边栏点击 **Database** > **+** > **Data Source** > 选择数据库类型。 2. **填写连接参数** 输入主机、端口、数据库名、账号密码,点击 **Test Connection** 验证: ``` Host: localhost Port: 3306 (MySQL) / 1433 (SQL Server) User: root Password: root Database: 数据库名 ``` 引用说明:IDEA 内置数据库工具支持主流数据库连接[^3][^4]。 #### 四、不同数据库配置差异 | 数据库类型 | 驱动类名 | URL 格式示例 | |------------|-----------------------------------|-----------------------------------------------| | MySQL | `com.mysql.cj.jdbc.Driver` | `jdbc:mysql://host:port/dbname` | | SQL Server | `com.microsoft.sqlserver.jdbc.SQLServerDriver` | `jdbc:sqlserver://host:port;databaseName=dbname`[^5] |
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值