Display JSON Base64 images created in C++Builder using Ext JS in browser

by Oct 24, 2017

Output to JSON Base64 Image Data Reading Browser.
I use Ext JS. And the JSON server is C++Builder bcc32.

 

Create a standalone new project for WebBroker.

 

 

Add action on TWebModule side.

PathInfo is set to "/img".

 

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"new TMemoryStream());
    std::tr1::shared_ptr<TJSONArray> ja(new TJSONArray());
    try
    {
        m1->LoadFromFile(filename);
        String ext          = ExtractFileExt(filename).Delete0(0,1new 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""Access-Control-Allow-Origin", "*""Access-Control-Allow-Headers", "X-Requested-With, X-PINGOTHER, Content-Type"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.

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{}[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 = thisvar store = Ext.getStore('Store1'{
            callback: function (records) {
                var img = me.lookup('json_img'[0].get('img'}
        }}