Notice
Recent Posts
Recent Comments
Link
투케이2K
353. (ios/swift5) [유틸 파일] isWifiConnected : 현재 와이파이 연결 상태 확인 본문
[개발 환경 설정]
개발 툴 : XCODE
개발 언어 : SWIFT5
[소스 코드]
// -----------------------------------------------------------------------------------------
// MARK: - [현재 와이파이 연결 상태 확인 메소드]
// -----------------------------------------------------------------------------------------
var checkWifiFlag = false
func isWifiConnected() -> Bool {
/*
// -----------------------------------------
// [isWifiConnected 메소드 설명]
// -----------------------------------------
1. 필요 import : import Network
// -----------------------------------------
2. 호출 방법 : if C_StateCheck().isWifiConnected() == true {} else {}
// -----------------------------------------
*/
if #available(iOS 12, *) {
// [현재 네트워크 연결 상태 확인 객체 선언]
let monitor = NWPathMonitor()
// [세마포어 선언 : 프로그램 로직을 동기화 구현 : value 0 값은 대기 상태 선언]
let semaphore = DispatchSemaphore(value: 0)
// [네트워크 연결 상태 확인 부분]
monitor.pathUpdateHandler = { path in
if path.status == .satisfied { // [네트워크가 연결된 경우]
if path.usesInterfaceType(.wifi) {
S_Log._D_(description: "와이파이 연결 상태 확인 [IF]", data: [
"연결 상태 :: 와이파이"
])
// [리턴 값 저장]
self.checkWifiFlag = true
}
else if path.usesInterfaceType(.cellular) {
S_Log._D_(description: "와이파이 연결 상태 확인 [IF]", data: [
"연결 상태 :: 모바일"
])
// [리턴 값 저장]
self.checkWifiFlag = false
}
// [세마포어 신호 알림]
semaphore.signal()
}
else { // [네트워크가 연결되지 않은 경우]
S_Log._D_(description: "와이파이 연결 상태 확인 [IF]", data: [
"연결 상태 :: 없음"
])
// [리턴 값 저장]
self.checkWifiFlag = false
// [세마포어 신호 알림]
semaphore.signal()
}
}
// [네트워크 연결 상태 확인 수행]
monitor.start(queue: DispatchQueue.global())
// [세마포어 확인 대기]
semaphore.wait()
S_Log._D_(description: "와이파이 연결 상태 확인 [IF]", data: [
"return :: \(self.checkWifiFlag)"
])
// [결과 리턴 수행 실시]
return self.checkWifiFlag
}
else {
// [세마포어 선언 : 프로그램 로직을 동기화 구현 : value 0 값은 대기 상태 선언]
let semaphore = DispatchSemaphore(value: 0)
// [ios 12 버전 미만 네트워크 연결 상태 체크]
var zeroAddress = sockaddr_in(sin_len: 0, sin_family: 0, sin_port: 0, sin_addr: in_addr(s_addr: 0), sin_zero: (0, 0, 0, 0, 0, 0, 0, 0))
zeroAddress.sin_len = UInt8(MemoryLayout.size(ofValue: zeroAddress))
zeroAddress.sin_family = sa_family_t(AF_INET)
let defaultRouteReachability = withUnsafePointer(to: &zeroAddress) {
$0.withMemoryRebound(to: sockaddr.self, capacity: 1) {zeroSockAddress in
SCNetworkReachabilityCreateWithAddress(nil, zeroSockAddress)
}
}
var flags: SCNetworkReachabilityFlags = SCNetworkReachabilityFlags(rawValue: 0)
if SCNetworkReachabilityGetFlags(defaultRouteReachability!, &flags) == false {
return false
}
// [Working for Cellular and WIFI]
let isReachable = (flags.rawValue & UInt32(kSCNetworkFlagsReachable)) != 0
let needsConnection = (flags.rawValue & UInt32(kSCNetworkFlagsConnectionRequired)) != 0
let ret = (isReachable && !needsConnection)
// [세마포어 신호 알림]
semaphore.signal()
// [세마포어 확인 대기]
semaphore.wait()
S_Log._D_(description: "와이파이 연결 상태 확인 [ELSE]", data: [
"return :: \(ret)"
])
// [결과 리턴 수행 실시]
return ret
}
}
[결과 출력]
================================================================
LOG :: CLASS PLACE :: C_StateCheck.swift :: isWifiConnected() :: 258
-------------------------------------------------
LOG :: NOW TIME :: 2023-10-21 21:17:32
-------------------------------------------------
LOG :: DESCRIPTION :: 와이파이 연결 상태 확인 [IF]
-------------------------------------------------
LOG :: 연결 상태 :: 와이파이
================================================================
================================================================
LOG :: CLASS PLACE :: C_StateCheck.swift :: isWifiConnected() :: 296
-------------------------------------------------
LOG :: NOW TIME :: 2023-10-21 21:17:32
-------------------------------------------------
LOG :: DESCRIPTION :: 와이파이 연결 상태 확인 [IF]
-------------------------------------------------
LOG :: return :: true
================================================================
반응형
'IOS' 카테고리의 다른 글
Comments