java能不能处理视频的java url编码和解码码

java视频音频的处理_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
评价文档:
java视频音频的处理
上传于||暂无简介
大小:987.16KB
登录百度文库,专享文档复制特权,财富值每天免费拿!
你可能喜欢Posts - 50,
Articles - 19,
Comments - 70
生活工作点点滴滴记录在此,相信好记性不如烂笔头!
11:45 by iBlog, ... 阅读,
&&&&&&在开始讨论编码解码之前,首先来明确一下问题。
什么是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端&form&表单的ENCTYPE属性值为multipart/form-data,它告诉我们传输的数据要用到传输,由于多媒体传输的都是大量的数据,所以规&&& 定上传文件必须是post方法,&input&的type属性必须是file。&
&&&& form中的其他enctype请。跑题了我。
&&& 我们经常会在浏览器的地址栏里看到这样的字符串%E6%96%87%E6%A1%A3
&&&这就是被编码后的字符串,下面我们就讨论一下java 的url编码与解码问题
java.net.URLDecoder.decode(String&s,String&enc);
将application/x-www-form-urlencoded字符串转换成普通字符串。
java.net.URLEncoder.decode(String&s,String&enc);
将普通字符串转换成application/x-www-form-urlencoded字符串
import&java.net.URLD
import&java.net.URLE
public&class&URLDecoderTest&{
&&&&public&static&void&main(String[]&args)&throws&Exception&{
&&&&&&&//将application/x-www-form-urlencoded字符串
&&&&&&&//转换成普通字符串
&&&&&&&//必须强调的是编码方式必须正确,如baidu的是gb2312,而google的是UTF-8
&&&&&&&String&keyWord&=&URLDecoder.decode("%E6%96%87%E6%A1%A3",&"gb2312");
&&&&&&&System.out.println(keyWord);
&&&&&&&//将普通字符串转换成
&&&&&&&//application/x-www-form-urlencoded字符串
&&&&&&&//必须强调的是编码方式必须正确,如baidu的是gb2312,而google的是UTF-8
&&&&&&&String&urlStr&=&URLEncoder.encode("文档",&"gb2312");
&&&&&&&System.out.println(urlStr);
下面转载一片文章
&&&& 网页中的表单使用POST方法提交时,数据内容的类型是 application/x-www-form-urlencoded,这种类型会:
1.字符"a"-"z","A"-"Z","0"-"9",".","-","*",和"_" 都不会被编码;
2.将空格转换为加号 (+) ;
3.将非文本内容转换成"%xy"的形式,xy是;
4.在每个 name=value 对之间放置 & 符号。
&&&URLEncoder类包含将字符串转换为application/x-www-form-urlencoded MIME 格式的静态方法。
&&&&&&&web 设计者面临的众多难题之一便是怎样处理不同操作系统间的差异性。这些差异性能引起URL方面的问题:例如,一些操作系统允许文件名中含有空格符,有些又不允许。大多数操作系统不会认为文件名中含有符号“#”会有什么特殊含义;但是在一个URL中,符号“#”表示该文件名已经结束,后面会紧跟一个 fragment(部分)标识符。其他的特殊字符,非字母数字字符集,它们在URL或另一个操作系统上都有其特殊的含义,表述着相似的问题。为了解决这些问题,我们在URL中使用的字符就必须是一个ASCII字符集的固定字集中的元素,具体如下:
1.大写字母A-Z
2.小写字母a-z
3.数字 0-9
4.标点符 - _ . ! ~ * ' (和 ,)
&&&&&&诸如字符: / & ? @ # ; $ + = 和 %也可以被使用,但是它们各有其特殊的用途,如果一个文件名包括了这些字符( / & ? @ # ; $ + = %),这些字符和所有其他字符就应该被编码。
&&&&&&编码过程非常简单,任何字符只要不是ASCII码数字,字母,或者前面提到的标点符,它们都将被转换成字节形式,每个字节都写成这种形式:一个“%”后面跟着两位16进制的数值。空格是一个特殊情况,因为它们太平常了。它除了被编码成以外,还能编码为一个“+”。加号(+)本身被编码为%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 Object
public class URLEncoder extends Object
一、URLEncoder
&&&&在java1.3和早期版本中,类java.net.URLEncoder包括一个简单的静态方法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是使用URLEncoder.encode( ) 来打印输出各种被编码后的string。它需要在java1.4或更新的版本中编译和运行。
Example 7-8. x-www-form-urlencoded strings
import java.net.URLE
import java.net.URLD
import java.io.UnsupportedEncodingE
public class EncoderTest {
public static void main(String[] args) {
System.out.println(URLEncoder.encode("This string has spaces","UTF-8"));
System.out.println(URLEncoder.encode("This*string*has*asterisks","UTF-8"));
System.out.println(URLEncoder.encode("This%string%has%percent%signs", "UTF-8"));
System.out.println(URLEncoder.encode("This+string+has+pluses","UTF-8"));
System.out.println(URLEncoder.encode("This/string/has/slashes","UTF-8"));
System.out.println(URLEncoder.encode("This\"string\"has\"quote\"marks", "UTF-8"));
System.out.println(URLEncoder.encode("This:string:has:colons","UTF-8"));
System.out.println(URLEncoder.encode("This~string~has~tildes","UTF-8"));
System.out.println(URLEncoder.encode("This(string)has(parentheses)", "UTF-8"));
System.out.println(URLEncoder.encode("This.string.has.periods","UTF-8"));
System.out.println(URLEncoder.encode("This=string=has=equals=signs", "UTF-8"));
System.out.println(URLEncoder.encode("This&string&has&ersands","UTF-8"));
System.out.println(URLEncoder.encode("Thiséstringéhasé non-ASCII characters","UTF-8"));
// System.out.println(URLEncoder.encode("this中华人民共和国","UTF-8"));
} catch (UnsupportedEncodingException ex) {throw new RuntimeException("Broken VM does not support UTF-8");
下面就是它的输出。需要注意的是这些代码应该以其他编码形式被保存而不是以ASCII码的形式,还有就是你选择的编码形式应该作为一个参数传给编译器,让编译器能据此对源代码中的非ASCII字符作出正确的解释。
% javac -encoding UTF8 EncoderTest&%
java EncoderTest
This+string+has+spaces
This*string*has*asterisks
This%25string%25has%25percent%25signs
This%2Bstring%2Bhas%2Bpluses
This%2Fstring%2Fhas%2Fslashes
This%22string%22has%22quote%22marks
This%3Astring%3Ahas%3Acolons
This%7Estring%7Ehas%7Etildes
This%28string%29has%28parentheses%29
This.string.has.periods
This%3Dstring%3Dhas%3Dequals%3Dsigns
This%26string%26has%26ampersands
This%C3%A9string%C3%A9has%C3%A9non-ASCII+characters
特别需要注意的是这个方法编码了符号,“\” ,&,=,和:。它不会尝试着去规定在一个URL中这些字符怎样被使用。由此,所以你不得不分块编码你的URL,而不是把整个URL一次传给这个方法。这是很重要的,因为对类URLEncoder最通常的用法就是查询string,为了和服务器端使用GET方法的程序进行交互。例如,假设你想编码这个查询sting,它用来搜索AltaVista网站:
pg=q&kl=XX&stype=stext&q=+"Java+I/O"&search.x=38&search.y=3
这段代码对其进行编码:
String query = URLEncoder.encode( "pg=q&kl=XX&stype=stext&q=+\"Java+I/O\"&search.x=38&search.y=3");System.out.println(query);
不幸的是,得到的输出是:
pg%3Dq%26kl%3DXX%26stype%3Dstext%26q%3D%2B%22Java%2BI%2FO%22%26search.x%3D38%26search.y%3D3
出现这个问题就是方法URLEncoder.encode( ) 在进行盲目地编码。它不能区分在URL或者查询string中被用到的特殊字符(象前面string中的“=”,和“&”)和确实需要被编码的字符。由此,所以URL需要像下面这样一次只编码一块:
String query = URLEncoder.encode("pg");
query += "=";
query += URLEncoder.encode("q");
query += "&";
query += URLEncoder.encode("kl");
query += "=";
query += URLEncoder.encode("XX");
query += "&";
query += URLEncoder.encode("stype");
query += "=";
query += URLEncoder.encode("stext");
query += "&";
query += URLEncoder.encode("q");
query += "=";
query += URLEncoder.encode("\"Java I/O\"");
query += "&";
query += URLEncoder.encode("search.x");
query += "=";
query += URLEncoder.encode("38");
query += "&";
query += URLEncoder.encode("search.y");
query += "=";
query += URLEncoder.encode("3");
System.out.println(query);
这才是你真正想得到的输出:
pg=q&kl=XX&stype=stext&q=%2B%22Java+I%2FO%22&search.x=38&search.y=3
例子7-9是一个QueryString类。在一个java对象中,它使用了类URLEncoder来编码连续的属性名和属性值对,这个java对象被用来发送数据到服务器端的程序。
当你在创建一个QueryString对象时,你可以把查询string中的第一个属性对传递给类QueryString的构造函数,得到初始 string。如果要继续加入后面的属性对,就应调用方法add(),它也能接受两个string作为参数,能对它们进行编码。方法getQuery( )返回一个属性对被逐个编码后得到的整个string。
Example 7-9. -The QueryString class
package com.macfaq.
import java.net.URLE
import java.io.UnsupportedEncodingE
public class QueryString {
&&private StringBuffer query = new StringBuffer();
public QueryString(String name, String value) {&
&&encode(name, value);
public synchronized void add(String name, String value) {
&&query.append('&');
&&encode(name, value);
private synchronized void encode(String name, String value) {
&&&&query.append(URLEncoder.encode(name, "UTF-8"));
&&&&query.append('=');
&&&&query.append(URLEncoder.encode(value, "UTF-8"));
} catch (UnsupportedEncodingException ex) {
&&&&&throw new RuntimeException("Broken VM does not support UTF-8");
public String getQuery() {
&&return query.toString();
public String toString() {
&&return getQuery();
利用这个类,现在我们就能对前面那个例子中的string进行编码了:
QueryString qs = new QueryString("pg", "q");
qs.add("kl", "XX");
qs.add("stype", "stext");
qs.add("q", "+\"Java I/O\"");
qs.add("search.x", "38");
qs.add("search.y", "3");
String url = " +
System.out.println(url);
二、URLDecoder
&&&&与URLEncoder 类相对应的URLDecoder 类有两种静态方法。它们解码以x-www-form-url-encoded这种形式编码的string。也就是说,它们把所有的加号(+)转换成空格符,把所有的%xx分别转换成与之相对应的字符:
public static String decode(String s) throws Exception
public static String decode(String s, String encoding) // Java 1.4 throws UnsupportedEncodingException
第一种解码方法在java1.3和java1.2中使用。第二种解码方法在java1.4和更新的版本中使用。如果你拿不定主意用哪种编码方式,那就选择UTF-8吧。它比其他任何的编码形式更有可能得到正确的结果。
如果string包含了一个“%”,但紧跟其后的不是两位16进制的数或者被解码成非法序列,该方法就会抛出 IllegalArgumentException 异常。当下次再出现这种情况时,它可能就不会被抛出了。这是与运行环境相关的,当检查到有非法序列时,抛不抛出 IllegalArgumentException 异常,这时到底会发生什么是不确定的。在Sun's JDK 1.4中,不会抛出什么异常,它会把一些莫名其妙的字节加进不能被顺利编码的string中。这的确令人头疼,可能就是一个安全漏洞。
由于这个方法没有触及到非转义字符,所以你可以把整个URL作为参数传给该方法,不用像之前那样分块进行。例如:
String input = " + "query?pg=q&kl=XX&stype=stext&q=%2B%22Java+I%2FO%22&search.x=38&search.y=3";
&&String output = URLDecoder.decode(input, "UTF-8");
&&System.out.println(output);34556人阅读
encoding(12)
因为在做链接来源统计的时候需要把 & 这类的URL编码还原成明文字串,一般大部分的网站都是用普通的URL编码形式,如上面链接中的badu,这种很容易转换和还原,Java包里提供了两个类的不同方法URLEncode.encode()和URLDecode.decode()可以很方便实现,但也有特别一点的就是Google了,= 他们的编码和别人不一样,如果使用URLDecode.decode()的话则变成乱码,查询的一些相关资料都说Google使用的是UTF-8编码,这点我就有些奇怪了,如果Google使用的是UTF-8编码,那别人使用的又是什么?IE的高级选项里不是有项&始终以UTF-8形式发送URL&的吗?但是UTF-8一个中文是3byte,而一般的编码则是2个byte,这就是为什么一般的URL中是以两组&%&代码表示一个汉字,如&中&的URL编码为"%D6%D0",而UTF-8则为3组,&中&为"%E4%B8%AD",这个问题我在Google里也没得到较好回答。我对各种编码形式了解的不是很好,之前只看过如何将字符串转成Utf8-URL编码的方法,其实也挺简单的,直接转成byte后直接取其16进制值前面加个%就行,还原方法在网上搜了几圈居然没发现有现成的!倒是也是几个人在CSDN问了此类的问题。最后还是决定自己搞定了,基本上是toUTF8的原路退回法,再加了个检测URL链接是否UTF-8形式的方法,觉得已经蛮好用了。可以拿出来share一下。
import java.io.UnsupportedEncodingE&&&&&&&&&&& import java.net.URLE&&&&&&&&&&& import java.net.URLD&&&&&&&&&&& /**&&&&&&&&&&& * &p&Title:字符编码工具类 &/p&&&&&&&&&&&& * &p&Description:& &/p&&&&&&&&&&&& * &p&Copyright: .cn Copyright (c) 2005&/p&&&&&&&&&&&& * &p&Company: .cn &/p&&&&&&&&&&&& * @author: jeffzhu&&&&&&&&&&& * @version 1.0&&&&&&&&&&& */&&&&&&&&&&& public class CharTools {&&&&&&&&&&& /**&&&&&&&&&&& * 转换编码 ISO-8859-1到GB2312&&&&&&&&&&& * @param text&&&&&&&&&&& * @return&&&&&&&&&&& */&&&&&&&&&&& public String ISO2GB(String text) {&&&&&&&&&&& String result = "";&&&&&&&&&&& try {&&&&&&&&&&& result = new String(text.getBytes("ISO-8859-1"), "GB2312");&&&&&&&&&&& }&&&&&&&&&&& catch (UnsupportedEncodingException ex) {&&&&&&&&&&& result = ex.toString();&&&&&&&&&&& }&&&&&&&&&&&&&&&&&&&&&& }&&&&&&&&&&& /**&&&&&&&&&&& * 转换编码 GB2312到ISO-8859-1&&&&&&&&&&& * @param text&&&&&&&&&&& * @return&&&&&&&&&&& */&&&&&&&&&&& public String GB2ISO(String text) {&&&&&&&&&&& String result = "";&&&&&&&&&&& try {&&&&&&&&&&& result = new String(text.getBytes("GB2312"), "ISO-8859-1");&&&&&&&&&&& }&&&&&&&&&&& catch (UnsupportedEncodingException ex) {&&&&&&&&&&& ex.printStackTrace();&&&&&&&&&&& }&&&&&&&&&&&&&&&&&&&&&& }&&&&&&&&&&& /**&&&&&&&&&&& * Utf8URL编码&&&&&&&&&&& * @param s&&&&&&&&&&& * @return&&&&&&&&&&& */&&&&&&&&&&& public String Utf8URLencode(String text) {&&&&&&&&&&& StringBuffer result = new StringBuffer();&&&&&&&&&&& for (int i = 0; i & text.length(); i++) {&&&&&&&&&&& char c = text.charAt(i);&&&&&&&&&&& if (c &= 0 && c &= 255) {&&&&&&&&&&& result.append(c);&&&&&&&&&&& }else {&&&&&&&&&&& byte[] b = new byte[0];&&&&&&&&&&& try {&&&&&&&&&&& b = Character.toString(c).getBytes("UTF-8");&&&&&&&&&&& }catch (Exception ex) {&&&&&&&&&&& }&&&&&&&&&&& for (int j = 0; j & b. j++) {&&&&&&&&&&& int k = b[j];&&&&&&&&&&& if (k & 0) k += 256;&&&&&&&&&&& result.append("%" + Integer.toHexString(k).toUpperCase());&&&&&&&&&&& }&&&&&&&&&&& }&&&&&&&&&&& }&&&&&&&&&&& return result.toString();&&&&&&&&&&& }&&&&&&&&&&& /**&&&&&&&&&&& * Utf8URL解码&&&&&&&&&&& * @param text&&&&&&&&&&& * @return&&&&&&&&&&& */&&&&&&&&&&& public String Utf8URLdecode(String text) {&&&&&&&&&&& String result = "";&&&&&&&&&&& int p = 0;&&&&&&&&&&& if (text!=null && text.length()&0){&&&&&&&&&&& text = text.toLowerCase();&&&&&&&&&&& p = text.indexOf("%e");&&&&&&&&&&& if (p == -1)&&&&&&&&&&& while (p != -1) {&&&&&&&&&&& result += text.substring(0, p);&&&&&&&&&&& text = text.substring(p, text.length());&&&&&&&&&&& if (text == "" || text.length() & 9)&&&&&&&&&&& result += CodeToWord(text.substring(0, 9));&&&&&&&&&&& text = text.substring(9, text.length());&&&&&&&&&&& p = text.indexOf("%e");&&&&&&&&&&& }&&&&&&&&&&& }&&&&&&&&&&& return result +&&&&&&&&&&& }&&&&&&&&&&& /**&&&&&&&&&&& * utf8URL编码转字符&&&&&&&&&&& * @param text&&&&&&&&&&& * @return&&&&&&&&&&& */&&&&&&&&&&& private String CodeToWord(String text) {&&&&&&&&&&& S&&&&&&&&&&& if (Utf8codeCheck(text)) {&&&&&&&&&&& byte[] code = new byte[3];&&&&&&&&&&& code[0] = (byte) (Integer.parseInt(text.substring(1, 3), 16) - 256);&&&&&&&&&&& code[1] = (byte) (Integer.parseInt(text.substring(4, 6), 16) - 256);&&&&&&&&&&& code[2] = (byte) (Integer.parseInt(text.substring(7, 9), 16) - 256);&&&&&&&&&&& try {&&&&&&&&&&& result = new String(code, "UTF-8");&&&&&&&&&&& }catch (UnsupportedEncodingException ex) {&&&&&&&&&&& result =&&&&&&&&&&& }&&&&&&&&&&& }&&&&&&&&&&& else {&&&&&&&&&&& result =&&&&&&&&&&& }&&&&&&&&&&&&&&&&&&&&&& }&&&&&&&&&&& /**&&&&&&&&&&& * 编码是否有效&&&&&&&&&&& * @param text&&&&&&&&&&& * @return&&&&&&&&&&& */&&&&&&&&&&& private boolean Utf8codeCheck(String text){&&&&&&&&&&& String sign = "";&&&&&&&&&&& if (text.startsWith("%e"))&&&&&&&&&&& for (int i = 0, p = 0; p != -1; i++) {&&&&&&&&&&& p = text.indexOf("%", p);&&&&&&&&&&& if (p != -1)&&&&&&&&&&& p++;&&&&&&&&&&& sign +=&&&&&&&&&&& }&&&&&&&&&&& return sign.equals("147-1");&&&&&&&&&&& }&&&&&&&&&&& /**&&&&&&&&&&& * 是否Utf8Url编码&&&&&&&&&&& * @param text&&&&&&&&&&& * @return&&&&&&&&&&& */&&&&&&&&&&& public boolean isUtf8Url(String text) {&&&&&&&&&&& text = text.toLowerCase();&&&&&&&&&&& int p = text.indexOf("%");&&&&&&&&&&& if (p != -1 && text.length() - p & 9) {&&&&&&&&&&& text = text.substring(p, p + 9);&&&&&&&&&&& }&&&&&&&&&&& return Utf8codeCheck(text);&&&&&&&&&&& }&&&&&&&&&&& /**&&&&&&&&&&& * 测试&&&&&&&&&&& * @param args&&&&&&&&&&& */&&&&&&&&&&& public static void main(String[] args) {&&&&&&&&&&& CharTools charTools = new CharTools();&&&&&&&&&&& S&&&&&&&&&&& url = "=";&&&&&&&&&&& if(charTools.isUtf8Url(url)){&&&&&&&&&&& System.out.println(charTools.Utf8URLdecode(url));&&&&&&&&&&& }else{&&&&&&&&&&& System.out.println(URLDecoder.decode(url));&&&&&&&&&&& }&&&&&&&&&&& url = "";&&&&&&&&&&& if(charTools.isUtf8Url(url)){&&&&&&&&&&& System.out.println(charTools.Utf8URLdecode(url));&&&&&&&&&&& }else{&&&&&&&&&&& System.out.println(URLDecoder.decode(url));&&&&&&&&&&& }&&&&&&&&&&& }&&&&&&&&&&& }&&&&&&&&&&& &&&&&&&&&&&&
0:06:06 By flashman]
[ from ]By [flashman] at 20:55:06 | Comments [1] | TrackBack[0] | 701 views &&& 网友评论 &&&& waterflier 在
10:04:39 说:最近我也在研究中文分词,到你的blog来找点资料 ^_^ 有什么好东西记得给兄弟分享一份。正式的正式:这编文章的理论基础有错误,建议fox去看看编码相关的基础知识。ISO-8859-1 和GB2312是不能直接转的。他们都属于ANSI编码。一共有三类编码ANSI(ISO-8859-1,GBK,GB2312,BIG5等) UCS(UCS2,UCS4) UTF(UTF7 UTF8 UTF16)其中 所有的编码都可以转成UCS,UTF是UCS为了节省空间的一种存储方式(使用huffman编码的理论的变长编码,如果全部都是e文的话可以有效地压缩成UTF8,如果是中文编码成UTF8反而会浪费空间)。ANSI各个编码之间不存在抓换关系只存在极少数的对应关系(比如每个ANSI编码都必须包含英文,又比如简体字与繁体字之间的对应关系使GBK和BIG5之间的某些编码存在对应关系,这种关系是无规律的)。我的blog上也有不少关于这方面的内容
&----------------------------------------------------------------------------------------------------------------------------&&html&&head&&meta http-equiv=&Content-Type& content=&text/ charset=gb2312&&&title&URL解码(Decode)/编码(Encode)&/title&&/head&&body&&center&&font color=green size=+2&URL解码(Decode)/编码(Encode)&/font&&br&需要解码的字符串:&TEXTAREA ID="String1" ROWS="10" COLS="30"&&/TEXTAREA& 解码后的字符串:&TEXTAREA ID="String2" ROWS="10" COLS="30"&&/TEXTAREA&&br&需要编码的字符串:&TEXTAREA ID="String3" ROWS="10" COLS="30"&&/TEXTAREA& 编码后的字符串:&TEXTAREA ID="String4" ROWS="10" COLS="30"&&/TEXTAREA&&br&&INPUT TYPE="button" ID="Decode" value="解码(Decode)" onClick="javascript:String2.value=decodeURI(String1.value);"&&INPUT TYPE="button" ID="Encode" value="编码(Encode)" onClick="javascript:String4.value=encodeURI(String3.value);"&&/center&&/body&&/html&
参考知识库
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
访问:1572917次
积分:14894
积分:14894
排名:第596名
原创:29篇
转载:818篇
评论:137条
(1)(3)(9)(4)(1)(2)(1)(2)(1)(4)(1)(10)(4)(8)(16)(6)(7)(13)(23)(10)(11)(7)(17)(14)(11)(32)(30)(20)(17)(28)(22)(59)(19)(17)(7)(8)(12)(11)(9)(30)(16)(18)(14)(68)(64)(31)(23)(50)(26)(27)(2)

我要回帖

更多关于 java base64编码解码 的文章

 

随机推荐