- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在 Android 中,我有一个文本字符串,我以这种方式读取(其字节):
String b = "7af18klmo02";
byte[] b=udid.getBytes("UTF-8");
此后,我使用公钥以这种方式加密字符串:
c = Cipher.getInstance("RSA/ECB/NoPadding");
c.init(Cipher.ENCRYPT_MODE, pubKeyNew);
encodeFile = c.doFinal(b);
之后,我尝试以这种方式在控制台上打印出“加密结果”:
String criptato = null;
try {
criptato = new String(encodeFile, "UTF8");
} catch (UnsupportedEncodingException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println("ENCRYPTED STRING: "+criptato);
System.out.println("LENGTH: "+criptato.length());
我得到的是:
ENCRYPTED STRING: (unreproducible characters)
LENGTH: 244
输出控制台中有很多不可读的字符。我无意更改它们,并且我认为应该使用一些特定的编码来避免这种情况。
但是当我通过 NFC 使用 NDEF 消息发送加密字符串时,我在 Java 端获得了一个我无法理解的不同“字符串”:
\x12\t\xc7NL\xb9\xee\xb3\xae\xe4\xa5\xe5\x88\x93\xd6\\=S\xff\xa0'\xf1\xd0\x87\x8bF\xb0\x0cT!\xd6\xca0\x8b\xe5\x13\xfd\x85\xc3=Z,u1\x14}d\x0b5\xe7\x0bBY\xe7$\xee\xc0Z\x150;r\xfa\xce\x93\x90\x0b\xdas\xe6o\xe8\x954._\x93\xa4\xc2\x06\xe3\x84\xf5\xdbw\x91\xd4'%\xf71\xf3B\x9eA=f\r\xaeu\xe5m\x1en\xdaw\x12\xad+\xfe\xb2\x91;\xbe\t\x1dTd\xf5m\t2\xafl<v\xf0\x06\x98)2]\xbeV\x86\xa7\xe7\xe6\xc3\x1f*b\x8c&\xd8ho\x18\x8a;\x8f\x8cW\xb6\x88A\xc9`^\xc2>\xfcQ\x07\x86\xb3\x82\x16\x8b\xed?\xae\xb0\x9bT<\x84y4/\xef\xf9j\xf2\xff\x17\x8d\xfddQN\x84\x97\xf2z\x88RJtw\xe2F5\xcd=l`\x89\xeaN\x86a\xde\xa4\xdb\xb1\x15x\xe4\xf0.\x06\x03\x16|\xfee\xbf\x8a\x81_\x86\xbc\x83\xd9 \xbc;\x16V.]\xb4\xf9\t>?{\xcdF\xa8\x82\x08\xe0\\L
LENGTH: 700
我在 Ubuntu 13.04 下运行
这是 ISO 8859-15 编码还是什么?
为什么最终长度是 700 而不是原来的 244?
如何将这些字符转换为 UTF-8,以便解密它们以获得原始字符串?
非常感谢任何帮助。
最佳答案
这是损坏的代码:
criptato = new String(encodeFile, "UTF8");
encodeFile
的内容不是 UTF-8 编码文本。它不是任何编码的文本 - 它是任意二进制数据。当您有任意二进制文件时,不要使用 String
构造函数将 byte[]
转换为 String
数据。
而是将其转换为十六进制或 base64。它们都明确设计用于对 ASCII 文本中的任意二进制数据进行编码,以便稍后可以将其解码为原始二进制数据。
关于java - Android 字符编码与 Java 字符编码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31070753/
我对自定义 CSS 或在将图像作为 Logo 上传到页面时使用编码 block 有疑问。我正在为我的网站使用 squarespace,我需要帮助编码我的 Logo 以使其适合每个页面。一个选项是使用自
如 encoding/json 包文档中所述, Marshal traverses the value v recursively. If an encountered value implement
我必须做一些相当于Java中的iconv -f utf8 -t sjisMS $INPUT_FILE的事情。该命令在 Unix 中 我在java中没有找到任何带有sjisMS的编码。 Java中有Sh
从 PHP 5.3 迁移到 PHP 5.6 后,我遇到了编码问题。我的 MySQL 数据库是 latin1,我的 PHP 文件是 windows-1251。现在一切都显示为“ñëåäíèòå àäðå
我有一个 RScript文件(我们称之为 main.r ),它引用了另一个文件,使用以下代码: source("functions.R") 但是,当我运行 RScript 文件时,它提示以下错误:
我无法设法从 WSDL 创建 RPC/编码风格的代码 - 有谁知道哪个框架可以做到这一点? 带有 adb 和 xmlbeans 映射的 Axis2 无法正常工作(无法处理响应中的肥皂编码)直接使用 X
安装了最新版本的Node.Js()和npm包**(1.2.10)**当我运行 Express 命令来生成项目时,它向我抛出以下错误 buffer.js:240 switch (encoding &
JavaScript中有JSON编码/解码base64编码/解码函数吗? 最佳答案 是的,btoa() 和 atob() 在某些浏览器中可以工作: var enc = btoa("this is so
>>> unicode('восстановление информации', 'utf-16') Traceback (most recent call last): File "", line
我当然熟悉 java.net.URLEncoder 和 java.net.URLDecoder 类。但是,我只需要 HTML 样式的编码。 (我不想将 ' ' 替换为 '+' 等)。我不知道任何只做
有一个非常简单的 SSIS 包: OLE DB Source 通过 View 获取数据(数据库表 nvarchar 或 nchar 中的所有字符串列)。 派生列,用于格式化现有日期并将其添加到数据集(
我正在使用一个在 Node 中进行base64编码的软件,如下所示: const enc = new Buffer('test', 'base64') console.log(enc) 显示: 我正
我试图将带有日语字符的数据插入到 oracle 数据库中。事情是保存在数据库中的是一堆倒置的问号。我该如何解决这个问题 最佳答案 见 http://www.errcode.net/blogs/?p=6
当我在 java 中解压 zip 文件时,我发现文件名中出现了带有重音字符的奇怪行为。 西索: Add File user : L'equipe Technique -- Folder : spec
在网上冲浪我找到了 ExtJS 的 Ext.Gantt 插件,该扩展有一个特殊的编码。任何人都知道如何编码那样或其他复杂的形式。 Encoded Gantt Chart 最佳答案 它似乎被 Dean
我正在用C语言做一个编码任务,我进展顺利,直到读取符号并根据表格分配相应的代码的部分。我必须连接几个代码,直到它们的长度达到 32 位,为此我必须将它们写入一个文件中。这种写入文件的方法给我带来了很多
我有一个外部链接的 javascript 文件。在那个 javascript 里面,我有这个功能: function getMonthNumber(monthName){ monthName = mo
使用mechanize,我检索到一个网页的源页面,其中包含一些非ASCII字符,比如汉字。 代码如下: #using python2.6 from mechanize import Browser b
我有一个包含字母 ø 的文件。当我用这段代码 File.ReadLines(filePath) 读取它时,我得到了一个问号而不是它。 当我像这样添加编码时 File.ReadLines(filePat
如何翻译下面的字符串 H.P. Dembinski, B. K\'{e}gl, I.C. Mari\c{s}, M. Roth, D. Veberi\v{c} 进入 H. P. Dembinski,
我是一名优秀的程序员,十分优秀!