- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想解码 java Servlet 中的十六进制字符串。
String str = "choKKlate+%2F%2F1%3A%D9%81%DB%8C%D9%81%D8%A7%3E2%3A03008498499%2F%2F";
上述 URL 中的以下字符串包含 URL 编码的 unicode 乌尔都语字符
%D9%81%DB%8C%D9%81%D8%A7
对应于乌尔都语字符串
فیفا
我通过 GET 方法发送 str 字符串变量。在 servlet 中我尝试了 URLDecoder
URLDecoder.decode(str, "UTF-8");
但这会返回问号('??????')而不是乌尔都语字符。
如何解决这个问题?
最佳答案
这里我的理解是%会在URL中发挥一些作用,所以我们不应该在URL中传递这个十六进制字符串。相反,您可以使用 Base64 算法或用户定义的算法来编码和解码字符串
例如,我们创建一个包含代码的 64 基类
package com.encrypt;
import java.util.Arrays;
public class Base64
{
public Base64()
{
}
public static final char[] encodeToChar(byte abyte0[], boolean flag)
{
int i = abyte0 == null ? 0 : abyte0.length;
if(i == 0)
return new char[0];
int j = (i / 3) * 3;
int k = (i - 1) / 3 + 1 << 2;
int l = k + (flag ? (k - 1) / 76 << 1 : 0);
char ac[] = new char[l];
int i1 = 0;
int j1 = 0;
int l1 = 0;
do
{
if(i1 >= j)
break;
int i2 = (abyte0[i1++] & 0xff) << 16 | (abyte0[i1++] & 0xff) << 8 | abyte0[i1++] & 0xff;
ac[j1++] = CA[i2 >>> 18 & 0x3f];
ac[j1++] = CA[i2 >>> 12 & 0x3f];
ac[j1++] = CA[i2 >>> 6 & 0x3f];
ac[j1++] = CA[i2 & 0x3f];
if(flag && ++l1 == 19 && j1 < l - 2)
{
ac[j1++] = '\r';
ac[j1++] = '\n';
l1 = 0;
}
} while(true);
i1 = i - j;
if(i1 > 0)
{
int k1 = (abyte0[j] & 0xff) << 10 | (i1 != 2 ? 0 : (abyte0[i - 1] & 0xff) << 2);
ac[l - 4] = CA[k1 >> 12];
ac[l - 3] = CA[k1 >>> 6 & 0x3f];
ac[l - 2] = i1 != 2 ? '=' : CA[k1 & 0x3f];
ac[l - 1] = '=';
}
return ac;
}
public static final byte[] decode(char ac[])
{
int i = ac == null ? 0 : ac.length;
if(i == 0)
return new byte[0];
int j = 0;
for(int k = 0; k < i; k++)
if(IA[ac[k]] < 0)
j++;
if((i - j) % 4 != 0)
return null;
int l = 0;
int i1 = i;
do
{
if(i1 <= 1 || IA[ac[--i1]] > 0)
break;
if(ac[i1] == '=')
l++;
} while(true);
i1 = ((i - j) * 6 >> 3) - l;
byte abyte0[] = new byte[i1];
int j1 = 0;
int k1 = 0;
do
{
if(k1 >= i1)
break;
int l1 = 0;
for(int i2 = 0; i2 < 4; i2++)
{
int j2 = IA[ac[j1++]];
if(j2 >= 0)
l1 |= j2 << 18 - i2 * 6;
else
i2--;
}
abyte0[k1++] = (byte)(l1 >> 16);
if(k1 < i1)
{
abyte0[k1++] = (byte)(l1 >> 8);
if(k1 < i1)
abyte0[k1++] = (byte)l1;
}
} while(true);
return abyte0;
}
public static final byte[] decodeFast(char ac[])
{
int i = ac.length;
if(i == 0)
return new byte[0];
int j = 0;
int k;
for(k = i - 1; j < k && IA[ac[j]] < 0; j++);
for(; k > 0 && IA[ac[k]] < 0; k--);
byte byte0 = ac[k] != '=' ? 0 : ((byte)(ac[k - 1] != '=' ? 1 : 2));
int l = (k - j) + 1;
int i1 = i <= 76 ? 0 : (ac[76] != '\r' ? 0 : l / 78) << 1;
int j1 = ((l - i1) * 6 >> 3) - byte0;
byte abyte0[] = new byte[j1];
int k1 = 0;
int l1 = 0;
int j2 = (j1 / 3) * 3;
do
{
if(k1 >= j2)
break;
int i3 = IA[ac[j++]] << 18 | IA[ac[j++]] << 12 | IA[ac[j++]] << 6 | IA[ac[j++]];
abyte0[k1++] = (byte)(i3 >> 16);
abyte0[k1++] = (byte)(i3 >> 8);
abyte0[k1++] = (byte)i3;
if(i1 > 0 && ++l1 == 19)
{
j += 2;
l1 = 0;
}
} while(true);
if(k1 < j1)
{
int i2 = 0;
for(int k2 = 0; j <= k - byte0; k2++)
i2 |= IA[ac[j++]] << 18 - k2 * 6;
for(int l2 = 16; k1 < j1; l2 -= 8)
abyte0[k1++] = (byte)(i2 >> l2);
}
return abyte0;
}
public static final byte[] encodeToByte(byte abyte0[], boolean flag)
{
int i = abyte0 == null ? 0 : abyte0.length;
if(i == 0)
return new byte[0];
int j = (i / 3) * 3;
int k = (i - 1) / 3 + 1 << 2;
int l = k + (flag ? (k - 1) / 76 << 1 : 0);
byte abyte1[] = new byte[l];
int i1 = 0;
int j1 = 0;
int l1 = 0;
do
{
if(i1 >= j)
break;
int i2 = (abyte0[i1++] & 0xff) << 16 | (abyte0[i1++] & 0xff) << 8 | abyte0[i1++] & 0xff;
abyte1[j1++] = (byte)CA[i2 >>> 18 & 0x3f];
abyte1[j1++] = (byte)CA[i2 >>> 12 & 0x3f];
abyte1[j1++] = (byte)CA[i2 >>> 6 & 0x3f];
abyte1[j1++] = (byte)CA[i2 & 0x3f];
if(flag && ++l1 == 19 && j1 < l - 2)
{
abyte1[j1++] = 13;
abyte1[j1++] = 10;
l1 = 0;
}
} while(true);
i1 = i - j;
if(i1 > 0)
{
int k1 = (abyte0[j] & 0xff) << 10 | (i1 != 2 ? 0 : (abyte0[i - 1] & 0xff) << 2);
abyte1[l - 4] = (byte)CA[k1 >> 12];
abyte1[l - 3] = (byte)CA[k1 >>> 6 & 0x3f];
abyte1[l - 2] = i1 != 2 ? 61 : (byte)CA[k1 & 0x3f];
abyte1[l - 1] = 61;
}
return abyte1;
}
public static final byte[] decode(byte abyte0[])
{
int i = abyte0.length;
int j = 0;
for(int k = 0; k < i; k++)
if(IA[abyte0[k] & 0xff] < 0)
j++;
if((i - j) % 4 != 0)
return null;
int l = 0;
int i1 = i;
do
{
if(i1 <= 1 || IA[abyte0[--i1] & 0xff] > 0)
break;
if(abyte0[i1] == 61)
l++;
} while(true);
i1 = ((i - j) * 6 >> 3) - l;
byte abyte1[] = new byte[i1];
int j1 = 0;
int k1 = 0;
do
{
if(k1 >= i1)
break;
int l1 = 0;
for(int i2 = 0; i2 < 4; i2++)
{
int j2 = IA[abyte0[j1++] & 0xff];
if(j2 >= 0)
l1 |= j2 << 18 - i2 * 6;
else
i2--;
}
abyte1[k1++] = (byte)(l1 >> 16);
if(k1 < i1)
{
abyte1[k1++] = (byte)(l1 >> 8);
if(k1 < i1)
abyte1[k1++] = (byte)l1;
}
} while(true);
return abyte1;
}
public static final byte[] decodeFast(byte abyte0[])
{
int i = abyte0.length;
if(i == 0)
return new byte[0];
int j = 0;
int k;
for(k = i - 1; j < k && IA[abyte0[j] & 0xff] < 0; j++);
for(; k > 0 && IA[abyte0[k] & 0xff] < 0; k--);
byte byte0 = abyte0[k] != 61 ? 0 : ((byte)(abyte0[k - 1] != 61 ? 1 : 2));
int l = (k - j) + 1;
int i1 = i <= 76 ? 0 : (abyte0[76] != 13 ? 0 : l / 78) << 1;
int j1 = ((l - i1) * 6 >> 3) - byte0;
byte abyte1[] = new byte[j1];
int k1 = 0;
int l1 = 0;
int j2 = (j1 / 3) * 3;
do
{
if(k1 >= j2)
break;
int i3 = IA[abyte0[j++]] << 18 | IA[abyte0[j++]] << 12 | IA[abyte0[j++]] << 6 | IA[abyte0[j++]];
abyte1[k1++] = (byte)(i3 >> 16);
abyte1[k1++] = (byte)(i3 >> 8);
abyte1[k1++] = (byte)i3;
if(i1 > 0 && ++l1 == 19)
{
j += 2;
l1 = 0;
}
} while(true);
if(k1 < j1)
{
int i2 = 0;
for(int k2 = 0; j <= k - byte0; k2++)
i2 |= IA[abyte0[j++]] << 18 - k2 * 6;
for(int l2 = 16; k1 < j1; l2 -= 8)
abyte1[k1++] = (byte)(i2 >> l2);
}
return abyte1;
}
public static final String encodeToString(byte abyte0[], boolean flag)
{
return new String(encodeToChar(abyte0, flag));
}
public static final byte[] decode(String s)
{
int i = s == null ? 0 : s.length();
if(i == 0)
return new byte[0];
int j = 0;
for(int k = 0; k < i; k++)
if(IA[s.charAt(k)] < 0)
j++;
if((i - j) % 4 != 0)
return null;
int l = 0;
int i1 = i;
do
{
if(i1 <= 1 || IA[s.charAt(--i1)] > 0)
break;
if(s.charAt(i1) == '=')
l++;
} while(true);
i1 = ((i - j) * 6 >> 3) - l;
byte abyte0[] = new byte[i1];
int j1 = 0;
int k1 = 0;
do
{
if(k1 >= i1)
break;
int l1 = 0;
for(int i2 = 0; i2 < 4; i2++)
{
int j2 = IA[s.charAt(j1++)];
if(j2 >= 0)
l1 |= j2 << 18 - i2 * 6;
else
i2--;
}
abyte0[k1++] = (byte)(l1 >> 16);
if(k1 < i1)
{
abyte0[k1++] = (byte)(l1 >> 8);
if(k1 < i1)
abyte0[k1++] = (byte)l1;
}
} while(true);
return abyte0;
}
public static final byte[] decodeFast(String s)
{
int i = s.length();
if(i == 0)
return new byte[0];
int j = 0;
int k;
for(k = i - 1; j < k && IA[s.charAt(j) & 0xff] < 0; j++);
for(; k > 0 && IA[s.charAt(k) & 0xff] < 0; k--);
byte byte0 = s.charAt(k) != '=' ? 0 : ((byte)(s.charAt(k - 1) != '=' ? 1 : 2));
int l = (k - j) + 1;
int i1 = i <= 76 ? 0 : (s.charAt(76) != '\r' ? 0 : l / 78) << 1;
int j1 = ((l - i1) * 6 >> 3) - byte0;
byte abyte0[] = new byte[j1];
int k1 = 0;
int l1 = 0;
int j2 = (j1 / 3) * 3;
do
{
if(k1 >= j2)
break;
int i3 = IA[s.charAt(j++)] << 18 | IA[s.charAt(j++)] << 12 | IA[s.charAt(j++)] << 6 | IA[s.charAt(j++)];
abyte0[k1++] = (byte)(i3 >> 16);
abyte0[k1++] = (byte)(i3 >> 8);
abyte0[k1++] = (byte)i3;
if(i1 > 0 && ++l1 == 19)
{
j += 2;
l1 = 0;
}
} while(true);
if(k1 < j1)
{
int i2 = 0;
for(int k2 = 0; j <= k - byte0; k2++)
i2 |= IA[s.charAt(j++)] << 18 - k2 * 6;
for(int l2 = 16; k1 < j1; l2 -= 8)
abyte0[k1++] = (byte)(i2 >> l2);
}
return abyte0;
}
private static final char CA[];
private static final int IA[];
static
{
CA = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".toCharArray();
IA = new int[256];
Arrays.fill(IA, -1);
int i = 0;
for(int j = CA.length; i < j; i++)
IA[CA[i]] = i;
IA[61] = 0;
}
}
现在我们将编写代码来编码和解码字符串
package com.encrypt;
import java.util.*;
public class EnMain {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
long l = (new Date()).getTime();
System.out.println(" timestamp "+l);
String userid ="hello------"+l;
Base64 base = new Base64();
System.out.println(userid.getBytes());
String encryptuserid = base.encodeToString(userid.getBytes(), false);
System.out.println("encrypt values "+encryptuserid);
byte[] b = base.decode("Y29nbm9zLS0tLS0xMzUxNDMzMjk2Mzk3");
StringBuffer sb = new StringBuffer();
for(int i =0;i<b.length;i++){
byte bx = b[i];
System.out.print((char)b[i]);
sb.append((char)b[i]);
//String s = ;
}System.out.println();
System.out.println(sb);
String[] as = sb.toString().split("-----");
long l1 = Long.parseLong(as[1]);
System.out.println("diff :"+(l1-l));
}
}
这里我们将“hello.........”+l作为字符串传递,并使用base64算法对其进行编码,然后检索它。
关于java - 如何转换十六进制字符串?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13487654/
我正在编写一个具有以下签名的 Java 方法。 void Logger(Method method, Object[] args); 如果一个方法(例如 ABC() )调用此方法 Logger,它应该
我是 Java 新手。 我的问题是我的 Java 程序找不到我试图用作的图像文件一个 JButton。 (目前这段代码什么也没做,因为我只是得到了想要的外观第一的)。这是我的主课 代码: packag
好的,今天我在接受采访,我已经编写 Java 代码多年了。采访中说“Java 垃圾收集是一个棘手的问题,我有几个 friend 一直在努力弄清楚。你在这方面做得怎么样?”。她是想骗我吗?还是我的一生都
我的 friend 给了我一个谜语让我解开。它是这样的: There are 100 people. Each one of them, in his turn, does the following
如果我将使用 Java 5 代码的应用程序编译成字节码,生成的 .class 文件是否能够在 Java 1.4 下运行? 如果后者可以工作并且我正在尝试在我的 Java 1.4 应用程序中使用 Jav
有关于why Java doesn't support unsigned types的问题以及一些关于处理无符号类型的问题。我做了一些搜索,似乎 Scala 也不支持无符号数据类型。限制是Java和S
我只是想知道在一个 java 版本中生成的字节码是否可以在其他 java 版本上运行 最佳答案 通常,字节码无需修改即可在 较新 版本的 Java 上运行。它不会在旧版本上运行,除非您使用特殊参数 (
我有一个关于在命令提示符下执行 java 程序的基本问题。 在某些机器上我们需要指定 -cp 。 (类路径)同时执行java程序 (test为java文件名与.class文件存在于同一目录下) jav
我已经阅读 StackOverflow 有一段时间了,现在我才鼓起勇气提出问题。我今年 20 岁,目前在我的家乡(罗马尼亚克卢日-纳波卡)就读 IT 大学。足以介绍:D。 基本上,我有一家提供簿记应用
我有 public JSONObject parseXML(String xml) { JSONObject jsonObject = XML.toJSONObject(xml); r
我已经在 Java 中实现了带有动态类型的简单解释语言。不幸的是我遇到了以下问题。测试时如下代码: def main() { def ks = Map[[1, 2]].keySet()
一直提示输入 1 到 10 的数字 - 结果应将 st、rd、th 和 nd 添加到数字中。编写一个程序,提示用户输入 1 到 10 之间的任意整数,然后以序数形式显示该整数并附加后缀。 public
我有这个 DownloadFile.java 并按预期下载该文件: import java.io.*; import java.net.URL; public class DownloadFile {
我想在 GUI 上添加延迟。我放置了 2 个 for 循环,然后重新绘制了一个标签,但这 2 个 for 循环一个接一个地执行,并且标签被重新绘制到最后一个。 我能做什么? for(int i=0;
我正在对对象 Student 的列表项进行一些测试,但是我更喜欢在 java 类对象中创建硬编码列表,然后从那里提取数据,而不是连接到数据库并在结果集中选择记录。然而,自从我这样做以来已经很长时间了,
我知道对象创建分为三个部分: 声明 实例化 初始化 classA{} classB extends classA{} classA obj = new classB(1,1); 实例化 它必须使用
我有兴趣使用 GPRS 构建车辆跟踪系统。但是,我有一些问题要问以前做过此操作的人: GPRS 是最好的技术吗?人们意识到任何问题吗? 我计划使用 Java/Java EE - 有更好的技术吗? 如果
我可以通过递归方法反转数组,例如:数组={1,2,3,4,5} 数组结果={5,4,3,2,1}但我的结果是相同的数组,我不知道为什么,请帮助我。 public class Recursion { p
有这样的标准方式吗? 包括 Java源代码-测试代码- Ant 或 Maven联合单元持续集成(可能是巡航控制)ClearCase 版本控制工具部署到应用服务器 最后我希望有一个自动构建和集成环境。
我什至不知道这是否可能,我非常怀疑它是否可能,但如果可以,您能告诉我怎么做吗?我只是想知道如何从打印机打印一些文本。 有什么想法吗? 最佳答案 这里有更简单的事情。 import javax.swin
我是一名优秀的程序员,十分优秀!