Haruyuki Mohri

毛利春幸のブログです。

Ext JS proxy.Ajaxストアで CORS JSON base64画像をブラウザで表示

Output to JSON Base64 Image Data Reading Browser.
I use Ext JS. And the JSON server is C++Builder bcc32.
f:id:mojeld:20171024162612g:plain

Create a standalone new project for WebBroker.

f:id:mojeld:20171024162043p:plain

Add action on TWebModule side.

PathInfo is set to "/img".
f:id:mojeld:20171024162513p:plain

It is a code to output JSON corresponding to CORS.

Code that can be compiled with bcc32. For CORS please refer to the following URL.
https://developer.mozilla.org/en-US/docs/Web/HTTP/CORS

#include <memory>
#include <System.NetEncoding.hpp>
#include <System.Json.hpp>
void __fastcall TWebModule_main::WebModule_mainWebActionItem1Action(TObject *Sender,
          TWebRequest *Request, TWebResponse *Response, bool &Handled)
{
    const String filename = "90020_Ballistoides_conspicillum.jpeg";
    std::tr1::shared_ptr<TMemoryStream> m1(new TMemoryStream());
    std::tr1::shared_ptr<TJSONArray> ja(new TJSONArray());
    try
    {
        m1->LoadFromFile(filename);
        String ext          = ExtractFileExt(filename).Delete0(0,1);
        TStringStream* m2   = new TStringStream();

        TNetEncoding::Base64->Encode(m1.get(), m2);
        String out =  StringReplace("data:image/jpeg;base64,","jpeg",ext,TReplaceFlags() << rfReplaceAll)
            + StringReplace(m2->DataString, "\r\n", "", TReplaceFlags() << rfReplaceAll);
        m2->Clear();

        Response->ContentType   = "application/json; charset=UTF-8";
        Response->SetCustomHeader("Access-Control-Allow-Origin", "*");
        Response->SetCustomHeader("Access-Control-Allow-Headers", "X-Requested-With, X-PINGOTHER, Content-Type");

        ja->AddElement(new TJSONObject(new TJSONPair("img",out)));
        m2->WriteString(StringReplace(ja->ToJSON(), "\\", "", TReplaceFlags() << rfReplaceAll));
        Response->ContentStream  = m2;
    }
    catch(Exception& e1)
    {
        Response->Content = e1.Message;
    }
}

The output JSON is as follows.

[{"img":""}]

Ext JS design.

Create image and button screens using Sencha Architect.
f:id:mojeld:20171024163632p:plain
Add Store.

Ext.define('jsonimage1.store.Store1', {
    extend: 'Ext.data.Store',

    requires: [
        'Ext.data.proxy.Ajax',
        'Ext.data.reader.Json'
    ],

    constructor: function(cfg) {
        var me = this;
        cfg = cfg || {};
        me.callParent([Ext.apply({
            storeId: 'Store1',
            proxy: {
                type: 'ajax',
                url: 'http://localhost:8080/img',
                reader: {
                    type: 'json'
                }
            }
        }, cfg)]);
    }
});

Create a button event for Ext JS.

    onButtonClick1: function(button, e, eOpts) {
        var me = this;
        var store = Ext.getStore('Store1');

        store.load({
            callback: function (records) {
                var img = me.lookup('json_img');
                img.setSrc(records[0].get('img'));
            }
        });
    }