您好,我想使用公钥实现SSL锁定&我使用的是Alamofire 4.8.2,下面是代码
func testWithAlmofire(){
let serverTrustPolicies:[String:ServerTrustPolicy] = [
"example.com": .pinPublicKeys(publicKeys: ServerTrustPolicy.publicKeys(), validateCertificateChain: true, validateHost: true)
]
sessionManager = SessionManager(
serverTrustPolicyManager: ServerTrustPolicyManager(policies: serverTrustPolicies)
)
sessionManager.request("https://example.com").response{ res in
if res.response != nil{
self.displayAlert(withTitle: "Test Result",
message: "Pinning validation succeeded")
}else{
self.displayAlert(withTitle: "Test Result",
message: "Pinning validation Failed")
}
}
}如果我做错了什么,请帮帮我。
发布于 2020-06-26 02:32:29
我正在使用类似的东西,我希望这能有所帮助
class NetworkingManager {
static let shared = NetworkingManager()
private init() {
sharedSession = enableCertificatePinning()
}
var sharedSession: Session?
func enableCertificatePinning() -> Session {
func getCertificates() -> [SecCertificate] {
let certs = ["AmazonExample1", "AmazonExample2"]
var certificates = [SecCertificate]()
certs.forEach { cert in
let url = Bundle.main.url(forResource: cert, withExtension: "cer")!
let localCertificate = try! Data(contentsOf: url) as CFData
if let certificate = SecCertificateCreateWithData(nil, localCertificate) {
certificates.append(certificate)
}
}
return certificates
}
let certificates: [SecCertificate] = getCertificates()
let trustPolicy = PinnedCertificatesTrustEvaluator(
certificates: certificates,
validateHost: true)
let trustPolicies = [certificateUrl: trustPolicy,
"https://example.com": trustPolicy,
"https://example2.com": trustPolicy]
let policyManager = ServerTrustManager(evaluators: trustPolicies)
return Session(
configuration: .default,
serverTrustManager: policyManager)
}
}你可以像这样使用
func exampleRequisiton(someBody: exampleBody, completion: @escaping (Result<responseExample, NetworkErrors>, _ message: String?) -> Void){
guard let url = URL(string: InviteUrl) else {
completion(.failure(.invalidUrl), nil)
return
}
var request = getDefaultRequest(url, .post)
request.httpBody = try? JSONEncoder().encode(someBody)
NetworkingManager.shared.sharedSession?.request(request).validate().responseDecodable(of: DefaultResponse.self, decoder: defaultDecoder) { data in
switch data.result {
case let .success(data):
completion(.success(data), nil)
case let .failure(error):
completion(.failure(.genericError), nil)
}
}
}我尝试使用一个示例,其中包含申请中使用的所有选项(正文、标题),因为我认为您在某些时刻需要使用这些选项。下面的代码是我单独创建的每个申请中使用的对象
var HttpHeaders: HTTPHeaders {
let version = Bundle.main.infoDictionary?["CFBundleVersion"] as? String ?? ""
return [
"SomeHeader if you have": "example"
]
}
func getDefaultRequest(_ url:URL, _ method:HTTPMethod) -> URLRequest{
var request = URLRequest(url: url)
request.setValue("application/json", forHTTPHeaderField: "Content-Type")
request.httpMethod = method.rawValue
request.headers = HttpHeaders
return request
}
enum NetworkErrors: Error {
case authError
case genericError
case invalidUrl
case serverMessage
}
struct responseExample:Codable{
let systemTimeMillis: Int?
let message: String?
let status: Int?
}
struct exampleBody: Codable {
var example: String
}https://stackoverflow.com/questions/62576429
复制相似问题