6月复盘篇:iOS问题解决经验总结复盘

目录
一、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


image.png

开始拉扯进行一系列推锅表演...


image.png
image.png

经历辛苦的口舌大战。。。开始各自找各自的原因。各种方式尝试后,比如h5那边给强制更新,我们app这边给webView清缓存等等各种一系统操作,在url后面给他们token、app_id呀,让h5那边从url后面拿。最终还是死活无法将Cookie种入到css、js中。

我们小组的ios资深技术大咖通过抓包很有自信的讲出自己的见得如上。最终提测后我通过实际证明,上面回复话术有误,并非如此,着实有点打脸。具体详见下文。

1.1 第三方注入

由于提测时间紧迫,最后在github里面找了一个第三方GGWKCookie进行尝试。

image.png
image.png
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
    }

总结:
导致这个问题的罪魁祸首在这里

image.png

注入cookie的这里写的有问题,但是由于此项目已经好几年了,刚开始我并没有怀疑是这里出了问题。后面由于提测后,有空闲时间了,自己写了个示例demo,只要注入cookie的方式正确也能正常跳转。


二、打包上传报错"could not download"

打开活动监视器,找到为java进程。强制退出该进程后,重新打开Transporter上传即可。


image.png
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容