× The internal search function is temporarily non-functional. The current search engine is no longer viable and we are researching alternatives.
As a stop gap measure, we are using Google's custom search engine service.
If you know of an easy to use, open source, search engine ... please contact support@midrange.com.



I found an example of doing a bit differently but getting closer.



Add varibles

Dcl-S DecodedTextVarBinary sqltype(VARBINARY:4096);

Dcl-S DecodedLabel VARCHAR(4096) CCSID(1208);



And change code to do



// Decode the encoded text into an EBCDIC VarBinary field

Exec SQL Values QSYS2.BASE64_DECODE(:Base64String) Into :DecodedTextVarBinary;



// Translate binary data in EBCDIC to UTF-8

DecodedLabel = DecodedTextVarBinary;



DecodedLabel

[cid:image002.png@01DA4948.23D733F0]



Why the second step? I have so much to learn.



-----Original Message-----
From: RPG400-L <rpg400-l-bounces@xxxxxxxxxxxxxxxxxx> On Behalf Of (WalzCraft) Jerry Forss
Sent: Wednesday, January 17, 2024 1:06 PM
To: RPG programming on IBM i <rpg400-l@xxxxxxxxxxxxxxxxxx>
Subject: RE: External RE: Base64Decode



Scott



Here is the pgm stripped down but getting same results.

I am trying different methods with QSys2.Base64Decode and systools.base64decode.

I get all @ returned.



**Free

Ctl-opt option(*SrcStmt : *NoDebugIO)

Dftactgrp(*NO)

ActGrp(*Caller);



Dcl-S DecodedLabel VarChar(4096) CCSID(1208);

Dcl-S Done Ind Inz('0');

Dcl-S False Ind Inz('0');

Dcl-S True Ind Inz('1');

Dcl-S Base64String VarChar(4096) CCSID(1208)

Inz('XlhBDQoNCl5GWCBTcGVlLURlZSBMb2dvDQpeRk81MTAsMTU0XkdGQSw3NTAsNzUwLDEwLCw6Ok4+

wMixRMDgsTDBDSjAxOCxLMDJMMDIsSzA4MDFGSjA4LEowMjAwM0YwMEMwMixKMDQwNzNDMDFGMDE4LEs+

wM0UzRjAxRkMwNCxJMDIwM0MxRjMxREMwMixJMDQwM0Y5QzdCOUM0MSxJMDgzREYxRjgzOUNGLDAwMTA+

3REUxRjg3QkNGOCwwMDIxQ0VGRDgwN0Y5RkMyLDAwNDFFQ0Y4STBGM0NDMSxJMDFGOEVJMDEwN0UwMDg+

sMDA4MEY4SjA2ODc3MDA0LEkwQzc4MDFGRTAwM0ExQzQsMDAxQzNDMDdGQzAzMUMzQzIsMDIzOTk4MUZ+

GRTdGMENGRSwwMDM3QzA3RkZDRTM4M0ZGMSwwNDNGQzBKRkMzMDNGMywwMDNFQzFJRjM5QzQxREEwOCw+

wMDM5QzNJRkIyMjYwRDgsSTAzODdJRjUwMDMwRTAwNCxJMDMwN0ZGRUMwMDc4NjAwNCxLMEZGRTY0MEM+

3OCxKMDFGRjAxRTQwRkMsSjAxRTIwMEU2MDdDLEowMzA0MDAyMjEzRSxKMDM4ODAwMTAzRkUsMkkwMzM+

xMEMxRTAwRSxKMDM4MjA2MDQwMDYsSjA3ODQwNjAwNzYzLEowNzA0NjAwMTAxMyxKMDcyOUkwMzAwQix+

KMDdBOEkwMjA0RCxKMDdDNEkwNjRFNyxKMDdDMDA0MEUyMDMsSjA3QzIzQzBBMDA3LDIwNzAzRUJDMzN+

GMDA3MDA0LDIwRjAzRkM4MDdGQzdBMDIsMjA5MDNGRDE4MEZGQkUwNjgsMDBGMDFGQzAwMUlGRTA3OCx+

KMDFGQzAwMUlGQzAzOCwwMDM4MUJDMDEwSUZDMEMsMDA3ODAwNTA3MDlGRjgwNywwMDdJMDgxRDExRkY+

4MEYsSTA0SjBBMzNGRjAxRSwwMDFDMDIwMTczM0ZFMDA2LDAwMTgwMjAwRjMzRkMwMzgwOCwwNDFCSTA+

zRkJGRjgwMUMsSTBGMDQzRkZCMUYsMDIwNDgwMUZGRDNDLEkwMUEwMEpGODAyLDAxMDFFMDAxRkZDMDA+

3MiwwMDgxOThNMDdFLEowM0NMMDFCODA4LDAwNDAzQkwwMzEwMSwwMDIwMzM4SzBCNDAyLDAwMTAwN0V+

KMDJEQyxJMDgwNzM4MDAxQUMsSTA0MDEzMEpFNDAxLEkwMjAwMjBDQ0U2MDAyLEkwMUowRUNGSTA0LE4+

wRUU4MDAxOCxTMDIsSzA4TTA4LEswMkwwMixMMENKMDE4LE0wOEkwQywsOl5GUw0KDQoNCl5GWCBTZXJ+

2aWNlIFN1bW1hcnleRlMNCl5GTzAsMF5HQjYwOSw4MTIsNV5GUw0KXkZPMjUsNDBeQTBOLDM1LDQwXkZ+

ET1ZSXkZTDQpeRk8yNSw3NV5BME4sMzUsNDBeRkReRlMNCl5GTzI1LDExMF5BME4sMzUsNDBeRkReRlM+

NCl5GTzI1LDE0NV5BME4sMzUsNDBeRkReRlMNCg0KXkZYIEJFR0lOX1NlbmRlciBJbmZvcm1hdGlvbl5+

GUw0KXkZPMTE1LDQwXkFBTiwxOCwxMF5GRF5GUw0KXkZPMTE1LDY1XkFBTiwxOCwxMF5GRFdhbHpDcmF+

mdF5GUw0KXkZPMTE1LDkwXkFBTiwxOCwxMF5GRDI2MDAgSGVtc3RvY2sgU3ReRlMNCl5GTzExNSwxMTV+

eQUFOLDE4LDEwXkZEXkZTDQpeRk8xMTUsMTQwXkFBTiwxOCwxMF5GRExhIENyb3NzZSwgV0kgNTQ2MDN+

eRlMNCl5GTzExNSwxNjVeQUFOLDE4LDEwXkZEXkZTDQpeRlggU2VuZGVyX0VORF5GUw0KDQpeRlggUGx+

hY2VIb2xkZXJfZm9yX0VaUmV0dXJuXkZTDQoNCl5GWCBBenRlYyBiYXJjb2RlXkZTDQpeQjBSLDYsTiw+

wLE4sMSwwDQpeRk80NzAsNDBeRkQ1MzUzMlNQMDkwMDAwMjYwMTc5NDIzODAwXkZTDQoNCl5GWCBTcGV+

lLURlZSBCYXJjb2RlLCB3ZWlnaHQsIHZlcnNpb25eRlMNCl5GTzI1LDE5MF5BQU4sMTgsMTBeRkRTcGV+

lLURlZSBCYXJjb2RlIE5vOl5GUw0KXkZPMjUsMzc1XkFBTiwxOCwxMF5TTlNQRUUtREVFIEFQSSAxLjA+

uMTUzLjBeRlMNCl5GTzI1LDIxNV5BQU4sMTgsMTBeRkRTUCAwOTAwMDAgMjYgMDE3MjQgMjM4MDBeRlM+

NCl5GTzM2MCwyMTVeQUFOLDE4LDEwXkZEV1Q6MjleRlMNCl5GTzI1LDIzNV5CWTMsXkJDTiwxMzUsTix+

ZLCxBDQpeQUJeRkRTUDA5MDAwMDI2MDE3OTQyMzgwMF5GUw0KDQpeRlggU2VydmljZSBEZXRhaWxeRlM+

NCl5GTzI1LDQwNV5BQU4sMTgsMTBeRkReRlMNCl5GTzUwMCw0MDUsMV5BQU4sMTgsMTBeRkReRlMNCl5+

GTzI1LDQzMF5BQU4sMTgsMTBeRkReRlMNCl5GTzUwMCw0MzAsMV5BQU4sMTgsMTBeRkReRlMNCl5GTzI+

1LDQ1NV5BQU4sMTgsMTBeRkReRlMNCl5GTzI1LDQ4MF5BQU4sMTgsMTBeRkReRlMNCg0KXkZYIFNoaXA+

gVG8gRGV0YWlsXkZTIA0KXkZPMjAwLDUyMF5BRk4sMTgsMTBeRkRTaGlwIFRvOl5GUw0KXkZPNDAsNTU+

wXkFBTiwxOCwxMF5GREplcnJ5IEZvcnNzXkZTDQpeRk80MCw1NzVeQUFOLDE4LDEwXkZESmVycnkgRm9+

yc3NeRlMNCl5GTzQwLDYwMF5BQU4sMTgsMTBeRkQ2NjY5IENodXJjaCBIaWxsIEN0XkZTDQpeRk80MCw+

2MjVeQUFOLDE4LDEwXkZEXkZTDQpeRk80MCw2NTBeQUROLDE4LDEwXkZEXkZTDQpeRk81MDAsNjUwLDF+

eQUROLDE4LDEwXkZEXkZTDQpeRk80MCw2NzVeQUROLDE4LDEwXkZEXkZTDQpeRk81MDAsNjc1LDFeQUR+

OLDE4LDEwXkZEXkZTDQpeRk80MCw3MDBeQUVOLDE4LDEwXkZERGVGb3Jlc3ReRlMNCl5GTzQwLDczMF5+

BRU4sMTgsMTBeRkReRlMNCl5GTzI2MCw3MzBeQUVOLDE4LDEwXkZEV0leRlMNCl5GTzM4MCw3MzBeQUV+

OLDE4LDEwXkZENTM1MzJeRlMNCl5GTzQwLDc2MF5BRE4sMTgsMTBeRkQ2MDg3OTcwOTI2XkZTDQoNCl5+

GWCBTaWRlIEJhciBDb2RlXkZTDQpeRk81MTUsMzgwDQpeQlkyXkJDQiw2NSxOLE4sLEENCl5GRFNQMDk+

wMDAwMjYwMTc5NDIzODAwXkZTDQoNCl5GTzIwLDUyMF5HQjYwLDMsMl5GUw0KXkZPMjAsNTIwXkdCMyw+

yNzAsMl5GUw0KXkZPMjAsNzg3XkdCNjAsMywyXkZTDQpeRk80NDAsNTIwXkdCNjAsMywyXkZTDQpeRk8+

1MDAsNTIwXkdCMywyNzAsMl5GUw0KXkZPNDQwLDc4N15HQjYwLDMsMl5GUw0KDQpeRlggU29ydCBDb2R+

lXkZTDQpeRk81MTUsNzIwXkEwTiw1NCw3MF5GRDExXkZTDQpeRk81MzAsNzcwXkFETiwxOCwxMF5GRDA+

wMF5GUw0KDQpeWFoNCg==');



// Convert From Base64Data To ZPL

exec sql values QSys2.Base64_DeCode(:Base64String) Into :DecodedLabel;



*InLr = True;

Return;



-----Original Message-----

From: RPG400-L <rpg400-l-bounces@xxxxxxxxxxxxxxxxxx<mailto:rpg400-l-bounces@xxxxxxxxxxxxxxxxxx>> On Behalf Of Scott Klement

Sent: Wednesday, January 17, 2024 12:44 PM

To: rpg400-l@xxxxxxxxxxxxxxxxxx<mailto:rpg400-l@xxxxxxxxxxxxxxxxxx>

Subject: Re: External RE: Base64Decode



Jerry,



I don't know how to help you with this. I feel that your original message is not technical enough for me to delve into it.



Can you provide a code example with hard-coded values that show what is provided on input, and lets me run it to see what you are getting on output, along with an explanation of what you are expecting to be different?





On 1/17/2024 8:27 AM, (WalzCraft) Jerry Forss wrote:

Is anyone actually using the base64decode from RPG and it's working?



Honestly the IBM doc is no help and my other research isn't bring up anything of a working example.





--

This is the RPG programming on IBM i (RPG400-L) mailing list To post a message email: RPG400-L@xxxxxxxxxxxxxxxxxx<mailto:RPG400-L@xxxxxxxxxxxxxxxxxx> To subscribe, unsubscribe, or change list options,

visit: https://lists.midrange.com/mailman/listinfo/rpg400-l

or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx<mailto:RPG400-L-request@xxxxxxxxxxxxxxxxxx>

Before posting, please take a moment to review the archives at https://archive.midrange.com/rpg400-l.



Please contact support@xxxxxxxxxxxxxxxxxxxx<mailto:support@xxxxxxxxxxxxxxxxxxxx> for any subscription related questions.









Subject to Change Notice:



WalzCraft reserves the right to improve designs, and to change specifications without notice.



Confidentiality Notice:



This message and any attachments may contain confidential and privileged information that is protected by law. The information contained herein is transmitted for the sole use of the intended recipient(s) and should "only" pertain to "WalzCraft" company matters. If you are not the intended recipient or designated agent of the recipient of such information, you are hereby notified that any use, dissemination, copying or retention of this email or the information contained herein is strictly prohibited and may subject you to penalties under federal and/or state law. If you received this email in error, please notify the sender immediately and permanently delete this email. Thank You



WalzCraft PO Box 1748 La Crosse, WI, 54602-1748 www.walzcraft.com<http://www.walzcraft.com<http://www.walzcraft.com%3chttp:/www.walzcraft.com>> Phone: 1-800-237-1326

--

This is the RPG programming on IBM i (RPG400-L) mailing list To post a message email: RPG400-L@xxxxxxxxxxxxxxxxxx<mailto:RPG400-L@xxxxxxxxxxxxxxxxxx> To subscribe, unsubscribe, or change list options,

visit: https://lists.midrange.com/mailman/listinfo/rpg400-l

or email: RPG400-L-request@xxxxxxxxxxxxxxxxxx<mailto:RPG400-L-request@xxxxxxxxxxxxxxxxxx>

Before posting, please take a moment to review the archives at https://archive.midrange.com/rpg400-l.



Please contact support@xxxxxxxxxxxxxxxxxxxx<mailto:support@xxxxxxxxxxxxxxxxxxxx> for any subscription related questions.





Subject to Change Notice:

WalzCraft reserves the right to improve designs, and to change specifications without notice.

Confidentiality Notice:

This message and any attachments may contain confidential and privileged information that is protected by law. The information contained herein is transmitted for the sole use of the intended recipient(s) and should "only" pertain to "WalzCraft" company matters. If you are not the intended recipient or designated agent of the recipient of such information, you are hereby notified that any use, dissemination, copying or retention of this email or the information contained herein is strictly prohibited and may subject you to penalties under federal and/or state law. If you received this email in error, please notify the sender immediately and permanently delete this email. Thank You

WalzCraft PO Box 1748 La Crosse, WI, 54602-1748
www.walzcraft.com<http://www.walzcraft.com> Phone: 1-800-237-1326

As an Amazon Associate we earn from qualifying purchases.

This thread ...

Follow-Ups:
Replies:

Follow On AppleNews
Return to Archive home page | Return to MIDRANGE.COM home page

This mailing list archive is Copyright 1997-2024 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].

Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.