on 03-24-2015 12:17 PM
Hi Experts,
I've got a SOAP to File Scenario (PI 7.4), I'm getting a XML message encoded as Base64 in a field from the web service, I'm using a UDF in mapping to decode an extract the XML file from the dedicated field, than use content conversion to get only the one field.
note, in the XML file it is declare as ISO-8599-8.
than I send it to file receiver adapter as type=text and encoding=ISO-8599-8.
I've also tried to write file as XML and tried using different encoding (UTF-8,ISO-8599-1, cp1255, windows-1255)
the Hebrew characters are always displayed as junk characters when trying to open the file and also in sxi_moni and RWB.
do I need to address in UDF the relevant encoding ?
what am i missing ?
Zevik,
I think, Sender system is sending incorrect data. Please decode the Base64 here Base64 Decode and Encode - Online
Your UDF works fine
return new String(BASE64Decoder.decode(var1.getBytes()));
Input: VGVzdGluZyBIZWJyZXcgYWxwaGFiZXQgINeQ1rjXnNa216PWvteR1rXWvNeZ16og16LWtNeR1rDXqNa015k=
Output: Testing Hebrew alphabet אָלֶף־בֵּית עִבְרִי
Please note, xml reserved characters will be escaped if they are present in data.
Input:PD94bWwgdmVyc2lvbj0iMS4wIiBlbmNvZGluZz0iaXNvLTg4NTktOCI/PjxLZXRlckludm9pY2U+PEhl
Ouput:<?xml version="1.0" encoding="iso-8859-8"?><KeterInvoice><He (Which is <?xml version="1.0" encoding="iso-8859-8"?><KeterInvoice><He).
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Sorry for the delay, I was away on vacation for a week.
this is the the string:
<?xml version="1.0" encoding="iso-8859-8"?><KeterInvoice><Header><TransactionID></TransactionID><Vendor_DUNS_Number>DE812603958</Vendor_DUNS_Number><Vendor_TaxBook_Number>DE812603958</Vendor_TaxBook_Number><Vendor_Name>סי. אי. פי. אי.</Vendor_Name><Vendor_Number>80522590</Vendor_Number><Invoice_Number>TestOrderLines</Invoice_Number><Matching_Purchase_Order_Number>4501041237</Matching_Purchase_Order_Number><Matching_Purchase_Order_Version></Matching_Purchase_Order_Version><Matching_Shipping_Note_Number>45465</Matching_Shipping_Note_Number><Customer_Shipping_Note_Number>45465</Customer_Shipping_Note_Number><Matching_Proforma_Invoice_Number></Matching_Proforma_Invoice_Number><Matching_Invoice_Draft_Number></Matching_Invoice_Draft_Number><Matching_Credited_Invoice_Number></Matching_Credited_Invoice_Number><Is_Invoice_Based_On_Order>1</Is_Invoice_Based_On_Order><Is_Invoice_Based_On_Proforma>0</Is_Invoice_Based_On_Proforma><Invoice_Year>2015</Invoice_Year><Reference_Invoice_Number></Reference_Invoice_Number><Issue_Date>26/03/2015</Issue_Date><Delivery_Date></Delivery_Date><Customer_Name>Jardin</Customer_Name><Customer_DUNS_Number>NL802659925B01</Customer_DUNS_Number><Customer_Vat></Customer_Vat><Customer_Department></Customer_Department><Customer_Full_Address></Customer_Full_Address><Customer_City_Name></Customer_City_Name><Customer_PO_Box></Customer_PO_Box><Customer_State></Customer_State><Customer_Country></Customer_Country><Customer_Zip_Code></Customer_Zip_Code><Customer_Phone></Customer_Phone><Customer_Fax></Customer_Fax><Contact_Person_Name></Contact_Person_Name><Contact_Phone_Number></Contact_Phone_Number><Contact_email></Contact_email><Total_Sum_Include_Vat_Local_Currency>295250.160</Total_Sum_Include_Vat_Local_Currency><Total_Sum_Before_Vat_Local_Currency>250212</Total_Sum_Before_Vat_Local_Currency><Total_Vat_Local_Currency>45038.16</Total_Vat_Local_Currency><Vat_Percentage>18</Vat_Percentage><Total_Sum_Include_Vat_Foreign_Currency>295250.16</Total_Sum_Include_Vat_Foreign_Currency><Total_Sum_Before_Vat_Foreign_Currency>250212</Total_Sum_Before_Vat_Foreign_Currency><Total_Vat_Foreign_Currency>45038.16</Total_Vat_Foreign_Currency><Total_Discount_Local_Currency>0</Total_Discount_Local_Currency><Total_Discount_Foreign_Currency>0</Total_Discount_Foreign_Currency><Total_Sum_Before_Vat_Local_Currency_Include_Duscount>250212</Total_Sum_Before_Vat_Local_Currency_Include_Duscount><Total_Sum_Before_Vat_Foreign_Currency_Include_Duscount>250212</Total_Sum_Before_Vat_Foreign_Currency_Include_Duscount><Local_Currency>EUR</Local_Currency><Foreign_Currency>EUR</Foreign_Currency><Invoice_Type>INVO</Invoice_Type><Matching_PO_Type></Matching_PO_Type><Payment_Conditions></Payment_Conditions><Exchange_Rate>1</Exchange_Rate><Government_Invoice_Number></Government_Invoice_Number><Remark></Remark></Header><Lines><Row><Invoice_Line_Number>2</Invoice_Line_Number><Matching_Purchase_Order_Number>4501041237</Matching_Purchase_Order_Number><Matching_Purchase_Order_Line_Number>20</Matching_Purchase_Order_Line_Number><Matching_Shipping_Note>45465</Matching_Shipping_Note><Matching_Shipping_Note_Line_Number></Matching_Shipping_Note_Line_Number><Matching_Proforma_Invoice_Number></Matching_Proforma_Invoice_Number><Matching_Proforma_Invoice_Line_Number></Matching_Proforma_Invoice_Line_Number><Supplier_Catalog_Number>555659</Supplier_Catalog_Number><Supplier_Unit_Of_Measure></Supplier_Unit_Of_Measure><Supplier_Quantity>200</Supplier_Quantity><Supplier_Unit_Price_Before_Vat_Local_Currency>1060</Supplier_Unit_Price_Before_Vat_Local_Currency><Supplier_Unit_Price_Before_Vat_Foreign_Currency>1060</Supplier_Unit_Price_Before_Vat_Foreign_Currency><Customer_Catalog_Number></Customer_Catalog_Number><Customer_Catalog_Description>Ds Daytona SL (incl kuss) 700x392x693mm</Customer_Catalog_Description><Customer_Unit_Of_Measure></Customer_Unit_Of_Measure><Customer_Quantity>200</Customer_Quantity><Customer_Unit_Price_Before_Vat_Local_Currency>1060</Customer_Unit_Price_Before_Vat_Local_Currency><Customer_Unit_Price_Before_Vat_Foreign_Currency></Customer_Unit_Price_Before_Vat_Foreign_Currency><Total_Line_Sum_Include_Vat_Local_Currency>250.16</Total_Line_Sum_Include_Vat_Local_Currency><Total_Line_Sum_Before_Vat_Local_Currency>212</Total_Line_Sum_Before_Vat_Local_Currency><Line_Total_Vat_Local_Currency>38.16</Line_Total_Vat_Local_Currency><Total_Line_Sum_Include_Vat_Foreign_Currency>250.16</Total_Line_Sum_Include_Vat_Foreign_Currency><Total_Line_Sum_Before_Vat_Foreign_Currency>212</Total_Line_Sum_Before_Vat_Foreign_Currency><Line_Total_Vat_Foreign_Currency>38.16</Line_Total_Vat_Foreign_Currency><Line_Vat_Percentage>18</Line_Vat_Percentage><Line_Vat_Indication></Line_Vat_Indication><Line_Discount_Local_Currency></Line_Discount_Local_Currency><Line_Discount_Foreign_currency></Line_Discount_Foreign_currency><Line_Invoice_Type></Line_Invoice_Type><Line_Delivery_Date></Line_Delivery_Date><Line_Remark></Line_Remark></Row><Row><Invoice_Line_Number>1</Invoice_Line_Number><Matching_Purchase_Order_Number>4501041237</Matching_Purchase_Order_Number><Matching_Purchase_Order_Line_Number>10</Matching_Purchase_Order_Line_Number><Matching_Shipping_Note>45465</Matching_Shipping_Note><Matching_Shipping_Note_Line_Number></Matching_Shipping_Note_Line_Number><Matching_Proforma_Invoice_Number></Matching_Proforma_Invoice_Number><Matching_Proforma_Invoice_Line_Number></Matching_Proforma_Invoice_Line_Number><Supplier_Catalog_Number>555086</Supplier_Catalog_Number><Supplier_Unit_Of_Measure></Supplier_Unit_Of_Measure><Supplier_Quantity>500</Supplier_Quantity><Supplier_Unit_Price_Before_Vat_Local_Currency>500</Supplier_Unit_Price_Before_Vat_Local_Currency><Supplier_Unit_Price_Before_Vat_Foreign_Currency>500</Supplier_Unit_Price_Before_Vat_Foreign_Currency><Customer_Catalog_Number></Customer_Catalog_Number><Customer_Catalog_Description>DS Daytona Full color incl 700x392x693mm</Customer_Catalog_Description><Customer_Unit_Of_Measure></Customer_Unit_Of_Measure><Customer_Quantity>500</Customer_Quantity><Customer_Unit_Price_Before_Vat_Local_Currency>500</Customer_Unit_Price_Before_Vat_Local_Currency><Customer_Unit_Price_Before_Vat_Foreign_Currency></Customer_Unit_Price_Before_Vat_Foreign_Currency><Total_Line_Sum_Include_Vat_Local_Currency>295000</Total_Line_Sum_Include_Vat_Local_Currency><Total_Line_Sum_Before_Vat_Local_Currency>250000</Total_Line_Sum_Before_Vat_Local_Currency><Line_Total_Vat_Local_Currency>45000</Line_Total_Vat_Local_Currency><Total_Line_Sum_Include_Vat_Foreign_Currency>295000</Total_Line_Sum_Include_Vat_Foreign_Currency><Total_Line_Sum_Before_Vat_Foreign_Currency>250000</Total_Line_Sum_Before_Vat_Foreign_Currency><Line_Total_Vat_Foreign_Currency>45000</Line_Total_Vat_Foreign_Currency><Line_Vat_Percentage>18</Line_Vat_Percentage><Line_Vat_Indication></Line_Vat_Indication><Line_Discount_Local_Currency></Line_Discount_Local_Currency><Line_Discount_Foreign_currency></Line_Discount_Foreign_currency><Line_Invoice_Type></Line_Invoice_Type><Line_Delivery_Date></Line_Delivery_Date><Line_Remark></Line_Remark></Row></Lines></KeterInvoice>
I see that the encoding declaration of the XML inside the base64 string is iso-8859-8, however the encoding of the hebrew characters is obviously UTF-8.
But one thing I noticed as well: The UDF escapes the < an > characters, so your result is no valid XML, but plain text. I think you cannot reach your goal with UDF at all.
As i wrote before, I recommend using a Java mapping. Here in forum are many guys who would assist you for writing a Java mapping for your purpose.
>>> not able to see Hebrew anywhere. maybe it's the import class i used ?
I don't think so. If you really want to validate if the decoded string has any Hebrew char, extend your UDF like this.
String output ="";
try {
output = new String(BASE64Decoder.decode(var1.getBytes()), "UTF-8");
}
catch (Exception e) {
return e.getMessage();
}
Pattern p = Pattern.compile("\\p{InHebrew}");
Matcher m = p.matcher(output);
if (m.find()){
return output;
}
else {
return "not found";
}
Hi experts,
Thank you for all your help, I will think about it and post again if needed.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Hi Experts,
So iv'e tried to change the base64 decoder udf to address the encoding issue with no success.
Hebrew is in Junk characters already in mapping test tab and even in display queue, and also in MONI.
I've checked with supplier of the web service and the Hebrew is OK on there side in the system and there logs.
Any ideas ?
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
I've tried this:
return new String(BASE64Decoder.decode(var1.getBytes()), "ISO-8599-8");
and i get an error while compiling :
Hi Experts,
Thank you all for your answers, You all raised good questions.
1. UDF for decoding Base64 field is working properly.
2. The Hebrew characters in the XML are displayed as junk characters already in MONI after the base64 decoding.
3. I didn't check how it looks in mapping test tab or even in display queue, so ill check that as well.
4. I didn't try to change the encoding using message transformation bean in the receiver file adapter.
5. i read the article (How To… Work with Character Encodings in Process Integration) and it says there that for XML files you need to Use the adapter module 'XmlAnonymizerBean', so ill try that too.
I will try it on Sunday and let you all know.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Hi Zevik,
Once you have extracted the XML via UDF, is it displaying junk even in mapping test tab or even in display queue?
Regards,
Mark
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Zevik,
First target should be properly viewing characters in sxmb_moni.
Is UDF working fine?
Try
byte[] b = new sun.misc.BASE64Decoder().decodeBuffer("input"); OR
byte[] b = javax.xml.blind.DatatypeConverter().decodeBuffer("input");
Once characters are properly displayed in moni. Then, you can write target file in UTF-8 (recomanded) or ISO 8859-8 or cp1255.
You can change prolog of XML after message mapping, using XSLT or Java mapping, but not required. FYI Link1, Link2.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Hi Zevik,
Please find below the UDF and solution provided by to Decode Base64 for a Single field:
==================================================================================================================
If you are using the sap util libraries i.e. aii_utilxi_misc.jar - import this in imported archive - import/mention this in the Archives Used tab in the screenshot below. In the Import Instructions mention - com.sap.aii.utilxi.base64.api.Base64 and create a udf as shown below (add exception handling).
This udf can then be used in your mapping for decoding :
If you want to use apache libraries - Go to the functions tab and add the import -org.apache.commons.codec.binary.Base64.
Create a udf in similar lines - where encoded is the input field value :
byte[] decoded = Base64.decodeBase64(encoded);
String decodedout = String(decoded);
return decodedout;
===============================================================================================================================
Please find the actual thread :
Regards,
Nabendu.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Hi Zevik
Try to change the encoding using message transformation bean in the receiver file adapter.
Transform.Class = com.sap.aii.messaging.adapter.Conversion
Transform.ContentType = text/xml;charset=ISO-8599-8
Thanks,
Indrajit
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
Hi Zevik,
The encodings chosen by you seems to be right. Have you check the java code for conversion in this document http://www.sdn.sap.com/irj/scn/go/portal/prtroot/docs/library/uuid/502991a2-45d9-2910-d99f-8aba5d79f...?
Regards.
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
User | Count |
---|---|
87 | |
23 | |
11 | |
9 | |
8 | |
5 | |
5 | |
5 | |
5 | |
4 |
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.