Как я могу отправить Emoji с запросом HTTP POST - PullRequest
0 голосов
/ 01 мая 2018

У меня есть приложение, которое отправляет данные на сервер MySQL с запросом http, но на сервере показывают "????" вместо смайликов. Когда я вставляю данные руководства на сервер, проблем с эмодзи нет. (Collation = utf8mb4_general_ci)

Мой код для отправки данных в android:

public static String sendData(String Address, HashMap hashMap)
{
    try
    {
        Object[] keys = hashMap.keySet().toArray();
        Object[] values = hashMap.values().toArray();

        String data = Utils.Encoder(keys[0].toString(), values[0].toString());
        for (int i = 1; i < hashMap.size(); i++)
        {
            data+= "&" + Utils.Encoder(keys[i].toString(), values[i].toString());
        }




        URL url = new URL(Address);

        HttpURLConnection connection = (HttpURLConnection) url.openConnection();


        connection.setRequestMethod("POST");
        connection.setRequestProperty("USER-AGENT", "Mozilla/5.0");
        connection.setRequestProperty("ACCEPT-LANGUAGE", "en-US,en;0.5");
        connection.setDoOutput(true);
        DataOutputStream dStream = new DataOutputStream(connection.getOutputStream());
        dStream.writeBytes(data);
        dStream.flush();
        dStream.close();

        BufferedReader br = new BufferedReader(new InputStreamReader(connection.getInputStream()));
        String line = "";
        StringBuilder responseOutput = new StringBuilder();

        while ((line = br.readLine()) != null)
        {
            responseOutput.append(line);
        }
        br.close();

        return responseOutput.toString();
    }
    catch (Exception e)
    {
        e.printStackTrace();
    }

    return null;
}

public static String getData(String Address)
{
    URL url = null;
    try
    {
        url = new URL(Address);
        HttpURLConnection connection = (HttpURLConnection) url.openConnection();
        connection.setRequestMethod("GET");
        connection.setRequestProperty("USER-AGENT", "Mozilla/5.0");
        connection.setRequestProperty("ACCEPT-LANGUAGE", "en-US,en;0.5");

        InputStream in = connection.getInputStream();
        BufferedReader br = new BufferedReader(new InputStreamReader(in));
        String line = "";
        StringBuilder responseOutput = new StringBuilder();
        while ((line = br.readLine()) != null)
        {
            responseOutput.append(line);
        }
        br.close();
        return responseOutput.toString();
    }
    catch (Exception e)
    {
        e.printStackTrace();
    }

    return "";
}

public static String Encoder(String key, String value)
{

    try
    {
        return URLEncoder.encode(base64Key, "UTF-8") + "=" + URLEncoder.encode(base64Value, "UTF-8");
    }
    catch (UnsupportedEncodingException e)
    {
        e.printStackTrace();
    }

    return "";
}
}

Я думаю, что у моего кодера есть проблема, поэтому я использую метод Base64 вместо UTF-8:

public static String Encoder(String key, String value)
{

    byte[] valueBytes =  value.getBytes();
    byte[] keyBytes =  key.getBytes();
    return Base64.encodeToString(valueBytes,Base64.DEFAULT) + "=" + Base64.encodeToString(keyBytes,Base64.DEFAULT);

    }

Но когда я использую это, ничего не показывает на сервере.

и это мой php-код: (это не весь код)

$conn = new mysqli($servername, $username, $password, $dbname);
$conn->set_charset('utf8mb4');

if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}


if (!$conn->set_charset("utf8")) {
printf("Error loading character set utf8: %s\n", $mysqli->error);
} else {
$conn->character_set_name();
}

$alias=$_POST['Alias'];
$text=$_POST['Text'];

Отредактировано: Я хочу отправить данные с персидским символом

Ответы [ 2 ]

0 голосов
/ 07 июня 2018

В коде php я должен использовать utf8mb4 для кодировки:

if (!$conn->set_charset("utf8mb4")) {
    printf("Error loading character set utf8: %s\n", $mysqli->error);
} else {
    $conn->character_set_name();
}

Все абсолютно правильно

0 голосов
/ 01 мая 2018

Надеюсь, это сработает для вас.

Изменить параметры сортировки соединения с сервером, как показано ниже

Collation = utf8mb4_unicode_ci

Затем отправьте его без кодирования.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...