- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
当我将数据 [希伯来语字符] 从浏览器传输到 Web 服务时,我遇到了问题。Browser js 端和 java 端没有问题,但是当我在它们之间传输数据时出现问题。
AJAX - setRequestHeader
var hebrewData = 'יאש';
var encodeData = encodeURIComponent( hebrew );
console.log('Encoding Before :', hebrewData, '\nAfter :', encodeData);
var xmlhttp = new XMLHttpRequest();
// Method: POST; Encoding type: application/x-www-form-urlencoded (default):
xmlhttp.open("POST","http://localhost:8088/WebApplication/Service", true);
xmlhttp.setRequestHeader("Content-type","application/x-www-form-urlencoded");
xmlhttp.send("data="+encodeData+"&userid="userid );
保存为 UTF-8 的 Web 服务 Java 文件
String hebrew = "חוּט";
System.out.println("Lan : "+hebrew);
我已经尝试过这些可能的方法;
XMLHttpRequest.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8");
从 java getParameter() 开始使用 ISO-8559-1 而不是 UTF-8改了,Tomcat HTTP Connector
使用 URIEncoding="UTF-8"(或)useBodyEncodingForURI="true"
In servlet « request.setCharacterEncoding("UTF-8");
tomcat server.xml « <Connector port="8010" protocol="AJP/1.3" redirectPort="8443" URIEncoding="UTF-8" />
但我无法获得正确的输出。
最佳答案
我已经尝试了这些可能的方法来将数据从 Java 保存到 DB,Servlet 到 DB,下面将逐步清楚地提到。
➩ As Windows OS uses CP1252 character encoding by default. So, changed code page value to 65001 - Unicode (OR) windows-1255 - ANSI Hebrew
public class My {
public static void main(String args[]) throws java.io.UnsupportedEncodingException {
System.setProperty("file.encoding","UTF-8");
System.out.println("Default Charset = " + java.nio.charset.Charset.defaultCharset());
String పేరు = "Yash";
System.out.println("UNICODE - Identifier[Variable Name] : " + పేరు);
String hebrew = "יאש";
System.out.println("UNICODE - Literal[Variable value] : "+ hebrew );
System.out.println("windows-1255 : " + new String(hebrew.getBytes("UTF-8"), "UTF-8") );
}
}
Compiling Java program Manually which is written using Text Editor Notepad
++
.
即使附加 JAVA_OPTS 也无济于事。当我们编译一个具有 Unicode 字符的 Java 文件时,我们得到这个错误
error: unmappable character for encoding Cp1252
➩ As Windows OS uses CP1252 character encoding by default.
D:\Yash>set JAVA_OPTS=%JAVA_OPTS% -Dfile.encoding=UTF-8 -Dsun.jnu.encoding=UTF-8
D:\Yash>javac -encoding UTF-8 -target 1.7 My.java
« -encoding <encoding> Specify character encoding used by source files.
« -target <release> Generate class files to support lowest specified version[1.7] and above[1.8]
For Example: trywithresource feature of 7 will not work on 6.
D:\Yash>java -Dfile.encoding=UTF-8 My
« -D<name>=<value> set a system property
O/P :- Unable to print UTF-8 characters on console command prompt, So go for Eclipse IDE
Default Charset = UTF-8
UNICODE - Identifier[Variable Name] : Yash
UNICODE - Literal[Variable value] : ×™×ש
windows-1255 : ×™×ש
From Eclipse Editor
在 中支持 Unicode Eclipse
保存Workspace|Class文件编码为UTF-8
Class ➩ Project ► properties ► Run/Debug ➤ settings Eccoding - UTF 8 (OR)
WorkSpace ➜ Preferences ► General ► Workspace ► Text file encoding UTF-16
MySQL DB
« 变化 Collation数据库名称|表到utf8_general_ci
和 Configuration settings file为了支持 Unicode。
MySQL 的其他几种语言接口(interface)都基于 C 客户端库。 mysql-connector-java [ 5.1.34
]
测试查询:
CREATE TABLE IF NOT EXISTS `unicodeinfo` (
`id` int(5) NOT NULL AUTO_INCREMENT,
`UserName` varchar(21) COLLATE utf8_unicode_ci NOT NULL,
`Language` varchar(20) COLLATE utf8_unicode_ci NOT NULL,
`Message` varchar(150) CHARACTER SET utf8 NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci AUTO_INCREMENT=6 ;
样本 Java Example to insert record .
public static void insertAutoIncrement_SQL(String UserName, String Language, String Message) {
String DB_URL = "jdbc:mysql://localhost:3306/test", DB_User = "root", DB_Password = "";
String insertSQL = "INSERT INTO `unicodeinfo`( `UserName`, `Language`, `Message`) VALUES (?,?,?)";
//"INSERT INTO `unicodeinfo`(`id`, `UserName`, `Language`, `Message`) VALUES (?,?,?,?)";
int primkey = 0 ;
try {
Class.forName("com.mysql.jdbc.Driver").newInstance();
Connection conn = DriverManager.getConnection(DB_URL, DB_User, DB_Password);
String columnNames[] = new String[] { "id" };
PreparedStatement pstmt = conn.prepareStatement( insertSQL, columnNames );
pstmt.setString(1, UserName );
pstmt.setString(2, Language );
pstmt.setString(3, Message );
if (pstmt.executeUpdate() > 0) {
// Retrieves any auto-generated keys created as a result of executing this Statement object
java.sql.ResultSet generatedKeys = pstmt.getGeneratedKeys();
if ( generatedKeys.next() ) {
primkey = generatedKeys.getInt(1);
}
}
System.out.println("Record updated with id = "+primkey);
} catch (InstantiationException | IllegalAccessException | ClassNotFoundException | SQLException e) {
e.printStackTrace();
}
}
如果您使用 ConnectionPool DBCP
使用值为 connectionProperties="useUnicode=yes;characterEncoding=utf8;"
的 connectionProperties
部署在 Tomcat server 上的 Java 服务器程序:
为了完全切换到使用 UTF-8,您需要进行以下更改:
<Connector>
上设置 URIEncoding="UTF-8"在 server.xml 中。<Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1"
redirectPort="8443" URIEncoding="UTF-8"/>
filter
默认编码设置为 UTF-8。<filter>
<filter-name>CharacterEncoding</filter-name>
<filter-class>org.apache.catalina.filters.SetCharacterEncodingFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>CharacterEncoding</filter-name>
<url-pattern>/msg/*</url-pattern>
</filter-mapping>
response.setContentType("text/html; charset=UTF-8")
或 response.setCharacterEncoding("UTF-8")
.@WebServlet(urlPatterns = { "/msg/locale", "/locale" }, loadOnStartup = 1 )
public class UnicodeTest extends HttpServlet {
private static final long serialVersionUID = 5081877L;
protected void service(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
//response.setCharacterEncoding("UTF-8");
String unicodeMessage = URLDecoder.decode( request.getParameter("message"), "UTF-8");
// request.getParameter("message"); // "××ש"
//new String(request.getParameter("message").getBytes("ISO-8859-1"), "UTF-8");
System.out.println("Unicode Message :"+ request.getParameter("message") );
try {
System.out.println("windows-1255 : " + new String(unicodeMessage.getBytes("UTF-8"), "UTF-8") );
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
UnicodeChars.insertAutoIncrement_SQL("Yash_777", "Telugu", unicodeMessage);
PrintWriter writer = response.getWriter();
if( unicodeMessage != null & !unicodeMessage.equals("") ) {
writer.append("Received Message : "+ URLEncoder.encode( unicodeMessage, "UTF-8"));
} else {
writer.append("Not Received any Message.");
}
writer.flush();
writer.close();
}
}
使用 Javascript 的 Ajax 请求:
var methodHTTP = 'GET'; // "POST", "GET", "PUT"
var serverURL = 'http://localhost:8080/SteamingServlet/msg/locale';
var queryString = 'יאש'; // 'యశ్వంత్ ' // 'यश'
var enobjects = 'message='+ encodeURIComponent( queryString );
var xmlhttp = new XMLHttpRequest();
if( methodHTTP == 'GET' ) { console.log( "XMLHttpRequest - GET" );
xmlhttp.open(methodHTTP, serverURL+'?'+enobjects, true);
xmlhttp.setRequestHeader("Content-type","application/x-javascript; charset=UTF-8");
xmlhttp.setRequestHeader("Access-Control-Allow-Origin","*");
xmlhttp.send( );
} else { console.log( "XMLHttpRequest - POST" );
xmlhttp.open(methodHTTP, serverURL, true);
xmlhttp.setRequestHeader("Content-type","application/x-javascript; charset=UTF-8");
xmlhttp.setRequestHeader("Access-Control-Allow-Origin","*");
xmlhttp.send( enobjects );
}
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {
console.log("Message :: ", xmlhttp.responseText);
console.log("Decoded Message :: ", decodeURIComponent( xmlhttp.responseText ) );
} else {
console.log("Status Code : ", xmlhttp.status);
}
}
关于javascript - UTF-8:从 Ajax 客户端到 Tomcat 服务器的希伯来字符集,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38308963/
有人有 Comet 应用程序 .net 的任何样本吗? 我需要一个示例如何在服务器中保持客户端的连接? 最佳答案 这里也有一些不错的: http://www.frozenmountain.com/we
我想知道是否有 Yii2 专家可以帮助我了解如何最好地使用 ajax 表单与 Yii ajax 验证相结合。我想我可以在不带您阅读我所有代码的情况下解释这个问题。 我正在处理一个促销代码输入表单,用户
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求提供代码的问题必须表现出对所解决问题的最低限度的了解。包括尝试的解决方案、为什么它们不起作用以及预期结果
f:ajax 和 a4j:ajax 标记之间有什么显着差异吗? 我知道 Richfaces 4 中的 a4j:ajax 基于 native f:ajax JSF2 标记,添加了一些 f:ajax 中未
我已经尝试过这样但无法获取数组列表。它返回“null” var data=[]; data[0] = '1'; data[1] = '2'; $.ajax({
在教程中可以看到 jQuery.ajax 和 $.ajax 喜欢这里 http://www.thekludge.com/form-auto-save-with-jquery-serialize/ jQ
过度使用 AJAX 会影响性能吗?在大型 Web 应用程序的上下文中,您如何处理 AJAX 请求以控制异步请求? 最佳答案 过度使用任何东西都会降低性能;在必要时使用 AJAX 将提高性能,特别是如果
似乎我无法使用 Ext.Ajax.request 进行跨域 ajax 调用。看起来 ScriptTag: True 没有任何效果。 这是我的代码: {
我正在使用 Bottle 微框架(但我怀疑我的问题来自它) 首先,如果我定义了一个从/test_redirect 到/x 的简单重定向,它会起作用。所以 Bottle redirect() 在简单的情
任何人都可以指出各种 AJAX 库的统一比较吗?我已经阅读了大约十几种不同的书,我即将开始一个项目,但我对自己是否已经探索了可能性的空间没有信心。 请注意,我不是在要求“我认为 XXX 很棒”——我正
似乎使用 AJAX 的站点和应用程序正在迅速增长。使用 AJAX 的主要原因之一可能是增强用户体验。我担心的是,仅仅因为项目可以使用 AJAX,并不意味着它应该。 可能是为了 UX,AJAX 向站点/
假设我有一个可以通过 Javascript 自定义的“报告”页面。假设我有可以更改的 start_date、end_date 和类型(“简单”或“完整”)。现在 我希望地址栏始终包含当前(自定义) V
我一直在阅读 Ajax 并且希望从 stackoverflow 社区看到我是否正确理解所有内容。 因此,正常的客户端服务器交互是用户在 url 中拉出 Web 浏览器类型,并将 HTTP 请求发送到服
这可能有点牵强,但让我们假设我们需要它以这种方式工作: 我在服务器的 web 根目录中有一个 index.html 文件。该文件中的 javascript 需要向/secure/ajax.php 发出
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 去年关闭。 Improve this
我希望ajax post成功进入主页。由于某种原因,我一直做错事。知道我应该做什么来解决这个问题吗? window.APP_ROOT_URL = ""; Ajax $.ajax({ url: '#{a
我在 2 个不同的函数中有 2 个 ajax 调用。我想用.click来调用这2个函数。 func1 将数据插入数据库,然后 func2 检索数据,所以我的问题是如何等到 func1 完全完成然后只执
我试图在单击按钮后禁用该按钮。我尝试过: $("#ajaxStart").click(function() { $("#ajaxStart").attr("disabled", true);
我试图在每个 Ajax 请求上显示加载动画/微调器 我的 application.js $(document).on("turbolinks:load", function() { window.
我正在显示使用jQplot监视数据的图形。 为了刷新保存该图的div,我每5秒调用一次ajax调用(请参见下面的JavaScript摘录)。 在服务器上,PHP脚本从数据库中检索数据。 成功后,将在5
我是一名优秀的程序员,十分优秀!