程序问答   发布时间:2022-06-02  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了android,UTF8-如何确保UTF8用于共享首选项大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

如何解决android,UTF8-如何确保UTF8用于共享首选项?

开发过程中遇到android,UTF8-如何确保UTF8用于共享首选项的问题如何解决?下面主要结合日常开发的经验,给出你关于android,UTF8-如何确保UTF8用于共享首选项的解决方法建议,希望对你解决android,UTF8-如何确保UTF8用于共享首选项有所启发或帮助;

关键是要了解UTF-8和Unicode之间的区别。

  • Java使用Unicode处理内存中的字符和字符串。每个字符存储在两个字节中。
  • 当文本在进程之间传输(例如,到Web服务器) 将文本写入磁盘 从磁盘读取时,内部表示形式将转换为在线格式。这是编码或解码。UTF-8是最受欢迎的,但是其他格式包括:

在您的问题中,您提到XML文件是用utf-8编码的:很好,您将能够在文件中放入外来字符,但这 指定了 该特定XML文件 的编码。

这些XML文件将被编译为AndroID资源,并将包含正确的值(如果您愿意,可以在调试器中对其进行检查,或者通过保留构建链中的中间Java资源文件来对其进行检查)。

问题几乎可以肯定是在http服务器上发送数据和从http服务器接收数据的地方,特别是在网络上的字节与Java之间转换数据的地方String。当前,您尚未在请求中设置它- 可以按照Apache httpClient文档中的说明进行设置。

尽管服务器可能已经/需要这样做,但是在请求中明确声明无疑是一件好事。

您还需要确保服务器(Rails 3中)的一个-如何处理PG错误不完整的多字节字符):

  • 期待UTF-8
  • 使用UTF-8解码器解码请求
  • 使用UTF-8编码对响应进行编码

(对不起,但是我不了解Ruby on Rails,所以我不知道该如何具体地提供帮助)。

回到AndroID端,您还需要确保http库正在使用UTF-8解码器解码响应。如果您自己处理此问题,请确保您使用String构造函数是该构造函数,并且参数为“ utf-8”:

  • 公共字符串(byte []数据,字符串charsetName)

一旦客户端和服务器都使用UTF-8,您的问题将得到解决。

为了帮助在这里调试,我建议:

  1. 服务器 客户端上的许多日志记录语句,它们输出尽可能接近http代码的相关字符串
  2. 与配置为通过调试代理进行对话的客户端一起运行。检查请求和响应,并检查它们是否确实为UTF-8。代理包括:

    • 查尔斯
    • Web疤痕
    • 提琴手

解决方法

如何确保UTF8用于共享首选项菜单?我有一个android偏好设置菜单,除其他外,该菜单允许用户设置其名称。

我需要知道如何将共享首选项中存储的数据转换为UTF8格式

在res / xml文件夹中一个名为setTings的文件中,首选项菜单使用utf8编码以xml布局,如下所示:

<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen
    xmlns:android="http://scheR_72_11845@as.android.com/apk/res/android">
    <EditTextPreference
        android:key="@String/name_key"
        android@R_827_6964@="@String/hof_name_title"
        android:sumMary="@String/hof_name_sumMary"
        android:DefaultValue="Anonymous" />
    <checkBoxPreference
        android:key="@String/new_game_preference_key"
        android@R_827_6964@="@String/new_game_preference_title"
        android:sumMary="@String/new_game_preference_sumMary"
        android:DefaultValue="false" />
</PreferenceScreen>

处理这个的类是

public class PrefsActivity extends PreferenceActivity implements OnSharedPreferenceChangeListener{
    @Override
    protected void onCreate(Bundle savedInstanceStatE) {
        requestWindowFeature(Window.FEATURE_NO_titlE);
        getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN,WindowManager.LayoutParams.FLAG_FULLSCREEN);
        super.onCreate(savedInstanceStatE);
        addPreferencesFromresource(R.xml.setTings);
    }

    @Override
    protected void onPause() {
        super.onPause();
        // Unregister the listener whenever a key changes
        getPreferenceScreen().getSharedPreferences()
                .unregisterOnSharedPreferenceChangeListener(this);
    }

    @Override
    protected void onResume() {
        super.onResume();
        // Set up a listener whenever a key changes
        getPreferenceScreen().getSharedPreferences()
                .registerOnSharedPreferenceChangeListener(this);
    }

    @Override
    public void onSharedPreferenceChanged(SharedPreferences sharedPreferences,String key) {
//      Util.log_debug_message("@@@@ Changed prefrence key = " + key);
        if (key.equalsIgnoreCase(getString(R.String.name_key))){
            update_webserver();
        }else if (key.equalsIgnoreCase(getString(R.String.new_game_preference_key))){
            update_webserver();
        }
    }

    protected void update_webserver(){
        Intent webServerReg = new Intent(this,Regservice.class);
        webServerReg.putExtra(Config.C2DM_REG_ID_EXTRA,C2Dmessaging.getRegistrationId(this));
        startservice(webServerReg);     
    }
}

我假设该设置 <?xml version="1.0" encoding="utf-8"?>将确保文本将以UTF8格式编码,但这并非总是如此。我正在获得各种格式的价值。一些例子

要么

是的,在最后一个示例中,这是一整套的红宝石。

使用以下代码尝试将nmes作为json http POST或PUT请求发送到我的Web服务器时出现的问题

public void update(String regId) throws AuthenticationException {
    JSONObject mu_to_send = createJsonToPost(regId,falsE);
    httpResponse response;
    try {
        response = httprequest.httpPutJSONObject(this,Config.updatE_user_URL,mu_to_send);
        int responseCode = response.getStatusLine().getStatusCode();
        String responseJson;
        try {
            responseJson = EntityUtils.toString(response.getEntity());
            String msg = "";

            if (responseCode == 201) {
                // mobile_user = new
                // JSONObject(responseJson).getJSONObject("mobile_user");
                // Broadcast.sendBroadcast(this,// ResponseReceiver.ACTION_RESP,// Intent.CATEGORY_DEFAULT,Config.C2DM_messaGE_EXTRA,// Config.broaDCAST_WEBSERVER_user_CREATED);
            } else {
                msg = "Failed to register with server! http response code = "
                        + responseCode;
            }
        } catch (ParseException E) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException E) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
    } catch (ClientProtocolException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    } catch (IOException e1) {
        // TODO Auto-generated catch block
        e1.printStackTrace();
    }

}

public JSONObject createJsonToPost(String regId,Boolean set_password) {
    JSONObject holder = new JSONObject();
    JSONObject data = new JSONObject();
    try {
        data.put("auth",regId);
        data.put("name",C2Dmessaging.getName(this));
        data.put("receive_new_game_notification",C2Dmessaging.getGameStartedNotificationPreference(this));
        holder.put("mobile_user",data);
    } catch (JSONException E) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    return holder;
}

public static httpResponse httpPutJSONObject(Context context,String url,JSONObject data) throws ClientProtocolException,IOException,AuthenticationException {
    DefaulthttpClient httpclient = gethttpClient(context);
    httpPut httpput = new httpPut(url);
    httpput.addHeader("User-Agent",Config.user_ageNT);
    httpput.addHeader("Accept","application/json");
    httpput.addHeader("Content-type","application/json");
    httpput.addHeader(new BasicscheR_72_11845@e().authenticate(
            getCredentials(context),httpput));
    StringEntity se = new StringEntity(data.toString());

    httpput.setEntity(sE);
    return httpclient.execute(httpput);
}

这会导致我的Web服务器上出现各种问题,这些问题期望有效的JSON(即UTF8),因为JSON首先应以UTF8编码发送。

所以

1)为什么实际上没有<?xml version="1.0" encoding="utf-8"?>设置UTF8编码?在布局中使用时?

2)如何最好地确保我始终获得发送到Web服务器的有效UTF8格式字符?应该通过放置请求还是保存到共享首选项的代码,或者填充json对象的代码,或者上述各项的组合来处理?或者是其他东西?

@H_262_120@

大佬总结

以上是大佬教程为你收集整理的android,UTF8-如何确保UTF8用于共享首选项全部内容,希望文章能够帮你解决android,UTF8-如何确保UTF8用于共享首选项所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。