在我阅读this question的答案后,我发现使用reachabilityWithHostName
无法使用此类网址:mySite.com/service.asmx
,无论如何都要检查对此的可访问性使用reachabilityWithHostName
或任何reachability
类方法的网址?
非常感谢。
答案 0 :(得分:18)
Reachability类和-reachabilityWithHostname:
旨在成为一种快速,快速的快速机制,用于确定您是否具有与主机的基本网络连接。如果您需要验证是否可以下载特定的URL,则需要使用NSURLConnection
来检索URL的内容,以验证它是否真正可用。
根据您是否需要在前台或后台执行此操作,您可以使用简单但阻止:
+ (NSData *)sendSynchronousRequest:(NSURLRequest *)request returningResponse:(NSURLResponse **)response error:(NSError **)error
或者您可以使用更复杂的方法创建NSURLConnection对象,设置委托以接收响应并等待这些响应进入。
对于简单的案例:
NSURL *myURL = [NSURL URLWithString: @"http://example.com/service.asmx"];
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL: myURL];
[request setHTTPMethod: @"HEAD"];
NSURLResponse *response;
NSError *error;
NSData *myData = [NSURLConnection sendSynchronousRequest: request returningResponse: &response error: &error];
如果你收到一封非零的myData,你就有了某种连接。 response
和error
将告诉您服务器对您的响应(在响应的情况下,如果您收到了非零的myData)或发生了什么样的错误,在nil myData的情况下
对于非平凡的案例,您可以从Apple的Using NSURLConnection获得良好的指导。
如果您不想拖延前台进程,可以通过两种不同的方式执行此操作。上面的文档将提供有关如何实现委托等的信息。但是,更简单的实现是使用GCD在后台线程上发送同步请求,然后在完成后在主线程上发送消息。
这样的事情:
NSURL *myURL = [NSURL URLWithString: @"http://example.com/service.asmx"];
NSMutableURLRequest *request = [NSMutableURLRequest requestWithURL: myURL];
[request setHTTPMethod: @"HEAD"];
dispatch_async( dispatch_get_global_queue( DISPATCH_QUEUE_PRIORITY_BACKGROUND, NULL), ^{
NSURLResponse *response;
NSError *error;
NSData *myData = [NSURLConnection sendSynchronousRequest: request returningResponse: &response error: &error];
BOOL reachable;
if (myData) {
// we are probably reachable, check the response
reachable=YES;
} else {
// we are probably not reachable, check the error:
reachable=NO;
}
// now call ourselves back on the main thread
dispatch_async( dispatch_get_main_queue(), ^{
[self setReachability: reachable];
});
});
答案 1 :(得分:6)
如果您想检查针对某个网址的可访问性(通常使用的是针对主机名),只需使用NSURLConnection执行HEAD请求。
答案 2 :(得分:2)
Swift的可能解决方案是:
<MSBuild Projects="$(MSBuildProjectFullPath)" Targets="Publish" Properties="TargetFramework=$(TargetFramework);_GetChildProjectCopyToPublishDirectoryItems=false" />
然后调用这样的方法:
func verifyURL(urlPath: String, completion: @escaping (_ isValid: Bool) ->()) {
if let url = URL(string: urlPath) {
var request = URLRequest(url: url)
request.httpMethod = "HEAD"
let task = URLSession.shared.dataTask(with: request) { _, response, error in
if let httpResponse = response {
if httpResponse.getStatusCode() == 200 {
completion(true)
}
} else {
completion(false)
}
}
task.resume()
} else {
completion(false)
}
}