使用 Alamofire 将 Curl 命令转换为 swift

Convert Curl Command to swift using Alamofire

在过去的一周里,我一直在尝试通过将他们的 API 与 Alamofire 结合使用来从第三方网络服务获取身份验证令牌。我实施了不同类型的解决方案。问题是 Web 服务仅提供有关如何使用 curl 连接到其服务的文档。但我想使用 Alamofire 连接到它,因为我正在开发一个 iOS 应用程序。

我在下面发布了我实施的不同解决方案,这些解决方案返回 400 状态代码或 404。有人愿意指导我完成这个吗?

这是我要使用 Alamofire 转换为 swift 的 curl 命令:

curl "https://api.webservice.com/oauth/token?client_id=<your-client-id>&client_secret=<your-client-secret>&grant_type=client_credentials"

为了从身份验证客户端接收访问令牌,您必须为其提供所提供的客户端 ID 和客户端密码。

下面是我尝试实施的一些解决方案:

func doAuth(){
    let parameters = ["ClientID": clientID, "clientSecret": clientSecret]

    Alamofire.request("https://api.everypixel.com/oauth/token", method: .post, parameters: parameters, encoding: JSONEncoding.default, headers: nil).responseJSON { (response:DataResponse<Any>) in

        switch(response.result) {
        case .success(_):
            if response.result.value != nil{
                print(response.result.value as Any)
            }
            break

        case .failure(_):
            print(response.result.error as Any)
            break

        }
    }

    let user = clientID
    let password = clientSecret
    let credentialData = "\(user):\(password)".data(using: String.Encoding.utf8)!
    let base64Credentials = credentialData.base64EncodedString(options: [])
    let headers = ["Authorization": "Bearer \(base64Credentials)"]
    print(credentialData)
    Alamofire.request(tokenRequestURL,
                      method: .post,
                      parameters: nil,
                      encoding: URLEncoding.default,
                      headers:headers)
        .validate()
        .responseJSON { response in
            if response.result.value != nil{
                print(response)
            }else{

                print("found an error")
            }
    }

    let response = Alamofire.request(tokenRequestURL, method: .get).authenticate(user: clientID, password: clientSecret).response?.statusCode
    print(response)


    let key = clientID
    let secret = clientSecret

    let url = tokenRequestURL

    var request = URLRequest(url: url!)

    request.addValue("application/json", forHTTPHeaderField: "Accept")
    request.addValue("sso-key \(key):\(secret)", forHTTPHeaderField: "Authorization")
    let task = URLSession.shared.dataTask(with: url!) { data, response, error in
        guard error == nil else {
            print(error!)
            return
        }
        guard let data = data else {
            print("Data is empty")
            return
        }

        print(response)
    }

    task.resume()
}

在您的代码中,您在不需要的地方使用了 method: .post。还有一些错误的参数名称(例如 "ClientID": clientID 应该重命名为 "client_id": clientID)。这可能是 400 或 404 状态代码的原因。

至少这个 GET 请求在没有 400 或 404 状态代码的情况下对我有效:

Alamofire
        .request(
            "https://api.everypixel.com/oauth/token",
            parameters:[
                "client_id"     : clientID,
                "client_secret" : clientSecret,
                "grant_type"    : "client_credentials"
            ]
        )
        .responseString { response in
            switch response.result {
            case .success(let value):
                print("from .success \(value)")
            case .failure(let error):
                print(error)
            }
    }