Home Web Front-end JS Tutorial The solution to the problem of garbled Chinese characters in the Post method of JQuery's Ajax_jquery

The solution to the problem of garbled Chinese characters in the Post method of JQuery's Ajax_jquery

May 16, 2016 pm 04:33 PM
ajax jquery post Chinese Garbled characters method Solution

The example in this article describes the solution to the problem of Chinese Post transmission in JQuery, that is, the garbled ajax and jquery.ajax Chinese parameter post transmission garbled processing method. Share it with everyone for your reference. The specific analysis is as follows:

Question 1:

When I was working on a project today, I needed to use Ajax. When I used GET to pass Chinese parameters, I only needed to set the page encoding to GB2312 in the background program so that Chinese could be displayed normally. However, this time due to the large number of form items , it is not suitable to be delivered by GET method, and can only be transmitted by POST method. However, I found that when the encoding is set to GB2312 in the background program, Chinese characters are still displayed as garbled characters. After some research the problem was finally solved.

Solution:

The method to solve this problem is very simple. You only need to use the escape() function when processing parameters in JS, and there is no need to use unescape() to decode. This method is suitable for POST and GET methods. Specific Ajax code I won’t give an example here, but here is the code for using the escape() function to process parameters:

Copy code The code is as follows:
var htmer ="getcode=" escape(getcode) "&Content=" escape(Content);

Usually when we process Ajax, we will directly obtain the parameter value here. In order to make the Chinese parameters not garbled, we only need to use the escape() function to process the parameters.

Question 2:

When the website page is not utf-8 encoded, the Chinese submitted by ajax will become garbled.

The solution is as follows:

Find contentType:application/x-www-form-urlencoded in jquery.js and change it to contentType:application/x-www-form-urlencoded; charset=UTF-8.

Cause: When charset is not specified, jquery uses ISO-8859-1, ISO8859-1, usually called Latin-1. Latin-1 includes additional characters indispensable for writing all Western European languages. jquery's ajax does not consider the issue of internationalization at all, but uses the European character set, so garbled characters appear when transmitting Chinese

I have been using the Prototype framework a long time ago. I have used it under .net-GB2312 or jsp tutorial-utf8, and I have never encountered any character encoding problems. So I downloaded both the Prototype and JQuery codes and opened them to study the reasons.

The difference is that JQuery’s default contentType: application/x-www-form-urlencoded

The Prototype is contentType:application/x-www-form-urlencoded; charset=UTF-8

This is the reason why JQuery is garbled. When the character set is not specified, ISO-8859-1 is used

ISO8859-1, usually called Latin-1. Latin-1 includes additional characters indispensable for writing all Western European languages.

JQuery’s Ajax did not consider the issue of internationalization at all and used the European character set, which caused the problem of garbled characters when transmitting Chinese.

Our UTF-8 can solve this problem.

Ultimately, it means that you need to modify the JQuery code and explicitly declare that the contentType uses the utf-8 character set, which can solve the problem of GB2312 Chinese transmission.

You only need to simply modify the JQuery code and add charset=UTF-8. In this way, there is no need to change web.config or change the encoding on the page, and there is no need to use escapc. (str) is then decoded on the server side. How it is conveyed in English is also conveyed in Chinese.

Here is a simple code to test:

test.html page code:

Copy code The code is as follows:








AjaxTest




AjaxTest.aspx processing page:

Copy code The code is as follows:
<%@ Page Language="C#" ContentType="text/html" ResponseEncoding="gb2312" %>

In addition, since the default Chinese character encoding of Ajax is utf-8, a safer way is to ensure that the unified encoding format of the pages involved is utf-8.

I hope this article will be helpful to everyone’s Ajax programming based on jQuery.

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

R.E.P.O. Energy Crystals Explained and What They Do (Yellow Crystal)
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Best Graphic Settings
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. How to Fix Audio if You Can't Hear Anyone
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: How To Unlock Everything In MyRise
4 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

What is the reason why PS keeps showing loading? What is the reason why PS keeps showing loading? Apr 06, 2025 pm 06:39 PM

PS "Loading" problems are caused by resource access or processing problems: hard disk reading speed is slow or bad: Use CrystalDiskInfo to check the hard disk health and replace the problematic hard disk. Insufficient memory: Upgrade memory to meet PS's needs for high-resolution images and complex layer processing. Graphics card drivers are outdated or corrupted: Update the drivers to optimize communication between the PS and the graphics card. File paths are too long or file names have special characters: use short paths and avoid special characters. PS's own problem: Reinstall or repair the PS installer.

What are the common questions about exporting PDF on PS What are the common questions about exporting PDF on PS Apr 06, 2025 pm 04:51 PM

Frequently Asked Questions and Solutions when Exporting PS as PDF: Font Embedding Problems: Check the "Font" option, select "Embed" or convert the font into a curve (path). Color deviation problem: convert the file into CMYK mode and adjust the color; directly exporting it with RGB requires psychological preparation for preview and color deviation. Resolution and file size issues: Choose resolution according to actual conditions, or use the compression option to optimize file size. Special effects issue: Merge (flatten) layers before exporting, or weigh the pros and cons.

How to select a child element with the first class name item through CSS? How to select a child element with the first class name item through CSS? Apr 05, 2025 pm 11:24 PM

When the number of elements is not fixed, how to select the first child element of the specified class name through CSS. When processing HTML structure, you often encounter different elements...

Unable to log in to mysql as root Unable to log in to mysql as root Apr 08, 2025 pm 04:54 PM

The main reasons why you cannot log in to MySQL as root are permission problems, configuration file errors, password inconsistent, socket file problems, or firewall interception. The solution includes: check whether the bind-address parameter in the configuration file is configured correctly. Check whether the root user permissions have been modified or deleted and reset. Verify that the password is accurate, including case and special characters. Check socket file permission settings and paths. Check that the firewall blocks connections to the MySQL server.

Why does negative margins not take effect in some cases? How to solve this problem? Why does negative margins not take effect in some cases? How to solve this problem? Apr 05, 2025 pm 10:18 PM

Why do negative margins not take effect in some cases? During programming, negative margins in CSS (negative...

How to use locally installed font files on web pages? How to use locally installed font files on web pages? Apr 05, 2025 pm 10:57 PM

How to use locally installed font files on web pages Have you encountered this situation in web page development: you have installed a font on your computer...

How to use export default in Vue How to use export default in Vue Apr 07, 2025 pm 07:21 PM

Export default in Vue reveals: Default export, import the entire module at one time, without specifying a name. Components are converted into modules at compile time, and available modules are packaged through the build tool. It can be combined with named exports and export other content, such as constants or functions. Frequently asked questions include circular dependencies, path errors, and build errors, requiring careful examination of the code and import statements. Best practices include code segmentation, readability, and component reuse.

How to remove the default style in Bootstrap list? How to remove the default style in Bootstrap list? Apr 07, 2025 am 10:18 AM

The default style of the Bootstrap list can be removed with CSS override. Use more specific CSS rules and selectors, follow the "proximity principle" and "weight principle", overriding the Bootstrap default style. To avoid style conflicts, more targeted selectors can be used. If the override is unsuccessful, adjust the weight of the custom CSS. At the same time, pay attention to performance optimization, avoid overuse of !important, and write concise and efficient CSS code.

See all articles