Alamofire로 본문에 간단한 문자열이있는 POST 요청
iOS 앱에서 Alamofire를 사용하여 HTTP 본문의 간단한 문자열로 POST 요청을 보내는 방법은 무엇입니까?
기본적으로 Alamofire에는 요청에 대한 매개 변수가 필요합니다.
Alamofire.request(.POST, "http://mywebsite.com/post-request", parameters: ["foo": "bar"])
이러한 매개 변수에는 키-값 쌍이 포함됩니다. 하지만 HTTP 본문에 키-값 문자열이 포함 된 요청을 보내고 싶지 않습니다.
나는 다음과 같은 것을 의미합니다.
Alamofire.request(.POST, "http://mywebsite.com/post-request", body: "myBodyString")
예제에 Alamofire.request(.POST, "http://mywebsite.com/post-request", parameters: ["foo": "bar"])
이미 "foo = bar"문자열이 본문으로 포함되어 있습니다. 그러나 정말로 사용자 정의 형식의 문자열을 원한다면. 다음과 같이 할 수 있습니다.
Alamofire.request(.POST, "http://mywebsite.com/post-request", parameters: [:], encoding: .Custom({
(convertible, params) in
var mutableRequest = convertible.URLRequest.copy() as NSMutableURLRequest
mutableRequest.HTTPBody = "myBodyString".dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: false)
return (mutableRequest, nil)
}))
주 : parameters
안nil
업데이트 (Alamofire 4.0, Swift 3.0) :
Alamofire 4.0에서 API가 변경되었습니다. 따라서 사용자 정의 인코딩의 경우 ParameterEncoding
프로토콜 을 준수하는 값 / 객체가 필요 합니다.
extension String: ParameterEncoding {
public func encode(_ urlRequest: URLRequestConvertible, with parameters: Parameters?) throws -> URLRequest {
var request = try urlRequest.asURLRequest()
request.httpBody = data(using: .utf8, allowLossyConversion: false)
return request
}
}
Alamofire.request("http://mywebsite.com/post-request", method: .post, parameters: [:], encoding: "myBody", headers: [:])
다음과 같이 할 수 있습니다.
- 별도의 요청 Alamofire 개체를 만들었습니다.
- 문자열을 데이터로 변환
httpBody에 데이터 입력
var request = URLRequest(url: URL(string: url)!) request.httpMethod = HTTPMethod.post.rawValue request.setValue("application/json", forHTTPHeaderField: "Content-Type") let pjson = attendences.toJSONString(prettyPrint: false) let data = (pjson?.data(using: .utf8))! as Data request.httpBody = data Alamofire.request(request).responseJSON { (response) in print(response) }
Alamofire를 사용하는 경우 유형을 "URLEncoding.httpBody"로 인코딩하는 것으로 충분합니다.
이를 통해 코드에서 json으로 정의 했음에도 불구하고 httpbody의 문자열로 데이터를 보낼 수 있습니다.
저 한테 효과가 있었어요 ..
업데이트 됨
var url = "http://..."
let _headers : HTTPHeaders = ["Content-Type":"application/x-www-form-urlencoded"]
let params : Parameters = ["grant_type":"password","username":"mail","password":"pass"]
let url = NSURL(string:"url" as String)
request(url, method: .post, parameters: params, encoding: URLEncoding.httpBody , headers: _headers).responseJSON(completionHandler: {
response in response
let jsonResponse = response.result.value as! NSDictionary
if jsonResponse["access_token"] != nil
{
access_token = String(describing: jsonResponse["accesstoken"]!)
}
})
Alamofire의 관리자를 확장하기 위해 @Silmaril의 답변을 수정했습니다. 이 솔루션은 EVReflection을 사용하여 객체를 직접 직렬화합니다.
//Extend Alamofire so it can do POSTs with a JSON body from passed object
extension Alamofire.Manager {
public class func request(
method: Alamofire.Method,
_ URLString: URLStringConvertible,
bodyObject: EVObject)
-> Request
{
return Manager.sharedInstance.request(
method,
URLString,
parameters: [:],
encoding: .Custom({ (convertible, params) in
let mutableRequest = convertible.URLRequest.copy() as! NSMutableURLRequest
mutableRequest.HTTPBody = bodyObject.toJsonString().dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: false)
return (mutableRequest, nil)
})
)
}
}
그런 다음 다음과 같이 사용할 수 있습니다.
Alamofire.Manager.request(.POST, endpointUrlString, bodyObject: myObjectToPost)
요청시 문자열을 원시 본문으로 게시하려는 경우
return Alamofire.request(.POST, "http://mywebsite.com/post-request" , parameters: [:], encoding: .Custom({
(convertible, params) in
let mutableRequest = convertible.URLRequest.copy() as! NSMutableURLRequest
let data = ("myBodyString" as NSString).dataUsingEncoding(NSUTF8StringEncoding)
mutableRequest.HTTPBody = data
return (mutableRequest, nil)
}))
나는 문자열에서 배열을 위해 그것을했다. 이 솔루션은 본문의 문자열에 맞게 조정됩니다.
Alamofire 4의 "기본"방식 :
struct JSONStringArrayEncoding: ParameterEncoding {
private let myString: String
init(string: String) {
self.myString = string
}
func encode(_ urlRequest: URLRequestConvertible, with parameters: Parameters?) throws -> URLRequest {
var urlRequest = urlRequest.urlRequest
let data = myString.data(using: .utf8)!
if urlRequest?.value(forHTTPHeaderField: "Content-Type") == nil {
urlRequest?.setValue("application/json", forHTTPHeaderField: "Content-Type")
}
urlRequest?.httpBody = data
return urlRequest!
}
}
그런 다음 다음과 같이 요청하십시오.
Alamofire.request("your url string", method: .post, parameters: [:], encoding: JSONStringArrayEncoding.init(string: "My string for body"), headers: [:])
func paramsFromJSON(json: String) -> [String : AnyObject]?
{
let objectData: NSData = (json.dataUsingEncoding(NSUTF8StringEncoding))!
var jsonDict: [ String : AnyObject]!
do {
jsonDict = try NSJSONSerialization.JSONObjectWithData(objectData, options: .MutableContainers) as! [ String : AnyObject]
return jsonDict
} catch {
print("JSON serialization failed: \(error)")
return nil
}
}
let json = Mapper().toJSONString(loginJSON, prettyPrint: false)
Alamofire.request(.POST, url + "/login", parameters: paramsFromJSON(json!), encoding: .JSON)
@afrodev의 답변을 참조로 사용했습니다. 제 경우에는 요청에 게시해야하는 문자열로 함수에 매개 변수를 사용합니다. 따라서 다음은 코드입니다.
func defineOriginalLanguage(ofText: String) {
let text = ofText
let stringURL = basicURL + "identify?version=2018-05-01"
let url = URL(string: stringURL)
var request = URLRequest(url: url!)
request.httpMethod = HTTPMethod.post.rawValue
request.setValue("text/plain", forHTTPHeaderField: "Content-Type")
request.httpBody = text.data(using: .utf8)
Alamofire.request(request)
.responseJSON { response in
print(response)
}
}
Illya Krit 의 답변을 바탕으로
세부
- Xcode 버전 10.2.1 (10E1001)
- Swift 5
- Alamofire 4.8.2
Solution
import Alamofire
struct BodyStringEncoding: ParameterEncoding {
private let body: String
init(body: String) { self.body = body }
func encode(_ urlRequest: URLRequestConvertible, with parameters: Parameters?) throws -> URLRequest {
guard var urlRequest = urlRequest.urlRequest else { throw Errors.emptyURLRequest }
guard let data = body.data(using: .utf8) else { throw Errors.encodingProblem }
urlRequest.httpBody = data
return urlRequest
}
}
extension BodyStringEncoding {
enum Errors: Error {
case emptyURLRequest
case encodingProblem
}
}
extension BodyStringEncoding.Errors: LocalizedError {
var errorDescription: String? {
switch self {
case .emptyURLRequest: return "Empty url request"
case .encodingProblem: return "Encoding problem"
}
}
}
Usage
Alamofire.request(url, method: .post, parameters: nil, encoding: BodyStringEncoding(body: text), headers: headers).responseJSON { response in
print(response)
}
Xcode 8.X , Swift 3.X
Easy Use;
let params:NSMutableDictionary? = ["foo": "bar"];
let ulr = NSURL(string:"http://mywebsite.com/post-request" as String)
let request = NSMutableURLRequest(url: ulr! as URL)
request.httpMethod = "POST"
request.setValue("application/json", forHTTPHeaderField: "Content-Type")
let data = try! JSONSerialization.data(withJSONObject: params!, options: JSONSerialization.WritingOptions.prettyPrinted)
let json = NSString(data: data, encoding: String.Encoding.utf8.rawValue)
if let json = json {
print(json)
}
request.httpBody = json!.data(using: String.Encoding.utf8.rawValue);
Alamofire.request(request as! URLRequestConvertible)
.responseJSON { response in
// do whatever you want here
print(response.request)
print(response.response)
print(response.data)
print(response.result)
}
'program tip' 카테고리의 다른 글
Y는 2012를 반환하고 y는 SimpleDateFormat에서 2011을 반환합니다. (0) | 2020.10.22 |
---|---|
onKeyPress 중에 입력 텍스트 상자의 텍스트를 얻는 방법은 무엇입니까? (0) | 2020.10.22 |
react-router v4에서 쿼리 매개 변수를 얻는 방법 (0) | 2020.10.21 |
Object를 부울로 캐스팅하는 방법은 무엇입니까? (0) | 2020.10.21 |
숨겨진 파일을 포함한 Zip (0) | 2020.10.21 |