Définissez le format d'encodage de sauvegarde du fichier. Généralement, lors de la création d'un nouveau projet, le format d'encodage GBK est défini. À ce stade, le format d'encodage de page du fichier est GBK, et le format de sauvegarde est ANSI. Plus tard, après avoir changé le format de codage du projet et des fichiers au format de codage UTF-8, des caractères chinois tronqués sont toujours apparus parce que le format de codage de sauvegarde des fichiers existants est toujours ANSI, donc le format précédent. Le fichier .java doit être enregistré. Changez le format en utf-8 afin qu'il n'y ait aucun problème avec les commentaires chinois tronqués
window-preferences-General-Content Types. Sélectionnez le type de fichier correspondant sous Texte et modifiez le. encodage de la page en UTF-8 et cliquez sur Mettre à jour .
Remarque :
S'il s'agit d'un tout nouvel espace de travail, définir le format d'encodage de Myeclipse équivaut à définir le format d'encodage du projet, du fichier et de l'enregistrement (hors jsp, etc. .Fichier)
S'il s'agit d'un espace de travail existant et que le format d'encodage d'origine est GBK, alors changer l'encodage de l'espace de travail équivaut à définir le format d'encodage du projet et du fichier, mais pour le précédent. L'encodage de sauvegarde des fichiers .java existants ne peut pas être modifié et doit être modifié conformément à (4) ci-dessus. Cependant, l'encodage de sauvegarde des nouveaux fichiers est efficace
Plusieurs endroits pour vérifier les caractères tronqués
1. L'encodage enregistré 2. L'encodage déclaré en jsp (UTF-8 et utf8 sont les mêmes) Remarque :<%@ page language="java" contentType="text/html; charset=UTF-8"pageEncoding="UTF-8"%>3 .L'encodage des caractères traité dans le filtre est limité au codage des données d’entrée et de sortie. Le format d'encodage défini dans le code ci-dessus est le format d'affichage de la page. Dans le code d'un projet javaweb, il existe un total de ces formats : 1. Format d'enregistrement du code 2. Format d'analyse du navigateur 3. Format d'entrée des données (c'est-à-dire déterminé par l'analyse du navigateur format) 4. Le format lors du traitement des données. En principe, les six formats ci-dessus doivent être les mêmes, et il n'y aura certainement pas de caractères tronqués. Cependant, il existe quelques cas particuliers, dont certains sont incohérents, et l'affichage sera correct. Sinon lors de l'affichage et du traitement du contenu d'entrée, le format de la requête et de la réponse peut être incohérent avec d'autres formats ps : les encodages couramment utilisés sont ISO-8859-1, gbk, utf-8
.
La méthode infaillible est donc la suivante :
package com.helloweenvsfei.filter; import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.servlet.ServletRequest; import javax.servlet.ServletResponse; public class CharacterEncodingFilter implements Filter{ private String characterEncoding; private boolean enabled; public void destroy() { // TODO Auto-generated method stub characterEncoding = null; } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // TODO Auto-generated method stub if(enabled || characterEncoding != null){ request.setCharacterEncoding(characterEncoding); response.setCharacterEncoding(characterEncoding); } chain.doFilter(request, response); } public void init(FilterConfig config) throws ServletException { // TODO Auto-generated method stub characterEncoding = config.getInitParameter("characterEncoding"); enabled = "true".equalsIgnoreCase(config.getInitParameter("enabled").trim()); } }web.xml
<filter> <filter-name>characterEncodingFilter</filter-name> <filter-class>com.helloweenvsfei.filter.CharacterEncodingFilter</filter-class> <init-param> <param-name>characterEncoding</param-name> <param-value>utf8</param-value> </init-param> <init-param> <param-name>enabled</param-name> <param-value>true</param-value> </init-param> </filter> <filter-mapping> <filter-name>characterEncodingFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>Pour plus de connaissances sur Java, veuillez faire attention au
Colonne Tutoriel de base Java.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!