- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在开发一个向网络服务发送多个请求的应用程序。随着我进一步开发,我发现 Web 服务变得不堪重负,我需要放慢速度。我想将每个请求单独发送到 Web 服务,并等到前一个请求完成后再发送下一个请求。下面是使用循环调用 Web 服务的函数:
func syncronize(){
for operation in syncOperations{
switch operation{
case "listPhone":
let listRequest = WSListRequest(requestType: operation, searchCriteria: [SearchCriteria(name: "name", value: "%")], returnTags: [])
_ = HTTPPost(method: "POST", body: listRequest.xml, operation: operation, credentials: creds)
default:
let listRequest = WSLListRequest(requestType: operation, searchCriteria: [SearchCriteria(name: "name", value: "%")], returnTags: ["name"])
_ = HTTPPost(method: "POST", body: listRequest.xml, operation: operation, credentials: creds)
}
}
}
HTTPPost 函数如下所示:
class HTTPPost: NSObject, URLSessionDelegate {
var componentDebug = false
var user = String()
var password = String()
var server = String()
var port = String()
var body = NSString()
var response = Data()
init(method: String, body: NSString, operation: String, credentials: WSCredential){
super.init()
let bodyData = body.data(using: String.Encoding.utf8.rawValue)
let config = URLSessionConfiguration.default
let userPasswordString = NSString(format: "%@:%@", credentials.userName, credentials.password)
let userPasswordData = userPasswordString.data(using: String.Encoding.utf8.rawValue)
let base64EncodedCredential = userPasswordData!.base64EncodedString(options: NSData.Base64EncodingOptions.lineLength64Characters)
let authString = "Basic \(base64EncodedCredential)"
config.httpAdditionalHeaders = ["Authorization" : authString, "Content-Type" : "text/xml;charset=UTF-8"]
config.timeoutIntervalForRequest = 10.0
// create the user request
let urlString = NSString(format: "https://%@:%@/ws/", credentials.server, credentials.port)
let url = URL(string: urlString as String)
var request = URLRequest(url: url!)
request.httpMethod = method
request.httpBody = bodyData
request.setValue("Basic \(base64EncodedCredential)", forHTTPHeaderField: "Authorization")
let session = Foundation.URLSession(configuration: config, delegate: self, delegateQueue:OperationQueue.main)
_ = session.dataTask(with: request, completionHandler: { (data, response, error) in
let responseParser = XMLParser(data: data!)
let responseParserDelegate = XMLResponseParser(operation: operation)
responseParser.delegate = responseParserDelegate
responseParser.parse()
// DEBUGGING OPTIONS
//print(response)
//print(NSString(data: data!, encoding: NSUTF8StringEncoding))
DispatchQueue.main.async(execute: {
self.response = data!
})
}).resume()
}
func urlSession(_ session: URLSession, didReceive challenge: URLAuthenticationChallenge, completionHandler: @escaping (URLSession.AuthChallengeDisposition, URLCredential?) -> Void) {
completionHandler(Foundation.URLSession.AuthChallengeDisposition.useCredential, URLCredential(trust: challenge.protectionSpace.serverTrust!))
}
}
我是异步编程方面的新手,需要一些帮助。提前致谢。
最佳答案
使用信号量,以便前一个任务完成之前不会开始一个任务。这是一个演示
// The semaphore value is like the size of a token pool. After you've taken
// all the tokens in the pool, you must wait until a task returns its token
// back to the pool. Here we only have 1 token (1 request at a time)
let semaphore = DispatchSemaphore(value: 1)
// task1 is a request that will take at least 5 seconds to respond
let task1 = URLSession.shared.dataTask(with: URL(string: "https://httpbin.org/delay/5")!) { data, response, error in
print("Task1 is done")
semaphore.signal() // release the token
}
// task2 is a faster request
let task2 = URLSession.shared.dataTask(with: URL(string: "https://httpbin.org")!) { data, response, error in
print("Task2 is done")
semaphore.signal() // release the token
}
// Never wait on your main queue, always do that in the background
DispatchQueue.global(qos: .background).async {
semaphore.wait() // take a token, wait if needed.
// There will never be a wait here, but included for consistency
print("starting task 1")
task1.resume()
semaphore.wait() // take a token, wait if needed
print("starting task 2")
task2.resume()
}
有了信号量,输出就是你所期望的:
starting task 1
Task1 is done
starting task 2
Task2 is done
取出 2 行 semaphore.wait()
可以看到这两个请求将如何同时发送:
starting task 1
starting task 2
Task2 is done
Task1 is done
关于Swift:减慢对 WebService 的多次调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42284950/
WebService 依赖: org.springframework.boot spring-boot-starter-web-services org.apache.cxf cxf-rt-fr
我需要在我的项目中使用 Web 服务。我使用 NetBeans,因此右键单击我的项目并尝试添加新的“Web 服务客户端”。上次我检查过,这是创建 Web 服务客户端的方法。但它导致了一个断言错误,说:
我在 Netbeans 中创建了两个 Java SOAP Web 服务。基本上每个服务都是一个不同的 Web 应用程序,有自己的 war 文件。我从 Java 客户端调用第一个 WS,并从第一个服务调
有没有一种有效的工具可以将 .Net C# webservice 转换为 java webservice。是否有任何开源工具可以提供帮助? 最佳答案 不要浪费时间寻找过渡工具。如果您使用的是 Java
情况是这样的。我从某人那里收到了由 Apache/Tomcat 服务器 (Java) 生成的 WSDL(包括 XSD)。我为其做一个项目的公司更喜欢 .NET,因此我使用 wsdl.exe 生成部分类
我正在使用 java 开发 axis2 网络服务,用于将记录插入数据库。我正在测试 web 服务客户端,它返回空响应代码,实际上我在 web 服务中返回整数值但我成功地将记录插入数据库,我可以在执行客
您好,我正在尝试使用 json 在钛中调用 webService。该 webService 不接受任何参数,所以我只需要调用它。 这是我的代码: var xhr = Titanium.Network.
我正在尝试将基本的Web服务模板部署到tomee,我尝试了Windows 7 64位和Windows 8 64位以及java版本1.8.0_25(64位),1.8.0_91(64位)(此java版本用
我正在尝试使用包含 web 服务参数的 get 方法调用 web 服务。但我无法在互联网上找到答案,请任何人帮助我。下面给出我的网络服务 http://api.crmseries.com/user/V
调用 Web 服务时出现以下抛出错误。除了人们问同样的问题外,用谷歌搜索没有任何结果。 Server was unable to process request. ---> The surrogate
我正在尝试使用 Yahoo 查询语言找到一种通过 Yahoo Weather 获取一些天气信息的方法。 因为我住在法国的一个叫尼斯的城市,下面的查询返回一个错误: select * from weat
我需要知道是否可以从后台调用 json webservices,当用户按下主页按钮时,我从后台执行调用此方法 - (void) runTimer { [NSThread detachNewTh
我有一个 Web 服务,它位于这样的反向代理后面: 现在发生的情况是,当我尝试添加 Web 引用来测试 Web 服务时,它说无法下载 wsdl 文件。那是因为当请求被发送时它是 https://uat
我需要创建一个Web服务,该服务用于通过输入一个字符串ID从服务器下载音频(wav)文件。如果服务器上不存在音频文件,则需要以json格式发送错误回传。 现在的问题是-如何为下载文件提供扩展名。我不知
我编写了一个 C# WebService。问题是,在我将其发布到 IIS 后,除非调用其任何方法,否则它不会自动启动。这是非常令人沮丧的,因为这个 WebService 必须在启动(其构造函数执行)后
simple spring example demoServiceImpl org.apache.axis2.extensions.spring.
我使用 reSTLet 为我的应用程序构建了 Java Web 服务。它是纯 Java 且独立的。有没有免费的云服务可以托管我的网络服务? 它的要求确实很低。其中之一是静态 IP。 最佳答案 使用 j
我正在研究基于 SOAP 的 Web 服务。我需要测试一个场景,如果由于任何网络问题或登录问题而发生 Web 服务连接错误。 apache cxf 的问题是无论 web 服务抛出什么异常 "java
如何在没有datamapper的情况下在mule中调用soap webservice并且输入是xml。我正在使用社区添加。 & 我的输入是 xml 而不是肥皂信封。 我的 wsdl 位置是 - htt
我知道 php webservice SOAP、json、rest 等,但我是 java webservice 的新手。现在我想让 php 客户端连接到 java webservice。最好的方法是什
我是一名优秀的程序员,十分优秀!