以编程方式登录SSRS

时间:2012-06-27 06:56:02

标签: php curl reporting-services www-authenticate

我正在尝试以编程方式以编程方式连接到Microsoft SSRS。我认为这必须以某种方式使用www-authentication http标头完成,但我不完全确定。

我这样做是因为我遇到了以匿名网络用户身份登录SSRS的问题。不应提示客户端输入用户名和密码。

假设我在正确的道路上,一旦登录,PHP就应该充当SSRS作为客户端之间的中继(用户通过PHP页面浏览SSRS)。

如果还有其他方法可以让它发挥作用,请大声呼喊!

这是我走了多远:

<?php
    function get_url_contents($url){
        $crl = curl_init();
        $timeout = 5;
        curl_setopt ($crl, CURLOPT_VERBOSE, 1);
        curl_setopt ($crl, CURLOPT_URL,$url);
        curl_setopt ($crl, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt ($crl, CURLOPT_HTTPHEADER,array("WWW-Authenticate: Basic"));
        curl_setopt ($crl, CURLOPT_HEADER, 1);
        curl_setopt ($crl, CURLOPT_CONNECTTIMEOUT, $timeout);
        $ret = curl_exec($crl);
        curl_close($crl);
        return $ret;
    }


    $url = "http://192.168.0.16/ReportServer";
    $str = get_url_contents($url);
    echo $str;
?>

输出为:

C:\wamp\bin\php\php5.3.8>php.exe c:\wamp\www\Test\index.php
* About to connect() to 192.168.0.16 port 80 (#0)
*   Trying 192.168.0.16... * connected
* Connected to 192.168.0.16 (192.168.0.16) port 80 (#0)
> GET /ReportServer HTTP/1.1
Host: 192.168.0.16
Accept: */*
WWW-Authenticate: Basic

< HTTP/1.1 401 Unauthorized
< Content-Length: 0
< WWW-Authenticate: NTLM
< WWW-Authenticate: Basic realm="192.168.0.16"
< Date: Wed, 27 Jun 2012 06:31:24 GMT
<
* Connection #0 to host 192.168.0.16 left intact
HTTP/1.1 401 Unauthorized
Content-Length: 0
WWW-Authenticate: NTLM
WWW-Authenticate: Basic realm="192.168.0.16"
Date: Wed, 27 Jun 2012 06:31:24 GMT

* Closing connection #0

C:\wamp\bin\php\php5.3.8>

1 个答案:

答案 0 :(得分:0)

因此,如果我没记错的话,SSRS在开箱即用时“默认”为NTLM。这意味着它正在寻找Windows AD帐户。当然,您可以根据您的使用情况通过配置将这些设置更改为无数其他设置。有关身份验证的详细信息,请查看此页面:http://msdn.microsoft.com/en-us/library/bb283249.aspx

很久以前,我参与过类似的项目。我们最终使用的最简单的解决方案是创建一个服务帐户,将PHP应用程序中使用的各种SSRS报告的权限授予服务帐户,然后在.NET端创建一个称为SSRS Web服务的包装器Web服务。服务帐户。然后我们从PHP端调用了这个包装器Web服务。有关SSRS Web服务的信息,请参阅此处:http://msdn.microsoft.com/en-us/library/ms155398.aspx

希望这会有所帮助......