Java中如何对字符串进行utf-8编码
java对字符串进行utf-8编码
我们在调用第三方 API 时,常常会被要求用到路径变量,而路径变量一般都是 utf-8 编码的,因此需要对传入的字符串参数进行 utf-8 编码处理。
本文提供一种使用 URLEncoder 库进行编码的方式。
废话少说,上代码。
// 使用 URLEncoder 库对字符串进行 utf-8 编码 import java.net.URLEncoder; public String encodePathVariable(String pathVariable) { String ret = "default"; try { ret = URLEncoder.encode(pathVariable, "utf-8"); System.out.println(pathVariable + " : " + ret); }catch(Exception e) { System.out.println(e); } return ret; }
java按照字节截取字符串-utf-8
如何按照utf-8的字节截取字符串呢?
utf-8,中文一个汉字是三个字节,一个字母或特殊符号是1个字节。
String类没有提供按字节截取字符串的方法,
StringUtil提供了截取的方法,但是默认是8858-1的,而且不能指定编码格式
但是给了我们思路,我们就将这段代码粘贴出来,将后面的编码格式给改成utf-8的
建个测试方法测试下
还是有些问题,截取3个字节时,正好把中字截取出来了,4个字节时有乱码,5个字节时,还有乱码,6个字节时,打印了两个字节,正好两个中文汉字。也就是说,本身是三个字节的文字,我们只取了它的1个字节,所以识别不出来出现了乱码!
经过反复测试,乱码就是�这种符号,别的符号没测出来,应该也没啥别的符号,我们就将这种符号截取掉就行了。
最后测试的代码
乱码没有了,而且准确率还高,因为字符串的情况挺复杂的,什么都有,文字,标点,特殊符号,穿插其中,字节也不一样,网上看了很多例子,都是他们自己编写的算法啥的,用了之后,错误率挺高的。
/** *string:字符串 offset:从哪个字节开始 len:从哪个字节结束 */ public static String getFromCompressedUnicode(String string,int offset,int len) throws UnsupportedEncodeingException{ byte[] bytes = string.getBytes("utf-8"); int len_to_use = Math.min(len,bytes.length - offset); return new String(bytes,offset,len_to_use,"utf-8").replaceAll("�","") }
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
使用Spring Initializr创建Spring Boot项目没有JDK1.8的解决办法
很久没创建springboot项目,今天使用idea的Spring Initializr 创建 Spring Boot项目时,发现java版本里,无法选择jdk1.8,只有17、21、22,所以本文介绍了使用Spring Initializr创建Spring Boot项目没有JDK1.8的解决办法,需要的朋友可以参考下2024-06-06Java中避免NullPointerException的方法总结
这篇文章主要介绍了Java中避免NullPointerException的方法总结的相关资料,需要的朋友可以参考下2017-07-07java多线程之线程,进程和Synchronized概念初解
这篇文章主要介绍了java多线程之线程,进程和Synchronized概念初解,涉及进程与线程的简单概念,实现多线程的方式,线程安全问题,synchronized修饰符等相关内容,具有一定借鉴价值,需要的朋友可以参考下。2017-11-11
最新评论