使用soui开发的mbc,只支持windows版本
w1146869587
2022-01-24 479b1995ef435713c2cf4f0da8de3a6af6c30922
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
#include "Cef3CustomerScheme.h"
#include <algorithm>
#include <string>
 
#include "include/cef_browser.h"
#include "include/cef_callback.h"
#include "include/cef_frame.h"
#include "include/cef_resource_handler.h"
#include "include/cef_response.h"
#include "include/cef_request.h"
#include "include/cef_scheme.h"
#include "include/wrapper/cef_helpers.h"
#include "Cef3ResourceUtil.h" 
 
namespace browser {
namespace scheme {
 
namespace {
 
 
// Implementation of the schema handler for live:// requests.
class ClientSchemeHandler : public CefResourceHandler {
public:
    ClientSchemeHandler() : offset_(0) {
    }
 
    virtual bool ProcessRequest(CefRefPtr<CefRequest> request,
                                CefRefPtr<CefCallback> callback)
        OVERRIDE {
        CEF_REQUIRE_IO_THREAD();
 
        bool handled = false;
 
        std::string url = request->GetURL();
        if (strstr(url.c_str(), "handler.html") != NULL) {
            // Build the response html
            data_ = "<html><head><title>Client Scheme Handler</title></head>"
                "<body bgcolor=\"white\">"
                "This contents of this page page are served by the "
                "ClientSchemeHandler class handling the live:// protocol."
                "<br/>You should see an image:"
                "<br/><img src=\"live://tests/logo.png\"><pre>";
 
            // Output a string representation of the request
            const std::string& dump = DumpRequestContents(request);
            data_.append(dump);
 
            data_.append("</pre><br/>Try the test form:"
                         "<form method=\"POST\" action=\"handler.html\">"
                         "<input type=\"text\" name=\"field1\">"
                         "<input type=\"text\" name=\"field2\">"
                         "<input type=\"submit\">"
                         "</form></body></html>");
 
            handled = true;
 
            // Set the resulting mime type
            mime_type_ = "text/html";
        } else if (strstr(url.c_str(), "logo.png") != NULL) {
            // Load the response image
            if (LoadBinaryResource("logo.png", data_)) {
                handled = true;
                // Set the resulting mime type
                mime_type_ = "image/png";
            }
        }
 
        if (handled) {
            // Indicate the headers are available.
            callback->Continue();
            return true;
        }
 
        return false;
    }
 
    virtual void GetResponseHeaders(CefRefPtr<CefResponse> response,
                                    int64& response_length,
                                    CefString& redirectUrl) OVERRIDE {
        CEF_REQUIRE_IO_THREAD();
 
        DCHECK(!data_.empty());
 
        response->SetMimeType(mime_type_);
        response->SetStatus(200);
 
        // Set the resulting response length
        response_length = data_.length();
    }
 
    virtual void Cancel() OVERRIDE {
        CEF_REQUIRE_IO_THREAD();
    }
 
    virtual bool ReadResponse(void* data_out,
                              int bytes_to_read,
                              int& bytes_read,
                              CefRefPtr<CefCallback> callback)
        OVERRIDE {
        CEF_REQUIRE_IO_THREAD();
 
        bool has_data = false;
        bytes_read = 0;
 
        if (offset_ < data_.length()) {
            // Copy the next block of data into the buffer.
            int transfer_size = (std::min)(bytes_to_read, static_cast<int>(data_.length() - offset_));
            memcpy(data_out, data_.c_str() + offset_, transfer_size);
            offset_ += transfer_size;
 
            bytes_read = transfer_size;
            has_data = true;
        }
 
        return has_data;
    }
 
private:
    std::string data_;
    std::string mime_type_;
    size_t offset_;
 
    IMPLEMENT_REFCOUNTING(ClientSchemeHandler);
};
 
// Implementation of the factory for for creating schema handlers.
class ClientSchemeHandlerFactory : public CefSchemeHandlerFactory {
public:
    // Return a new scheme handler instance to handle the request.
    virtual CefRefPtr<CefResourceHandler> Create(CefRefPtr<CefBrowser> browser,
                                                 CefRefPtr<CefFrame> frame,
                                                 const CefString& scheme_name,
                                                 CefRefPtr<CefRequest> request)
        OVERRIDE {
        CEF_REQUIRE_IO_THREAD();
        return new ClientSchemeHandler();
    }
 
    IMPLEMENT_REFCOUNTING(ClientSchemeHandlerFactory);
};
 
}  // namespace
 
void RegisterSchemeHandlers() {
    CefRegisterSchemeHandlerFactory("live", "tests", new ClientSchemeHandlerFactory());
}
 
void RegisterCustomSchemes(CefRawPtr<CefSchemeRegistrar> registrar,
                           std::vector<CefString>& cookiable_schemes) {
    registrar->AddCustomScheme("client", true, false, false, false, true, false);
}
 
}  // namespace scheme
}  // namespace browser