科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道怎样在SQL Server 2005中建立HTTP的端点

怎样在SQL Server 2005中建立HTTP的端点

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

SQL Server2005提供了一个新的执行存储过程或者T-SQL的方法,它可以以Web服务的方式发布到服务器上,而不必使用IIS 这个新特点通过HTTP API把HTTP端点暴露给用户。

作者:赛迪网 10396 来源:天新网 2008年3月25日

关键字: 数据库 Mssql SQL SQL Server

  • 评论
  • 分享微博
  • 分享邮件

SQL Server2005提供了一个新的执行存储过程或者T-SQL的方法,它可以以Web服务的方式发布到服务器上,而不必使用IIS 这个新特点通过HTTP API把HTTP端点暴露给用户,在WINXP SP2和WIN2003上被支持。

建立一个HTTP端点是非常简单的,如下:

CREATE ENDPOINT MyEndpoint?
STATE = STARTED
AS HTTP (
AUTHENTICATION = (INTEGRATED),
PATH = '/sql/myendpoint',
PORTS = (CLEAR) )
FOR SOAP (
BATCHES = ENABLED,
WSDL = DEFAULT
)

在上面的示例中我建立一个命名为MyEndpoint的端点,它在http://localhost/sql/myendpoint监听T-SQL语句,你可以使用下面URL测试它

http://localhost/sql/myendpoint?wsdl.

上面这个URL还可以附加很丰富的参数,具体参见SQL帮助

下面这个例子显示如何通过JAVSCRIPT来调用端点执行T-SQL语句,如下:

function SendBatchRequest( strServerName, strUrlPath, strQuery )
{
var objXMLHttp = null; 
var strRequest = ""; 
objXmlHttp = new ActiveXObject( "microsoft.xmlhttp" ); 
objXmlHttp.open( "POST", "http://" + strServerName + strUrlPath, false ); 
objXmlHttp.setrequestheader( "Content-Type", "text/xml" ); 
objXmlHttp.setRequestHeader( "Host", strServerName ); 
strRequest = "<SOAP-ENV:Envelope xmlns:SOAP-ENV='http://schemas.xmlsoap.org/soap/envelope/'
xmlns:sql='http://schemas.microsoft.com/sqlserver/2004/SOAP'>
<SOAP-ENV:Body>
<sql:sqlbatch>
<sql:BatchCommands>" + strQuery + "</sql:BatchCommands>
</sql:sqlbatch>
</SOAP-ENV:Body>
</SOAP-ENV:Envelope>"; 
objXmlHttp.send( strRequest ); 
if( objXmlHttp.status == 200 )
return objXmlHttp.responseXML.xml; 
else
return ""; 
}
var response = SendBatchRequest( 'localhost', 
'/sql/myendpoint', 'Select * from sys.http_endpoints' )
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章