Swift3 WKWebView如何从HTTPCookieStorage添加身份验证Cookie

Swift3 WKWebView如何从HTTPCookieStorage添加身份验证Cookie,swift3,wkwebview,Swift3,Wkwebview,我正在开发一个使用混合本机视图控制器和UIWebView的应用程序。应用程序登录由API处理,我有一个实用程序函数,可以将身份验证令牌保存到HTTPCookieStorage中的cookie以及持久用户模型中 现在我想更新到WKWebView,但它不会像UIWebView那样自动从HTTPCookieStorage加载cookies 我找到了一种从答案中保存响应cookie的方法,我可以修改答案以将身份验证令牌也存储到我的用户模型中,但我不确定如何将cookie用于新请求。我只需要将cookie

我正在开发一个使用混合本机视图控制器和
UIWebView
的应用程序。应用程序登录由API处理,我有一个实用程序函数,可以将身份验证令牌保存到
HTTPCookieStorage
中的cookie以及持久用户模型中

现在我想更新到
WKWebView
,但它不会像
UIWebView
那样自动从
HTTPCookieStorage
加载cookies

我找到了一种从答案中保存响应cookie的方法,我可以修改答案以将身份验证令牌也存储到我的用户模型中,但我不确定如何将cookie用于新请求。我只需要将cookie添加到初始加载,因为我将禁用web视图中的导航

有没有办法将cookie值添加到标头或其他解决方案

下面是我将用于从响应中获取cookie的代码

func webView(_ webView: WKWebView, decidePolicyFor navigationResponse: WKNavigationResponse, decisionHandler: @escaping (WKNavigationResponsePolicy) -> Void) {
if let urlResponse = navigationResponse.response as? HTTPURLResponse,
   let url = urlResponse.url,
   let allHeaderFields = urlResponse.allHeaderFields as? [String : String] {
   let cookies = HTTPCookie.cookies(withResponseHeaderFields: allHeaderFields, for: url)
   HTTPCookieStorage.shared.setCookies(cookies , for: urlResponse.url!, mainDocumentURL: nil)
   decisionHandler(.allow)
}
}

这不是WKWebView。
func webViewDidStartLoad(webView: UIWebView)
{


    let currentURL: String = webView.stringByEvaluatingJavaScriptFromString("window.location.href")!

    print("currentURL =\(currentURL)")

    self.invalidUserNameMsg.hidden = true;
    self.startActivityIndicatory()

    if(!self.isLoginButtonClick)
    {
        let cookieStorage = NSHTTPCookieStorage.sharedHTTPCookieStorage()
        var cookieStr:String = ""
        let cookies = cookieStorage.cookies!
        let strTemp = self.linstance_url.stringByReplacingOccurrencesOfString("https://", withString: "")
        for cookie in cookies {
            cookieStr = cookieStr + "=" + cookie.name + "=" + cookie.value


            if(cookie.name == "sid" && (cookie.value.characters.count > 100) && cookie.domain == strTemp)
            {

                ApplicationContext.sharedInstance.accessToken = cookie.value
                ApplicationContext.sharedInstance.instanceUrl = self.linstance_url
                ApplicationContext.sharedInstance.orgNamespace = orgNamespaceStr


                NSUserDefaults.standardUserDefaults().setObject(cookie.value, forKey: "accessToken")
                NSUserDefaults.standardUserDefaults().setBool(true, forKey: "IsSSOLogin")
                NSUserDefaults.standardUserDefaults().setObject(self.linstance_url, forKey: "linstance_url")

                NSUserDefaults.standardUserDefaults().synchronize()

                let appDelegate : AppDelegate = UIApplication.sharedApplication().delegate as! AppDelegate;

                appDelegate.isSidValue = true
                NSOperationQueue.mainQueue().addOperationWithBlock {

                    self.ssoWebView.hidden = true
                    self.ssoWebViewCloseButton.hidden = true

                }


                if(!self.isLoginButtonClick)
                {
                    userNameTextField.text = ""
                    passwordTextField.resignFirstResponder();
                    userNameTextField.resignFirstResponder();
                    loginScrollView.contentSize = CGSizeMake(loginScrollView.frame.width, loginScrollView.frame.height - 100)

                    self.loginButtonAction(UIButton)
                    self.isLoginButtonClick = true
                }

            }

        }
    }
}

func webViewDidFinishLoad(webView: UIWebView)
{


    self.stopActivityIndicator()




}
func webView(webView: UIWebView, didFailLoadWithError error: NSError?)
{
    self.stopActivityIndicator()
}