asfgit closed pull request #6579: [FLINK-10174][table] fix getbytes in hex and toBase64 URL: https://github.com/apache/flink/pull/6579
This is a PR merged from a forked repository. As GitHub hides the original diff on merge, it is displayed below for the sake of provenance: As this is a foreign pull request (from a fork), the diff is supplied below (as it won't show otherwise due to GitHub magic): diff --git a/flink-libraries/flink-table/src/main/scala/org/apache/flink/table/runtime/functions/ScalarFunctions.scala b/flink-libraries/flink-table/src/main/scala/org/apache/flink/table/runtime/functions/ScalarFunctions.scala index d92af7aaae2..3cf618ee717 100644 --- a/flink-libraries/flink-table/src/main/scala/org/apache/flink/table/runtime/functions/ScalarFunctions.scala +++ b/flink-libraries/flink-table/src/main/scala/org/apache/flink/table/runtime/functions/ScalarFunctions.scala @@ -20,6 +20,7 @@ package org.apache.flink.table.runtime.functions import java.lang.{StringBuilder, Long => JLong} import java.math.{BigDecimal => JBigDecimal} +import org.apache.commons.codec.Charsets import org.apache.commons.codec.binary.{Base64, Hex} import scala.annotation.varargs @@ -206,12 +207,12 @@ object ScalarFunctions { /** * Returns the base string decoded with base64. */ - def fromBase64(str: String): String = new String(Base64.decodeBase64(str)) + def fromBase64(str: String): String = new String(Base64.decodeBase64(str), Charsets.UTF_8) /** * Returns the base64-encoded result of the input string. */ - def toBase64(base: String): String = Base64.encodeBase64String(base.getBytes()) + def toBase64(base: String): String = Base64.encodeBase64String(base.getBytes(Charsets.UTF_8)) /** * Returns the hex string of a long argument. @@ -221,7 +222,7 @@ object ScalarFunctions { /** * Returns the hex string of a string argument. */ - def hex(x: String): String = Hex.encodeHexString(x.getBytes).toUpperCase() + def hex(x: String): String = Hex.encodeHexString(x.getBytes(Charsets.UTF_8)).toUpperCase() /** * Returns an UUID string using Java utilities. diff --git a/flink-libraries/flink-table/src/test/scala/org/apache/flink/table/expressions/ScalarFunctionsTest.scala b/flink-libraries/flink-table/src/test/scala/org/apache/flink/table/expressions/ScalarFunctionsTest.scala index 145f3c5fba3..4a7a4f881a7 100644 --- a/flink-libraries/flink-table/src/test/scala/org/apache/flink/table/expressions/ScalarFunctionsTest.scala +++ b/flink-libraries/flink-table/src/test/scala/org/apache/flink/table/expressions/ScalarFunctionsTest.scala @@ -483,6 +483,13 @@ class ScalarFunctionsTest extends ScalarTypesTestBase { "f24.hex()", "HEX(f24)", "2A5F546869732069732061207465737420537472696E672E") + + testAllApis( + "你好".hex(), + "'你好'.hex()", + "HEX('你好')", + "E4BDA0E5A5BD" + ) } @Test @@ -563,6 +570,13 @@ class ScalarFunctionsTest extends ScalarTypesTestBase { "f33.fromBase64()", "FROM_BASE64(f33)", "null") + + testAllApis( + "5L2g5aW9".fromBase64(), + "'5L2g5aW9'.fromBase64()", + "FROM_BASE64('5L2g5aW9')", + "你好" + ) } @Test @@ -591,6 +605,13 @@ class ScalarFunctionsTest extends ScalarTypesTestBase { "f33.toBase64()", "TO_BASE64(f33)", "null") + + testAllApis( + "你好".toBase64(), + "'你好'.toBase64()", + "TO_BASE64('你好')", + "5L2g5aW9" + ) } @Test ---------------------------------------------------------------- This is an automated message from the Apache Git Service. To respond to the message, please log on GitHub and use the URL above to go to the specific comment. For queries about this service, please contact Infrastructure at: us...@infra.apache.org With regards, Apache Git Services