前提・実現したいこと
ページの文字化けを直したい
こんにちは。助けてください。
Java(Eclipse)でタスク管理のアプリを作成しているのですが
![
上記のように文字化けしてしまいます。
現在はEncodingFilterを作って、UTF8を適用しているはずなのですが、思うように行きません・・
該当のソースコード
app.jsp ソースコード <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8"> <title>タスクリスト</title> </head> <body> <div id="wrapper"> <div id="header"> <h1>タスクリスト アプリケーション</h1> </div> <div id=content> ${param.content} </div> <div id="footer"> by Nyababa. </div> </div> </body> </html>
index.jsp ソースコード <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> <c:import url="../layout/app.jsp"> <c:param name="content"> <h2>タスク一覧</h2> <ul> <c:forEach var="task" items="${tasks}"> <li> <a href="${pageContext.request.contextPath}/show?id=${task.id}"> <c:out value="${task.id}" /> </a> :<c:out value="${task.content}" /> </li> </c:forEach> </ul> <p><a href="${pageContext.request.contextPath}/new">新規タスクの作成</a></p> </c:param> </c:import>
IndexServlet ソースコード package controllers; import java.io.IOException; import java.util.List; import javax.persistence.EntityManager; import javax.servlet.RequestDispatcher; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import models.Task; import utils.DBUtil; /** * Servlet implementation class IndexServlet */ @WebServlet("/index") public class IndexServlet extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#HttpServlet() */ public IndexServlet() { super(); } /** * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) */ protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { EntityManager em = DBUtil.createEntityManager(); List<Task> tasks = em.createNamedQuery("getAllTasks", Task.class).getResultList(); response.getWriter().append(Integer.valueOf(tasks.size()).toString()); em.close(); request.setAttribute("tasks", tasks); RequestDispatcher rd = request.getRequestDispatcher("/WEB-INF/views/tasks/index.jsp"); rd.forward(request, response); } }
<?xml version="1.0" encoding="UTF-8"?> <persistence version="2.1" xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_1.xsd"> <persistence-unit name="tasklist" transaction-type="RESOURCE_LOCAL"> <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider> <class>models.Task</class> <properties> <property name="javax.persistence.jdbc.driver" value="com.mysql.jdbc.Driver"/> <property name="javax.persistence.jdbc.url" value="jdbc:mysql://localhost/tasklist?useSSL=false&useUnicode=true&characterEncoding=utf-8"/> <property name="javax.persistence.schema-generation.database.action" value="create"/> <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/> <property name="hibernate.show_sql" value="true"/> <property name="hibernate.format_sql" value="true"/> <property name="javax.persistence.jdbc.user" value="root"/> <property name="javax.persistence.jdbc.password" value="fucktheworld"/> </properties> </persistence-unit> </persistence>
試したこと
入力ミスなどの確認。事前設定もどこがおかしいのかわかりません。
補足情報(FW/ツールのバージョンなど)
Java8
回答1件
あなたの回答
tips
プレビュー