首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Power Shell Web抓取SSL/TSL问题

Power Shell Web抓取SSL/TSL问题
EN

Stack Overflow用户
提问于 2012-03-29 09:12:14
回答 2查看 11.1K关注 0票数 5

我想在服务器上运行一个网络抓取脚本。

当前脚本收集指定页面上的html。

代码语言:javascript
复制
$url = "http://websms"
 [net.httpWebRequest] $request = [net.webRequest]::create($url)
 [net.httpWebResponse] $response = $request.getResponse()
 $responseStream = $response.getResponseStream()
 $sr = new-object IO.StreamReader($responseStream)
 $result = $sr.ReadToEnd()

 $result

这在一个典型的网页上工作得很好。然而,我想在一个服务器管理页面上运行它,这当然需要一个登录。

我想在我尝试登录之前,我会尝试抓取服务器的登录页面。运行上面的脚本,我得到了以下结果。

代码语言:javascript
复制
   Exception calling "GetResponse" with "0" argument(s): "The underlying connection was closed: Could not establish trust relationship for the SSL/TLS secure channel."
At C:\temp\web3.ps1:3 char:56
+  [net.httpWebResponse] $response = $request.getResponse <<<< ()
    + CategoryInfo          : NotSpecified: (:) [], MethodInvocationException
    + FullyQualifiedErrorId : DotNetMethodException

任何想法,如何解决这个问题,或者如果你可以指出我一个不同的方向,这样我就可以从服务器的管理html页面中抓取元素。

谢谢你们!

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-03-29 09:40:04

下面这行代码将忽略SSL证书错误:

代码语言:javascript
复制
[System.Net.ServicePointManager]::ServerCertificateValidationCallback = {$true}

执行此操作后,将忽略有关自签名不受信任证书、名称不匹配或过期的错误。

票数 24
EN

Stack Overflow用户

发布于 2012-03-29 09:20:42

使用this brilliant answer

代码语言:javascript
复制
public bool AcceptAllCertifications(object sender, System.Security.Cryptography.X509Certificates.X509Certificate certification, System.Security.Cryptography.X509Certificates.X509Chain chain, System.Net.Security.SslPolicyErrors sslPolicyErrors)
{
    return true;
}
ServicePointManager.ServerCertificateValidationCallback = new System.Net.Security.RemoteCertificateValidationCallback(AcceptAllCertifications);
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9917875

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档