連投で申し訳ありません。
下記のようなコードでデータをインサートしていますが、
データベースのテーブルの中身の日本語が文字化けしてしまいます。
(セレクト文でブラウザにつしても文字化けしています。)
開発環境
OS windows10
エディション enterprise
言語 java8.0.1310.11
MariaDB10.1
HeidiSQL
eclipse NEON
java
1package test; 2 3import java.io.IOException; 4import java.io.PrintWriter; 5import java.sql.Connection; 6import java.sql.PreparedStatement; 7 8import javax.naming.InitialContext; 9import javax.servlet.ServletException; 10import javax.servlet.annotation.WebServlet; 11import javax.servlet.http.HttpServlet; 12import javax.servlet.http.HttpServletRequest; 13import javax.servlet.http.HttpServletResponse; 14import javax.sql.DataSource; 15 16import tool.Page; 17/** 18 * Servlet implementation class Insert 19 */ 20@WebServlet("/Insert") 21public class Insert extends HttpServlet { 22 private static final long serialVersionUID = 1L; 23 24 /** 25 * @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) 26 */ 27 protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { 28 // TODO Auto-generated method stub 29 response.setCharacterEncoding("UTF-8");// 30 PrintWriter out = response.getWriter(); 31 Page.header(out); 32 out.println("<meta charset = \"UTF-8\">");//HTML 33 try{ 34 InitialContext ic = new InitialContext(); 35 DataSource ds = (DataSource)ic.lookup("java:comp/env/jdbc/localDB"); 36 Connection con = ds.getConnection(); 37 38 response.setCharacterEncoding("UTF-8");// 39 String name = request.getParameter("name"); 40 int price = Integer.parseInt(request.getParameter("price")); 41 42 43 PreparedStatement st = con.prepareStatement("insert into product(id,name,price) values(null,?,?)"); 44 con.setAutoCommit(true); 45 46 47 st.setString(1, name); 48 st.setInt(2,price); 49 int line = st.executeUpdate(); 50 51 if(line > 0){ 52 out.println("追加に成功しました。"); 53 } 54 st.close(); 55 con.close(); 56 }catch(Exception e){ 57 e.printStackTrace(out); 58 } 59 Page.footer(out); 60 } 61} 62
今の文字データの設定
そこで調べていたら下記のような記事を見つけました。
しかしcp932への変更の仕方がわかりません。
show variables like "chara%";で表示させて直接変更しようとしたらエラーが出てしまいました。
当方MariaDBをGUIのみで操作しているのですがどこをいじれば変更できますでしょうか?
どなたかご回答よろしくお願いいたします。
追記
下記のソースで結果をブラウザ(google chrome)で表示しても文字化けしてしまいます。
package test; //import tool.Page; import java.io.IOException; import java.io.PrintWriter; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import javax.naming.InitialContext; 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 javax.sql.DataSource; /** * Servlet implementation class All */ @WebServlet("/All") public class All extends HttpServlet { private static final long serialVersionUID = 1L; /** * @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) */ protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // TODO Auto-generated method stub //response.getWriter().append("Served at: ").append(request.getContextPath()); response.setCharacterEncoding("UTF-8"); PrintWriter out = response.getWriter(); //Page.header(out); try{ InitialContext ic = new InitialContext(); DataSource ds =(DataSource)ic.lookup("java:comp/env/jdbc/localDB"); Connection con = ds.getConnection(); PreparedStatement st = con.prepareStatement("select * from product"); ResultSet rs = st.executeQuery(); out.println("<html>"); out.println("<head>"); out.println("<meta charset = \"UTF-8\">"); out.println("</head>"); out.println("<body>"); while(rs.next()){ out.println(rs.getInt("id")); out.println(":"); out.println(rs.getString("name")); out.println(":"); out.println(rs.getInt("price")); out.println("<br>"); } out.println("</body>"); out.println("</html>"); st.close(); con.close(); }catch(Exception e){ e.printStackTrace(out); } //Page.footer(out); } }
回答1件
あなたの回答
tips
プレビュー