目录
一、webView 跳转h5, css 、js如何注入cookie
1.1 第三方注入
1.2 原生通过js注入
二、打包上传报错"could not download"
一、webView 跳转h5, css 、js如何注入cookie
问题纪要
由于公司的有些业务是跳转到h5, 目前市面上大部分与h5的交互几乎都是通过以添加个请求头,记录登录态。由于该公司环境较多要想达到灰度,我们需要多拼接一个app_id.....
问题解决方式记录:
首先第一波必然先排查,排查发现css、js的一些相关资源丢失Cookie
开始拉扯进行一系列推锅表演...
经历辛苦的口舌大战。。。开始各自找各自的原因。各种方式尝试后,比如h5那边给强制更新,我们app这边给webView清缓存等等各种一系统操作,在url后面给他们token、app_id呀,让h5那边从url后面拿。最终还是死活无法将Cookie种入到css、js中。
我们小组的ios资深技术大咖通过抓包很有自信的讲出自己的见得如上。最终提测后我通过实际证明,上面回复话术有误,并非如此,着实有点打脸。具体详见下文。
1.1 第三方注入
由于提测时间紧迫,最后在github里面找了一个第三方GGWKCookie进行尝试。
1.2 原生通过js注入
js注入
func setupSubViews(){
let configuration = WKWebViewConfiguration()
let contentController = WKUserContentController()
if #available(iOS 10.0, *){
// configuration.mediaTypesRequiringUserActionForPlayback = .none
} else {
// Fallback on earlier versions
configuration.mediaPlaybackRequiresUserAction = false
}
var cookie = ""
for cookieModel in cookieArr() {
cookie = cookie.appendingFormat("document.cookie = '\(cookieModel.key)=\(cookieModel.value); path=/; domain=.xiaoeknow.com';")
}
let cookieScript = WKUserScript.init(source: cookie, injectionTime: .atDocumentStart, forMainFrameOnly: false)
contentController.addUserScript(cookieScript)
configuration.userContentController = contentController
webView = WKWebView(frame: CGRect(x: 0, y: kNavBarHeight, width: kScreenWidth, height: kScreenHeight),configuration: configuration)
webView.scrollView.bounces = false
webView.backgroundColor = UIColor.white
// webView.scrollView.delegate = self
webView.clipsToBounds = false
view.addSubview(webView)
loadWebViewUrl()
}
func loadWebViewUrl(){
if params.requestUrl.count > 0 {
let request = NSMutableURLRequest(url: URL(string: params.requestUrl)!)
var cookie = ""
for cookieModel in cookieArr() {
cookie = cookie.appendingFormat("\(cookieModel.key)=\(cookieModel.value),")
}
request.setValue(cookie, forHTTPHeaderField: "Cookie")
self.webView?.load(request as URLRequest)
}
}
// 设置cookie
func cookieArr() -> [CookieModel]{
var cookies = [CookieModel]()
let app_token = CookieModel()
app_token.key = "app_token"
app_token.value = "token_62a99c028136e3VXn5oPa5wWoFfixVLRx"
let with_app_id = CookieModel()
with_app_id.key = "with_app_id"
with_app_id.value = "appptaa4nql6484"
let app_type = CookieModel()
app_type.key = " app-type"
app_type.value = "merchant_assistant_app"
cookies.append(app_token)
cookies.append(with_app_id)
cookies.append(app_type)
return cookies
}
总结:
导致这个问题的罪魁祸首在这里
注入cookie的这里写的有问题,但是由于此项目已经好几年了,刚开始我并没有怀疑是这里出了问题。后面由于提测后,有空闲时间了,自己写了个示例demo,只要注入cookie的方式正确也能正常跳转。
二、打包上传报错"could not download"
打开活动监视器,找到为java进程。强制退出该进程后,重新打开Transporter上传即可。