• Servlet系列教材 (二十五)- JSON


     

    步骤1:先运行,看到效果,再学习 
    步骤2:模仿和排错
    步骤3:效果
    步骤4:资源
    步骤5:submit.html
    步骤6:SubmitServlet
    步骤7:web.xml
    步骤8:测试

    步骤 1 : 先运行,看到效果,再学习 

    老规矩,先下载下载区(点击进入)的可运行项目,配置运行起来,确认可用之后,再学习做了哪些步骤以达到这样的效果。

    步骤 2 : 模仿和排错

    在确保可运行项目能够正确无误地运行之后,再严格照着教程的步骤,对代码模仿一遍。 
    模仿过程难免代码有出入,导致无法得到期望的运行结果,此时此刻通过比较正确答案 ( 可运行项目 ) 和自己的代码,来定位问题所在。 
    采用这种方式,学习有效果,排错有效率,可以较为明显地提升学习速度,跨过学习路上的各个槛。 

    推荐使用diffmerge软件,进行文件夹比较。把你自己做的项目文件夹,和我的可运行项目文件夹进行比较。 
    这个软件很牛逼的,可以知道文件夹里哪两个文件不对,并且很明显地标记出来 
    这里提供了绿色安装和使用教程:diffmerge 下载和使用教程

    步骤 3 : 效果

    访问地址,提交数据

    http://127.0.0.1:8080/submit.html

    效果

    步骤 4 : 资源

    要运行起来需要jquery.min.js,各种jar包,都在下载区(点击进入)的j2ee.rar中提供,请自行下载解压获取。

    步骤 5 : submit.html

    点击提交之后,把form中的数据取出来,组织成json的格式,用ajax发送出去。
    这里用的ajax方式是 jquery的post函数, 请参考:使用post方式提交ajax

    JSON.stringify函数的作用是将一个javascript对象,转换为JSON格式的字符串。

    提交之后,将会看到如图所示的对话框

    这里还用到了jquery.min.js,请在下载区(点击进入)下载

    submit.html

    <!DOCTYPE html>

    <html>

    <head>

    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  

    <title>用AJAX以JSON方式提交数据</title>  

    <script type="text/javascript" src="jquery.min.js"></script>  

    </head>  

    <body>  

        <form >  

           名称:<input type="text" id="name"/><br/>  

            血量:<input type="text" id="hp"/><br/>  

            <input type="button" value="提交" id="sender">   

        </form>  

        <div id="messageDiv"></div>  

           

        <script>  

        $('#sender').click(function(){  

            var name=document.getElementById('name').value;  

            var hp=document.getElementById('hp').value;  

            var hero={"name":name,"hp":hp};  

            var url="submitServlet";  

               

            $.post(

                    url, 

                    {"data":JSON.stringify(hero)},

                    function(data) {  

                         alert("提交成功,请在Tomcat控制台查看服务端接收到的数据");

             });   

        });  

        </script>  

    </body>  

       

    </body>

    </html>

    步骤 6 : SubmitServlet

    1. 获取浏览器提交的字符串
    2. 把字符串转换为JSON对象
    3. 把JSON对象转换为Hero对象

    SubmitServlet

    public class Hero {

        private String name;

        private int hp;

        public String getName() {

            return name;

        }

        public void setName(String name) {

            this.name = name;

        }

        public int getHp() {

            return hp;

        }

        public void setHp(int hp) {

            this.hp = hp;

        }

        @Override

        public String toString() {

            return "Hero [name=" + name + ", hp=" + hp + "]";

        }

         

    }

    import java.io.IOException;

    import javax.servlet.ServletException;

    import javax.servlet.http.HttpServlet;

    import javax.servlet.http.HttpServletRequest;

    import javax.servlet.http.HttpServletResponse;

    import net.sf.json.JSONObject;  

       

    public class SubmitServlet extends HttpServlet {  

        protected void service(HttpServletRequest request, HttpServletResponse response)  

                throws ServletException, IOException {

            String data =request.getParameter("data");

             

            System.out.println("服务端接收到的数据是:" +data);

      

            JSONObject json=JSONObject.fromObject(data);  

              

            System.out.println("转换为JSON对象之后是:"+ json);

               

            Hero hero = (Hero)JSONObject.toBean(json,Hero.class);  

            System.out.println("转换为Hero对象之后是:"+hero);

        }  

    }  

    步骤 7 : web.xml

    配置映射

    <?xml version="1.0" encoding="UTF-8"?>

    <web-app>

        <servlet>

            <servlet-name>SubmitServlet</servlet-name>

            <servlet-class>SubmitServlet</servlet-class>

        </servlet>

        <servlet-mapping>

            <servlet-name>SubmitServlet</servlet-name>

            <url-pattern>/submitServlet</url-pattern>

        </servlet-mapping>

    </web-app>

    步骤 8 : 测试

    重启tomcat,访问地址:
     

    http://127.0.0.1:8080/submit.html


    更多内容,点击了解: https://how2j.cn/k/servlet/servlet-submit-json/1323.html

  • 相关阅读:
    多视点视频的分类和技术标准
    判断任意控制台输入十进制数是否为水仙花数(C++)
    mysql创建新用户并授权限
    Linux下使用sqlplus查询数据时乱行显示问题
    读Strarling有感
    Starling性能优化技巧
    如何在Django Rest Framework中过滤嵌套的序列化器?
    sql 高级教程
    小技巧字符串比较
    WPF MVVM DataGrid数据直更新
  • 原文地址:https://www.cnblogs.com/Lanht/p/12615401.html
Copyright © 2020-2023  润新知