2023年8月1日发(作者:)

java中的url编码与解码 在开始讨论编码解码之前,⾸先来明确⼀下问题。什么是application/x-www-form-urlencoded字符串?答:它是⼀种编码类型。当URL地址⾥包含⾮西欧字符的字符串时,系统会将这些字符转换成application/x-www-form-urlencoded字符串。 表单⾥提交时也是如此,当包含⾮西欧字符的字符串时,系统也会将这些字符转换成application/x-www-form-urlencoded字符串。 然⽽,在向服务器发送⼤量的⽂本、包含⾮ASCII字符的⽂本或⼆进制数据时这种编码⽅式效率很低。这个时候我们就要使⽤另⼀种 编码类型“multipart/form-data”,⽐如在我们在做上传的时候,表单的enctype属性⼀般会设置成“multipart/form-data”。 Browser端

表单的ENCTYPE属性值为multipart/form-data,它告诉我们传输的数据要⽤到传输,由于多媒体传输的都是⼤量的数据,所以规 定上传⽂件必须是post⽅法,的type属性必须是file。

form中的其他enctype请。跑题了我。

我们经常会在浏览器的地址栏⾥看到这样的字符串%E6%96%87%E6%A1%A3 这就是被编码后的字符串,下⾯我们就讨论⼀下java 的url编码与解码问题

代码(String s,String enc);将application/x-www-form-urlencoded字符串转换成普通字符串。(String s,String enc);将普通字符串转换成application/x-www-form-urlencoded字符串代码下⾯转载⼀⽚⽂章 /*

⽹页中的表单使⽤POST⽅法提交时,数据内容的类型是 application/x-www-form-urlencoded,这种类型会:1.字符"a"-"z","A"-"Z","0"-"9",".","-","*",和"_" 都不会被编码;2.将空格转换为加号 (+) ;3.将⾮⽂本内容转换成"%xy"的形式,xy是两位16进制的数值;4.在每个 name=value 对之间放置 & 符号。*/ URLEncoder类包含将字符串转换为application/x-www-form-urlencoded MIME 格式的静态⽅法。 web 设计者⾯临的众多难题之⼀便是怎样处理不同操作系统间的差异性。这些差异性能引起URL⽅⾯的问题:例如,⼀些操作系统允许⽂件名中含有空格符,有些⼜不允许。⼤多数操作系统不会认为⽂件名中含有符号“#”会有什么特殊含义;但是在⼀个URL中,符号“#”表⽰该⽂件名已经结束,后⾯会紧跟⼀个 fragment(部分)标识符。其他的特殊字符,⾮字母数字字符集,它们在URL或另⼀个操作系统上都有其特殊的含义,表述着相似的问题。为了解决这些问题,我们在URL中使⽤的字符就必须是⼀个ASCII字符集的固定字集中的元素,具体如下:1.⼤写字母A-Z2.⼩写字母a-z3.数字 0-94.标点符 - _ . ! ~ * ' (和 ,) 诸如字符: / & ? @ # ; $ + = 和 %也可以被使⽤,但是它们各有其特殊的⽤途,如果⼀个⽂件名包括了这些字符( / & ? @ # ; $ + = %),这些字符和所有其他字符就应该被编码。 编码过程⾮常简单,任何字符只要不是ASCII码数字,字母,或者前⾯提到的标点符,它们都将被转换成字节形式,每个字节都写成这种形式:⼀个“%”后⾯跟着两位16进制的数值。空格是⼀个特殊情况,因为它们太平常了。它除了被编码成“%20”以外,还能编码为⼀个“+”。加号(+)本⾝被编码为%2B。当/ # = & 和?作为名字的⼀部分来使⽤时,⽽不是作为URL部分之间的分隔符来使⽤时,它们都应该被编码。 WARNING这种策略在存在⼤量字符集的异构环境中效果不甚理想。例如:在U.S. Windows 系统中, é 被编码为 %E9. 在 U.S. Mac中被编码为%8E。这种不确定性的存在是现存的URI的⼀个明显的不⾜。所以在将来URI的规范当中应该通过国际资源标识符(IRIs)进⾏改善。 类 URL并不⾃动执⾏编码或解码⼯作。你能⽣成⼀个URL对象,它可以包括⾮法的ASCII和⾮ASCII字符和/或%xx。当⽤⽅法getPath() 和toExternalForm( ) 作为输出⽅法时,这种字符和转移符不会⾃动编码或解码。你应对被⽤来⽣成⼀个URL对象的字符串对象负责,确保所有字符都会被恰当地编码。 幸运的是,java提供了⼀个类URLEncoder把string编码成这种形式。Java1.2增加了⼀个类URLDecoder它能以这种形式解码string。这两个类都不⽤初始化:public class URLDecoder extends Objectpublic class URLEncoder extends Object⼀、URLEncoder 在java1.3和早期版本中,类oder包括⼀个简单的静态⽅法encode( ), 它对string以如下规则进⾏编码: public static String encode(String s) 这个⽅法总是⽤它所在平台的默认编码形式,所以在不同系统上,它就会产⽣不同的结果。结果java1.4中,这个⽅法被另⼀种⽅法取代了。该⽅法要求你⾃⼰指定编码形式:public static String encode(String s, String encoding) throws UnsupportedEncodingException 两种关于编码的⽅法,都把任何⾮字母数字字符转换成%xx(除了空格,下划线(_),连字符(?),句号(。),和星号(*))。两者也都编码所以的⾮ASCII字符。空格被转换成⼀个加号。这些⽅法有⼀点过分累赘了;它们也把“~”,“‘”,“()”转换成%xx,即使它们完全⽤不着这样做。尽管这样,但是这种转换并没被URL规范所禁⽌。所以web浏览器会⾃然地处理这些被过分编码后的URL。 两中关于编码的⽅法都返回⼀个新的被编码后的string,java1.3的⽅法encode( ) 使⽤了平台的默认编码形式,得到%xx。这些编码形式典型的有:在 U.S. Unix 系统上的ISO-8859-1, 在U.S. Windows 系统上的Cp1252,在U.S. Macs上的MacRoman,和其他本地字符集等。因为编码解码过程都是与本地操作平台相关的,所以这些⽅法是令⼈不爽的,不能跨平台的。 这就明确地回答了为什么在java1.4中这种⽅法被抛弃了,转⽽投向了要求以⾃⼰指定编码形式的这种⽅法。尽管如此,如果你执意要使⽤所在平台的默认编码形式,你的程序将会像在java1.3中的程序⼀样,是本地平台相关的。在另⼀种编码的⽅法中,你应该总是⽤UTF-8,⽽不是其他什么。 UTF-8⽐起你选的其他的编码形式来说,它能与新的web浏览器和更多的其他软件相兼容。 例⼦7-8是使⽤( ) 来打印输出各种被编码后的string。它需要在java1.4或更新的版本中编译和运⾏。Example 7-8. x-www-form-urlencoded strings

import oder;import oder;import ortedEncodingException;public class EncoderTest {public static void main(String[] args) {try {n(("This string has spaces","UTF-8"));n(("This*string*has*asterisks","UTF-8"));n(("This%string%has%percent%signs", "UTF-8"));n(("This+string+has+pluses","UTF-8"));n(("This/string/has/slashes","UTF-8"));n(("This"string"has"quote"marks", "UTF-8"));n(("This:string:has:colons","UTF-8"));n(("This~string~has~tildes","UTF-8"));n(("This(string)has(parentheses)", "UTF-8"));n(("s","UTF-8"));n(("This=string=has=equals=signs", "UTF-8"));n(("This&string&has&ersands","UTF-8"));n(("Thiséstringéhasé non-ASCII characters","UTF-8"));// n(("this中华⼈民共和国","UTF-8"));} catch (UnsupportedEncodingException ex) {throw new RuntimeException("Broken VM does not support UTF-8");}}}

2023年8月1日发(作者:)

java中的url编码与解码 在开始讨论编码解码之前,⾸先来明确⼀下问题。什么是application/x-www-form-urlencoded字符串?答:它是⼀种编码类型。当URL地址⾥包含⾮西欧字符的字符串时,系统会将这些字符转换成application/x-www-form-urlencoded字符串。 表单⾥提交时也是如此,当包含⾮西欧字符的字符串时,系统也会将这些字符转换成application/x-www-form-urlencoded字符串。 然⽽,在向服务器发送⼤量的⽂本、包含⾮ASCII字符的⽂本或⼆进制数据时这种编码⽅式效率很低。这个时候我们就要使⽤另⼀种 编码类型“multipart/form-data”,⽐如在我们在做上传的时候,表单的enctype属性⼀般会设置成“multipart/form-data”。 Browser端表单的ENCTYPE属性值为multipart/form-data,它告诉我们传输的数据要⽤到传输,由于多媒体传输的都是⼤量的数据,所以规 定上传⽂件必须是post⽅法,的type属性必须是file。

form中的其他enctype请。跑题了我。

我们经常会在浏览器的地址栏⾥看到这样的字符串%E6%96%87%E6%A1%A3 这就是被编码后的字符串,下⾯我们就讨论⼀下java 的url编码与解码问题

代码(String s,String enc);将application/x-www-form-urlencoded字符串转换成普通字符串。(String s,String enc);将普通字符串转换成application/x-www-form-urlencoded字符串代码下⾯转载⼀⽚⽂章 /*

⽹页中的表单使⽤POST⽅法提交时,数据内容的类型是 application/x-www-form-urlencoded,这种类型会:1.字符"a"-"z","A"-"Z","0"-"9",".","-","*",和"_" 都不会被编码;2.将空格转换为加号 (+) ;3.将⾮⽂本内容转换成"%xy"的形式,xy是两位16进制的数值;4.在每个 name=value 对之间放置 & 符号。*/ URLEncoder类包含将字符串转换为application/x-www-form-urlencoded MIME 格式的静态⽅法。 web 设计者⾯临的众多难题之⼀便是怎样处理不同操作系统间的差异性。这些差异性能引起URL⽅⾯的问题:例如,⼀些操作系统允许⽂件名中含有空格符,有些⼜不允许。⼤多数操作系统不会认为⽂件名中含有符号“#”会有什么特殊含义;但是在⼀个URL中,符号“#”表⽰该⽂件名已经结束,后⾯会紧跟⼀个 fragment(部分)标识符。其他的特殊字符,⾮字母数字字符集,它们在URL或另⼀个操作系统上都有其特殊的含义,表述着相似的问题。为了解决这些问题,我们在URL中使⽤的字符就必须是⼀个ASCII字符集的固定字集中的元素,具体如下:1.⼤写字母A-Z2.⼩写字母a-z3.数字 0-94.标点符 - _ . ! ~ * ' (和 ,) 诸如字符: / & ? @ # ; $ + = 和 %也可以被使⽤,但是它们各有其特殊的⽤途,如果⼀个⽂件名包括了这些字符( / & ? @ # ; $ + = %),这些字符和所有其他字符就应该被编码。 编码过程⾮常简单,任何字符只要不是ASCII码数字,字母,或者前⾯提到的标点符,它们都将被转换成字节形式,每个字节都写成这种形式:⼀个“%”后⾯跟着两位16进制的数值。空格是⼀个特殊情况,因为它们太平常了。它除了被编码成“%20”以外,还能编码为⼀个“+”。加号(+)本⾝被编码为%2B。当/ # = & 和?作为名字的⼀部分来使⽤时,⽽不是作为URL部分之间的分隔符来使⽤时,它们都应该被编码。 WARNING这种策略在存在⼤量字符集的异构环境中效果不甚理想。例如:在U.S. Windows 系统中, é 被编码为 %E9. 在 U.S. Mac中被编码为%8E。这种不确定性的存在是现存的URI的⼀个明显的不⾜。所以在将来URI的规范当中应该通过国际资源标识符(IRIs)进⾏改善。 类 URL并不⾃动执⾏编码或解码⼯作。你能⽣成⼀个URL对象,它可以包括⾮法的ASCII和⾮ASCII字符和/或%xx。当⽤⽅法getPath() 和toExternalForm( ) 作为输出⽅法时,这种字符和转移符不会⾃动编码或解码。你应对被⽤来⽣成⼀个URL对象的字符串对象负责,确保所有字符都会被恰当地编码。 幸运的是,java提供了⼀个类URLEncoder把string编码成这种形式。Java1.2增加了⼀个类URLDecoder它能以这种形式解码string。这两个类都不⽤初始化:public class URLDecoder extends Objectpublic class URLEncoder extends Object⼀、URLEncoder 在java1.3和早期版本中,类oder包括⼀个简单的静态⽅法encode( ), 它对string以如下规则进⾏编码: public static String encode(String s) 这个⽅法总是⽤它所在平台的默认编码形式,所以在不同系统上,它就会产⽣不同的结果。结果java1.4中,这个⽅法被另⼀种⽅法取代了。该⽅法要求你⾃⼰指定编码形式:public static String encode(String s, String encoding) throws UnsupportedEncodingException 两种关于编码的⽅法,都把任何⾮字母数字字符转换成%xx(除了空格,下划线(_),连字符(?),句号(。),和星号(*))。两者也都编码所以的⾮ASCII字符。空格被转换成⼀个加号。这些⽅法有⼀点过分累赘了;它们也把“~”,“‘”,“()”转换成%xx,即使它们完全⽤不着这样做。尽管这样,但是这种转换并没被URL规范所禁⽌。所以web浏览器会⾃然地处理这些被过分编码后的URL。 两中关于编码的⽅法都返回⼀个新的被编码后的string,java1.3的⽅法encode( ) 使⽤了平台的默认编码形式,得到%xx。这些编码形式典型的有:在 U.S. Unix 系统上的ISO-8859-1, 在U.S. Windows 系统上的Cp1252,在U.S. Macs上的MacRoman,和其他本地字符集等。因为编码解码过程都是与本地操作平台相关的,所以这些⽅法是令⼈不爽的,不能跨平台的。 这就明确地回答了为什么在java1.4中这种⽅法被抛弃了,转⽽投向了要求以⾃⼰指定编码形式的这种⽅法。尽管如此,如果你执意要使⽤所在平台的默认编码形式,你的程序将会像在java1.3中的程序⼀样,是本地平台相关的。在另⼀种编码的⽅法中,你应该总是⽤UTF-8,⽽不是其他什么。 UTF-8⽐起你选的其他的编码形式来说,它能与新的web浏览器和更多的其他软件相兼容。 例⼦7-8是使⽤( ) 来打印输出各种被编码后的string。它需要在java1.4或更新的版本中编译和运⾏。Example 7-8. x-www-form-urlencoded strings

import oder;import oder;import ortedEncodingException;public class EncoderTest {public static void main(String[] args) {try {n(("This string has spaces","UTF-8"));n(("This*string*has*asterisks","UTF-8"));n(("This%string%has%percent%signs", "UTF-8"));n(("This+string+has+pluses","UTF-8"));n(("This/string/has/slashes","UTF-8"));n(("This"string"has"quote"marks", "UTF-8"));n(("This:string:has:colons","UTF-8"));n(("This~string~has~tildes","UTF-8"));n(("This(string)has(parentheses)", "UTF-8"));n(("s","UTF-8"));n(("This=string=has=equals=signs", "UTF-8"));n(("This&string&has&ersands","UTF-8"));n(("Thiséstringéhasé non-ASCII characters","UTF-8"));// n(("this中华⼈民共和国","UTF-8"));} catch (UnsupportedEncodingException ex) {throw new RuntimeException("Broken VM does not support UTF-8");}}}