2017-03-29 17 views
1

私はフォームを提出するときに投稿をデータベースに保存し、フォームの下に表示するフォーラムを作成しようとしています。 データベースに保存されていますが、ページをリロードした後にのみ表示されます。私たちがフォームを提出する際に、それが現れる方法はありますか?リロードせずにjspページからの応答を取得するには?

<%@ page import="java.sql.*"%> 
<%@page import="org.json.*"%> 
<% 
    System.out.println("Start"); 
    String value = request.getParameter("jsonData"); 
    JSONObject newObj = new JSONObject(); 

    try { 
     newObj = new JSONObject(request.getParameter("jsonData")); 
    } catch (JSONException e) { 
     e.printStackTrace(); 
    } 

    String title = ""; 
    String tag = ""; 
    String postData = ""; 

    try { 
     title = newObj.getJSONObject("mydata").getString("title"); 
     tag = newObj.getJSONObject("mydata").getString("tag"); 
     postData = newObj.getJSONObject("mydata").getString("postData"); 
    } catch (JSONException e) { 
     e.printStackTrace(); 
    } 
    try { 
     Class.forName("com.mysql.jdbc.Driver"); 
     Connection con = DriverManager.getConnection("jdbc:mysql://localhost:3306/mysql?useSSL=true", "root", "1111"); 
     //System.out.println(con); 
     PreparedStatement ps = con.prepareStatement("insert into forumdb.userpost(title,post,tag) values(?,?,?)"); 
     ps.setString(1, title); 
     ps.setString(2, postData); 
     ps.setString(3, tag); 
     ps.executeUpdate(); 
     con.close(); 
    } catch (Exception e) { 
    } 
    System.out.println("End"); 

    response.setContentType("text/html"); 
    response.getWriter().write("success"); 
%> 



var request; 
    function postArticle() { 
      var title=document.postform.title.value; 
      var postDescription = CKEDITOR.instances.postDescription.getData(); 
      var tag=document.postform.tag.value; 
      var myData = {"mydata": {"title": title, "tag": tag, "postData":postDescription}}; 
      $.ajax({ 
       type: "POST", 
       url: "/forum1/index.jsp", 
       data: {jsonData: JSON.stringify(myData)}, 
       dataType: "json", 
       success: function(){ 
        if(success==false) 
        { location.reload(); } 
        }  
      }); 
     } 
+0

あなたはajaxを利用できます。 –

+0

http://stackoverflow.com/questions/9280345/updating-contents-of-a-jsp-page-without-refreshing これを試してください、それは同じ概念を持っています。 –

答えて

-1

ページを更新せずにリクエストを送信したい場合は、 同じものにAJAXを使うことができます。 XHRは、AJAXでページにリクエストを送信し、ページをリフレッシュせずに必要な操作を実行するために使用されます。

関連する問題