Latest 0.0.1
License MIT
Platforms ios 6.0, requires ARC


客户端与 UIWebView 中的 HTML 页面需要同步登录态时,如果客户端登录后,进入 HTML 页面则不用重新登录。该项目适用于登录态采用 Cookies 机制。


引用的一段来自 教程中的话:

NSURLProtocol is like a magic key to the URL. It lets you redefine how Apple’s URL Loading System operates, by defining custom URL schemes and redefining the behavior of existing URL schemes.

该项目通过子类 NSURLProtocol 实现 URL 加载时,向符合条件的 URL 注入本地已保存的 Cookies 已达到同步登录态的作用。
另外一篇是 Mattt 大神关于 NSURLProtocol 的文章


#import "HTXSCookieURLProtocol.h"

尽早地在 AppDelegate 注册 NSURLProtocol 子类。

// Register NSURLProtocol
[NSURLProtocol registerClass:[HTXSCookieURLProtocol class]];
[HTXSCookieURLProtocol configureCookieWithBlock:^(id<HTXSCookieConfiguration> configuration) {
        // Init Config Cookies
        [configuration setCookies:[[CookiesManager sharedInstance] getCookies]];

Nginx + PHP

示例项目中包括 Authority.phpindex.html 文件用于测试客户端与 UIWebView 中同步登录态。需要搭建 Nginx 和 PHP 环境,我也是通过 这篇教程 从 0 到 1 搭建的环境。最后使用了 CodeIgniter 配置了 RESTful 接口用于测试。


Feel free to drag HTXSCookieURLProtocol.h and HTXSCookieURLProtocol.m to your iOS Project. But it’s recommended to use CocoaPods.


CocoaPods is a dependency manager for Cocoa projects. You can install it with the following command:

$ [sudo] gem install cocoapods

To integrate HTXSCookieURLProtocol into your Xcode project using CocoaPods, specify it in your Podfile:

source ''

pod 'HTXSCookieURLProtocol', '~> 0.0.1'

Then, run the following command:

$ pod install

You should open the {Project}.xcworkspace instead of the {Project}.xcodeproj after you installed anything from CocoaPods.

For more information about how to use CocoaPods, I suggest this tutorial.


HTXSCookieURLProtocol is available under the MIT license. See the LICENSE file for more info.

Latest podspec

    "name": "HTXSCookieURLProtocol",
    "version": "0.0.1",
    "summary": "Synchronization Cookies with NSURLProtocol.",
    "homepage": "",
    "license": {
        "type": "MIT",
        "file": "LICENSE"
    "authors": {
        "tianjie": "[email protected]"
    "platforms": {
        "ios": "6.0"
    "source": {
        "git": "",
        "tag": "0.0.1"
    "source_files": "HTXSCookieURLProtocol/*.{h,m}",
    "requires_arc": true

Pin It on Pinterest

Share This